blob: e3f9631afff73b38ab54f7e3c98c58422dafa256 [file] [log] [blame]
var paper = 'image://';
var startData = 13000;
var maxData = 18000;
var minData = 5000;
option = {
backgroundColor: '#0f375f',
tooltip: {},
legend: {
data: ['all'],
textStyle: {color: '#ddd'}
},
grid: {
right: 20,
left: 140,
bottom: 160
},
xAxis: {
data: ['a', 'b', 'c', 'd'],
axisTick: {show: false},
axisLine: {
lineStyle: {
color: '#ddd'
}
},
axisLabel: {show: false}
},
yAxis: {
splitLine: {show: false},
axisTick: {
lineStyle: {
color: '#ddd'
}
},
axisLine: {
lineStyle: {
color: '#ddd'
}
},
axisLabel: {
textStyle: {
color: '#ddd'
}
}
},
animationEasing: 'cubicOut',
animationDuration: 100,
animationDurationUpdate: 2000,
series: [{
type: 'pictorialBar',
name: 'all',
id: 'paper',
hoverAnimation: true,
label: {
normal: {
show: true,
position: 'top',
formatter: '{c} km',
textStyle: {
fontSize: 16,
color: '#e54035'
}
}
},
symbol: paper,
symbolSize: ['70%', 50],
symbolMargin: '-25%',
data: [{
value: maxData,
symbolRepeat: true
}, {
value: startData,
symbolRepeat: true
}, {
value: startData,
symbolBoundingData: startData,
symbolRepeat: true
}, {
value: startData,
symbolBoundingData: startData,
symbolRepeat: 20
}],
markLine: {
symbol: ['none', 'none'],
label: {
normal: {show: false}
},
lineStyle: {
normal: {
color: '#e54035'
}
},
data: [{
yAxis: startData
}]
}
}, {
name: 'all',
type: 'pictorialBar',
symbol: 'circle',
itemStyle: {
normal: {
color: '#185491'
}
},
silent: true,
symbolSize: ['150%', 50],
symbolOffset: [0, 20],
z: -10,
data: [1, 1, 1, 1]
}]
};
setInterval(function () {
var dynamicData = Math.round(Math.random() * (maxData - minData) + minData);
myChart.setOption({
series: [{
id: 'paper',
data: [{
value: maxData,
symbolRepeat: true
}, {
value: dynamicData,
symbolRepeat: true
}, {
value: dynamicData,
symbolBoundingData: dynamicData,
symbolRepeat: true
}, {
value: dynamicData,
symbolBoundingData: dynamicData,
symbolRepeat: 20
}],
markLine: {
data: [{
yAxis: dynamicData
}]
}
}]
});
}, 3000);
// Add descriptions.
function addDescriptions() {
var descriptions = [
[
'symbolBoundingData:',
'value:',
'symbolRepeat:',
'characteristic:',
],
[
'default',
'max value',
'true (auto)',
'This is a standard'
],
[
'default',
'current value',
'true (auto)',
'Not accurate\nSymbol gap stable\nAppropriate to compare\nwith other bar'
],
[
'current value',
'current value',
'true (auto)',
'Accurate\nSymbol gap unstable\nInappropriate to compare\nwith other bar'
],
[
'current value',
'current value',
'20 (a fixed number)',
'Accurate\nSymbol gap unstable\nNot responsive'
]
];
myChart.setOption({
graphic: descriptions.map(function (item, index) {
var pos = myChart.convertToPixel('grid', [Math.max(index - 1, 0), -1000]);
return {
type: 'group',
position: pos,
left: index ? null : 10,
children: [{
type: 'text',
left: 'center',
top: 0,
style: {
text: descriptions[index].join('\n\n'),
fill: index ? '#fff' : 'yellow',
textAlign: index ? 'left' : 'right'
},
z: 101
}]
};
})
}, {silent: true});
}
setTimeout(function () {
addDescriptions();
myChart.on('updated', addDescriptions);
}, 100);