<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>ECharts</title>
<!-- 引入 echarts.js -->
<script src="js/echarts.min.js"></script>
<script src="js/jquery-1.11.0.min.js"></script>
<script src="dist/extension/dataTool.js"></script>
</head>
<body>
<!-- 为ECharts准备一个具备大小(宽高)的Dom -->
<div id="main" style="width: 1024px;height:768px;"></div>
<script type="text/javascript">
// 基于准备好的dom,初始化echarts实例
var myChart = echarts.init(document.getElementById('main'));
var option;
var treeDataURI = '';
var beginYear = 2016;
var endYear = 2050;
var lineCount = 10;
// Basic option:
option = {
color: ['#e54035'],
xAxis: {
axisLine: {
show: false
},
axisLabel: {
show: false
},
axisTick: {
show: false
},
splitLine: {
show: false
},
name: beginYear,
nameLocation: 'middle',
nameGap: 40,
nameTextStyle: {
color: 'green',
fontSize: 30,
fontFamily: 'Arial'
},
min: -2800,
max: 2800
},
yAxis: {
data: makeCategoryData(),
show: false
},
grid: {
top: 'center',
height: 280
},
series: [{
name: 'all',
type: 'pictorialBar',
symbol: 'image://' + treeDataURI,
symbolSize: [30, 55],
symbolRepeat: true,
data: makeSeriesData(beginYear),
animationEasing: 'elasticOut'
}, {
name: 'all',
type: 'pictorialBar',
symbol: 'image://' + treeDataURI,
symbolSize: [30, 55],
symbolRepeat: true,
data: makeSeriesData(beginYear, true),
animationEasing: 'elasticOut'
}]
};
// Make fake data.
function makeCategoryData() {
var categoryData = [];
for(var i = 0; i < lineCount; i++) {
categoryData.push(i + 'a');
}
return categoryData;
}
function makeSeriesData(year, negative) {
// make a fake value just for demo.
var r = (year - beginYear + 1) * 10;
var seriesData = [];
for(var i = 0; i < lineCount; i++) {
var sign = (negative ? -1 * ((i % 3) ? 0.9 : 1) : 1 * (((i + 1) % 3) ? 0.9 : 1));
seriesData.push({
value: 0,
value: sign * (
year <= beginYear + 1 ?
(Math.abs(i - lineCount / 2 + 0.5) < lineCount / 5 ? 5 : 0) :
(lineCount - Math.abs(i - lineCount / 2 + 0.5)) * r
),
symbolOffset: (i % 2) ? ['50%', 0] : null
});
}
return seriesData;
}
// Set dynamic data.
var currentYear = beginYear;
setInterval(function() {
currentYear++;
if(currentYear > endYear) {
currentYear = beginYear;
}
myChart.setOption({
xAxis: {
name: currentYear
},
series: [{
data: makeSeriesData(currentYear)
}, {
data: makeSeriesData(currentYear, true)
}]
});
}, 800);
myChart.setOption(option);
</script>
</body>
</html>