|
|
|
<html>
|
|
|
|
<head>
|
|
|
|
<link rel="stylesheet" type="text/css" href="/css/c3.css">
|
|
|
|
<style>
|
|
|
|
.c3-region-1 {
|
|
|
|
fill: #dd3333;
|
|
|
|
fill-opacity: 0.8
|
|
|
|
}
|
|
|
|
</style>
|
|
|
|
</head>
|
|
|
|
<body>
|
|
|
|
<div id="chart"></div>
|
|
|
|
|
|
|
|
<script src="http://d3js.org/d3.v3.min.js" charset="utf-8"></script>
|
|
|
|
<script src="/js/c3.js"></script>
|
|
|
|
<script>
|
|
|
|
|
|
|
|
var padding = {}, chart, generate = function () { return c3.generate({
|
|
|
|
data: {
|
|
|
|
columns: [
|
|
|
|
['data1'],
|
|
|
|
['data2'],
|
|
|
|
],
|
|
|
|
types: {
|
|
|
|
data2: 'area',
|
|
|
|
data3: 'bar',
|
|
|
|
},
|
|
|
|
labels: true
|
|
|
|
},
|
|
|
|
bar: {
|
|
|
|
width: 10
|
|
|
|
},
|
|
|
|
axis: {
|
|
|
|
x: {
|
|
|
|
padding: padding
|
|
|
|
},
|
|
|
|
y: {
|
|
|
|
/*
|
|
|
|
min: -100,
|
|
|
|
max: 1000
|
|
|
|
*/
|
|
|
|
}
|
|
|
|
},
|
|
|
|
grid: {
|
|
|
|
x: {
|
|
|
|
show: true,
|
|
|
|
lines: [{value: 3, text:'Label 3'}, {value: 4.5, text: 'Label 4.5'}]
|
|
|
|
},
|
|
|
|
y: {
|
|
|
|
show: true
|
|
|
|
}
|
|
|
|
},
|
|
|
|
regions: [
|
|
|
|
{start:2, end:4, class:'region1'},
|
|
|
|
{start:100, end:200, axis:'y'},
|
|
|
|
],
|
|
|
|
});
|
|
|
|
};
|
|
|
|
|
|
|
|
function run() {
|
|
|
|
|
|
|
|
chart = generate();
|
|
|
|
|
|
|
|
setTimeout(function () {
|
|
|
|
// Load only one data
|
|
|
|
chart.flow({
|
|
|
|
columns: [
|
|
|
|
['data1', 500, 200, 100],
|
|
|
|
['data2', 100, null, 50],
|
|
|
|
['data3', 200, null, null],
|
|
|
|
],
|
|
|
|
duration: 1500,
|
|
|
|
|
|
|
|
onend: function () {
|
|
|
|
// Load 2 data without data2 and remove 1 data
|
|
|
|
chart.flow({
|
|
|
|
columns: [
|
|
|
|
['data1', 200, 300],
|
|
|
|
['data3', 100, 100]
|
|
|
|
],
|
|
|
|
length: 0,
|
|
|
|
duration: 1500,
|
|
|
|
|
|
|
|
onend: function () {
|
|
|
|
chart.flow({
|
|
|
|
columns: [
|
|
|
|
['data1', 200, 300],
|
|
|
|
['data2', 200, 300],
|
|
|
|
['data3', 100, 100]
|
|
|
|
],
|
|
|
|
length: 2,
|
|
|
|
duration: 1500,
|
|
|
|
onend: function () {
|
|
|
|
|
|
|
|
chart.flow({
|
|
|
|
columns: [
|
|
|
|
['data1', 500],
|
|
|
|
['data2', 100],
|
|
|
|
['data3', 200]
|
|
|
|
],
|
|
|
|
length: 1,
|
|
|
|
duration: 1500,
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
});
|
|
|
|
}// onend
|
|
|
|
|
|
|
|
});
|
|
|
|
},
|
|
|
|
|
|
|
|
});
|
|
|
|
}, 1000);
|
|
|
|
|
|
|
|
setTimeout(function () {
|
|
|
|
chart.flow({
|
|
|
|
columns: [
|
|
|
|
['data1', 250],
|
|
|
|
['data2', 350],
|
|
|
|
['data3', 150]
|
|
|
|
],
|
|
|
|
length: 0
|
|
|
|
});
|
|
|
|
}, 9000);
|
|
|
|
|
|
|
|
setTimeout(function () {
|
|
|
|
chart.flow({
|
|
|
|
columns: [
|
|
|
|
['data1', 100],
|
|
|
|
['data2', 50],
|
|
|
|
['data3', 300]
|
|
|
|
],
|
|
|
|
length: 2
|
|
|
|
});
|
|
|
|
}, 10000);
|
|
|
|
|
|
|
|
setTimeout(function () {
|
|
|
|
chart.flow({
|
|
|
|
columns: [
|
|
|
|
['data1', 600],
|
|
|
|
['data2', 400],
|
|
|
|
['data3', 500]
|
|
|
|
],
|
|
|
|
to: 2,
|
|
|
|
});
|
|
|
|
}, 11000);
|
|
|
|
|
|
|
|
setTimeout(function () {
|
|
|
|
chart.flow({
|
|
|
|
columns: [
|
|
|
|
['data1', 100],
|
|
|
|
['data2', 200],
|
|
|
|
['data3', 300]
|
|
|
|
]
|
|
|
|
});
|
|
|
|
}, 12000);
|
|
|
|
|
|
|
|
setTimeout(function () {
|
|
|
|
chart = generate();
|
|
|
|
}, 13000);
|
|
|
|
|
|
|
|
setTimeout(function () {
|
|
|
|
chart.flow({
|
|
|
|
columns: [
|
|
|
|
['data1', 500, 100],
|
|
|
|
['data2', 100, 200],
|
|
|
|
['data3', 200, 300],
|
|
|
|
],
|
|
|
|
duration: 1500,
|
|
|
|
onend: function () {
|
|
|
|
chart.flow({
|
|
|
|
columns: [
|
|
|
|
['data1', 200],
|
|
|
|
['data3', 100]
|
|
|
|
],
|
|
|
|
// duration: 1000,
|
|
|
|
length: 1
|
|
|
|
});
|
|
|
|
},
|
|
|
|
});
|
|
|
|
}, 14000);
|
|
|
|
|
|
|
|
setTimeout(function () {
|
|
|
|
chart.flow({
|
|
|
|
columns: [
|
|
|
|
['data1', 200],
|
|
|
|
['data2', 300],
|
|
|
|
['data3', 100]
|
|
|
|
],
|
|
|
|
to: 1,
|
|
|
|
});
|
|
|
|
}, 18000);
|
|
|
|
|
|
|
|
setTimeout(function () {
|
|
|
|
chart.flow({
|
|
|
|
columns: [
|
|
|
|
['data1', 200],
|
|
|
|
['data2', 300],
|
|
|
|
['data3', 400]
|
|
|
|
]
|
|
|
|
});
|
|
|
|
}, 19000);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
run();
|
|
|
|
|
|
|
|
setTimeout(function () {
|
|
|
|
padding = {left: 0, right: 0};
|
|
|
|
run();
|
|
|
|
}, 22000);
|
|
|
|
|
|
|
|
</script>
|
|
|
|
</body>
|
|
|
|
</html>
|