You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
224 lines
4.6 KiB
224 lines
4.6 KiB
2 years ago
|
<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="https://d3js.org/d3.v5.min.js" charset="utf-8"></script>
|
||
|
<script src="../js/c3.js"></script>
|
||
|
<script>
|
||
|
|
||
|
var padding = {}, types = {}, chart, generate = function () { return c3.generate({
|
||
|
data: {
|
||
|
columns: [
|
||
|
['data1'],
|
||
|
['data2'],
|
||
|
],
|
||
|
types: types,
|
||
|
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({
|
||
|
rows: [
|
||
|
['data1', 'data2', 'data3'],
|
||
|
[500, 100, 200],
|
||
|
[200, null, null],
|
||
|
[100, 50, null]
|
||
|
],
|
||
|
duration: 1500,
|
||
|
|
||
|
done: function () {
|
||
|
// Load 2 data without data2 and remove 1 data
|
||
|
chart.flow({
|
||
|
columns: [
|
||
|
['data1', 200, 300],
|
||
|
['data3', 100, 100]
|
||
|
],
|
||
|
length: 0,
|
||
|
duration: 1500,
|
||
|
|
||
|
done: function () {
|
||
|
chart.flow({
|
||
|
columns: [
|
||
|
['data1', 200, 300],
|
||
|
['data2', 200, 300],
|
||
|
['data3', 100, 100]
|
||
|
],
|
||
|
length: 2,
|
||
|
duration: 1500,
|
||
|
done: function () {
|
||
|
|
||
|
chart.flow({
|
||
|
columns: [
|
||
|
['data1', 500],
|
||
|
['data2', 100],
|
||
|
['data3', 200]
|
||
|
],
|
||
|
length: 1,
|
||
|
duration: 1500,
|
||
|
});
|
||
|
}
|
||
|
|
||
|
});
|
||
|
}// done
|
||
|
|
||
|
});
|
||
|
},
|
||
|
|
||
|
});
|
||
|
}, 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,
|
||
|
done: 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();
|
||
|
|
||
|
// Test for no padding
|
||
|
setTimeout(function () {
|
||
|
padding = {left: 0, right: 0};
|
||
|
run();
|
||
|
}, 22000);
|
||
|
|
||
|
// Test for other chart types
|
||
|
setTimeout(function () {
|
||
|
types = {
|
||
|
data2: 'area',
|
||
|
data3: 'bar',
|
||
|
};
|
||
|
run();
|
||
|
}, 45000);
|
||
|
|
||
|
</script>
|
||
|
</body>
|
||
|
</html>
|