g214/static/bower_components/echarts/test/pie-calculable.html

171 lines
6.1 KiB
HTML

<html>
<head>
<meta charset="utf-8">
<script src="esl.js"></script>
<script src="config.js"></script>
<script src="lib/dat.gui.min.js"></script>
</head>
<body>
<style>
html, body, #main {
width: 100%;
height: 100%;
background-image: url(old_mathematics.png);
background-repeat: repeat;
}
</style>
<div id="main"></div>
<script>
require([
'echarts',
'echarts/chart/pie',
'echarts/component/legend',
'echarts/component/grid',
'echarts/component/tooltip',
'echarts/component/toolbox'
], function (echarts) {
var mainEl = document.getElementById('main');
var chart = echarts.init(mainEl);
var colorList = [
'#c23531', '#2f4554', '#61a0a8',
'#d48265', '#91c7ae','#749f83',
'#ca8622', '#bda29a','#6e7074',
'#546570', '#c4ccd3'
];
var data = [
{value: 335, name: '直接访问'},
{value: 310, name: '邮件营销'},
{value: 234, name: '联盟广告'},
{value: 135, name: '视频广告'},
{value: 1548, name: '搜索引擎'}
];
var legendData = [];
echarts.util.each(data, function (item, index) {
item.itemStyle = {
normal: {color: colorList[index]}
};
legendData.push(item.name);
});
chart.setOption({
legend: {
data: legendData,
formatter: function (name) {
return name.replace(/\n/g, ' + ');
}
},
toolbox: {
left: 'left',
feature: {
dataView: {},
saveAsImage: {}
}
},
tooltip: {},
series: [{
name: 'pie',
type: 'pie',
selectedMode: 'single',
selectedOffset: 30,
clockwise: true,
label: {
normal: {
textStyle: {
fontSize: 18,
color: '#333'
}
}
},
labelLine: {
normal: {
lineStyle: {
color: '#333'
}
}
},
data: data
}]
});
var dragging;
var draggingDataIndex;
var dx;
var dy;
var zr = chart.getZr();
chart.on('mousedown', function (params) {
draggingDataIndex = getHoveredDataIndex(params);
if (draggingDataIndex != null) {
var srcSector = params.event.target;
dragging = new echarts.graphic.Sector({
shape: echarts.util.extend({}, srcSector.shape),
style: {
fill: srcSector.style.fill,
opacity: 0.5
},
silent: true,
z: 10000
});
dx = params.event.offsetX - srcSector.shape.cx;
dy = params.event.offsetY - srcSector.shape.cy;
zr.add(dragging);
}
});
chart.on('mouseup', function (params) {
if (dragging) {
var targetDataIndex = getHoveredDataIndex(params);
if (targetDataIndex != null
&& targetDataIndex !== draggingDataIndex
) {
data[targetDataIndex].value += data[draggingDataIndex].value;
data[targetDataIndex].name += '\n' + data[draggingDataIndex].name;
legendData[targetDataIndex] = data[targetDataIndex].name;
data.splice(draggingDataIndex, 1);
legendData.splice(draggingDataIndex, 1);
chart.setOption({
legend: {data: legendData},
series: {data: data}
});
}
}
});
mainEl.addEventListener('mousemove', function (e) {
var box = mainEl.getBoundingClientRect();
var zrX = e.clientX - box.left;
var zrY = e.clientY - box.top;
if (dragging) {
dragging.setShape({
cx: zrX - dx,
cy: zrY - dy
});
}
});
document.addEventListener('mouseup', function (e) {
if (dragging) {
zr.remove(dragging);
dragging = null;
}
});
function getHoveredDataIndex(params) {
return params.componentType === 'series'
&& params.componentSubType === 'pie'
&& params.dataIndex;
}
})
</script>
</body>
</html>