blob: d05aa8754b306698f426eae1030f64fc7a15b668 [file] [log] [blame]
/*
title: Transition of Parliament and Pie Chart
category: custom, animtion
titleCN: 自定义议会图与饼图过渡动画
difficulty: 10
*/
var data = [
{ value: 800, name: 'A' },
{ value: 635, name: 'B' },
{ value: 580, name: 'C' },
{ value: 484, name: 'D' },
{ value: 300, name: 'E' },
{ value: 200, name: 'F' }
];
var defaultPalette = [
// '#51689b', '#ce5c5c', '#fbc357', '#8fbf8f', '#659d84', '#fb8e6a', '#c77288', '#786090', '#91c4c5', '#6890ba'
'#5470c6',
'#91cc75',
'#fac858',
'#ee6666',
'#73c0de',
'#3ba272',
'#fc8452',
'#9a60b4',
'#ea7ccc'
];
var radius = ['30%', '80%'];
var pieOption = {
series: [{
type: 'pie',
id: 'distribution',
radius: radius,
label: {
show: false
},
universalTransition: true,
animationDurationUpdate: 1000,
data: data
}]
};
var parliamentOption = (function () {
var sum = data.reduce(function (sum, cur) {
return sum + cur.value;
}, 0);
var angles = [];
var startAngle = -Math.PI / 2;
var curAngle = startAngle;
data.forEach(function (item) {
angles.push(curAngle);
curAngle += (item.value / sum) * Math.PI * 2;
});
angles.push(startAngle + Math.PI * 2);
function parliamentLayout(startAngle, endAngle, totalAngle, r0, r1, size) {
var rowsCount = Math.ceil((r1 - r0) / size);
var points = [];
var r = r0;
for (var i = 0; i < rowsCount; i++) {
// Recalculate size
var totalRingSeatsNumber = Math.round((totalAngle * r) / size);
var newSize = (totalAngle * r) / totalRingSeatsNumber;
for (
var k = Math.floor((startAngle * r) / newSize) * newSize;
k < Math.floor((endAngle * r) / newSize) * newSize - 1e-6;
k += newSize
) {
var angle = k / r;
var x = Math.cos(angle) * r;
var y = Math.sin(angle) * r;
points.push([x, y]);
}
r += size;
}
return points;
}
return {
series: {
type: 'custom',
id: 'distribution',
data: data,
coordinateSystem: undefined,
universalTransition: true,
animationDurationUpdate: 1000,
renderItem: function (params, api) {
var idx = params.dataIndex;
var viewSize = Math.min(api.getWidth(), api.getHeight());
var r0 = ((parseFloat(radius[0]) / 100) * viewSize) / 2;
var r1 = ((parseFloat(radius[1]) / 100) * viewSize) / 2;
var cx = api.getWidth() * 0.5;
var cy = api.getHeight() * 0.5;
var size = viewSize / 50;
var points = parliamentLayout(
angles[idx],
angles[idx + 1],
Math.PI * 2,
r0,
r1,
size + 3
);
return {
type: 'group',
children: points.map(function (pt) {
return {
type: 'circle',
autoBatch: true,
shape: {
cx: cx + pt[0],
cy: cy + pt[1],
r: size / 2
},
style: {
fill: defaultPalette[idx % defaultPalette.length]
}
};
})
};
}
}
};
})();
var currentOption = option = pieOption;
setInterval(function () {
currentOption = currentOption === pieOption ? parliamentOption : pieOption;
myChart.setOption(currentOption);
}, 2000);