mirror of
https://github.com/chartjs/Chart.js.git
synced 2024-10-07 04:39:06 +02:00
141 lines
5.6 KiB
HTML
141 lines
5.6 KiB
HTML
<!doctype html>
|
|
<html>
|
|
|
|
<head>
|
|
<title>Bar Chart Multi Axis</title>
|
|
<script src="../node_modules/jquery/dist/jquery.min.js"></script>
|
|
<script src="../Chart.js"></script>
|
|
</head>
|
|
|
|
<body>
|
|
<div style="width: 50%">
|
|
<canvas id="canvas" height="450" width="600"></canvas>
|
|
</div>
|
|
<button id="randomizeData">Randomize Data</button>
|
|
<script>
|
|
var randomScalingFactor = function() {
|
|
return (Math.random() > 0.5 ? 1.0 : -1.0) * Math.round(Math.random() * 100);
|
|
};
|
|
var randomColorFactor = function() {
|
|
return Math.round(Math.random() * 255);
|
|
};
|
|
var randomColor = function() {
|
|
return 'rgba(' + randomColorFactor() + ',' + randomColorFactor() + ',' + randomColorFactor() + ',.7)';
|
|
};
|
|
|
|
var barChartData = {
|
|
labels: ["January", "February", "March", "April", "May", "June", "July"],
|
|
datasets: [{
|
|
label: 'Dataset 1',
|
|
backgroundColor: "rgba(220,220,220,0.5)",
|
|
yAxisID: "y-axis-1",
|
|
data: [randomScalingFactor(), randomScalingFactor(), randomScalingFactor(), randomScalingFactor(), randomScalingFactor(), randomScalingFactor(), randomScalingFactor()]
|
|
}, {
|
|
label: 'Dataset 2',
|
|
backgroundColor: "rgba(151,187,205,0.5)",
|
|
yAxisID: "y-axis-2",
|
|
data: [randomScalingFactor(), randomScalingFactor(), randomScalingFactor(), randomScalingFactor(), randomScalingFactor(), randomScalingFactor(), randomScalingFactor()]
|
|
}, {
|
|
label: 'Dataset 3',
|
|
backgroundColor: [randomColor(), randomColor(), randomColor(), randomColor(), randomColor(), randomColor(), randomColor()],
|
|
yAxisID: "y-axis-1",
|
|
data: [randomScalingFactor(), randomScalingFactor(), randomScalingFactor(), randomScalingFactor(), randomScalingFactor(), randomScalingFactor(), randomScalingFactor()]
|
|
}]
|
|
|
|
};
|
|
window.onload = function() {
|
|
var ctx = document.getElementById("canvas").getContext("2d");
|
|
window.myBar = new Chart(ctx).Bar({
|
|
data: barChartData,
|
|
options: {
|
|
responsive: true,
|
|
hoverMode: 'label',
|
|
hoverAnimationDuration: 400,
|
|
stacked: false,
|
|
scales: {
|
|
yAxes: [{
|
|
scaleType: "linear", // only linear but allow scale type registration. This allows extensions to exist solely for log scale for instance
|
|
display: true,
|
|
position: "left",
|
|
id: "y-axis-1",
|
|
|
|
// grid line settings
|
|
gridLines: {
|
|
show: true,
|
|
color: "rgba(0, 0, 0, 0.05)",
|
|
lineWidth: 1,
|
|
drawOnChartArea: true,
|
|
drawTicks: true,
|
|
zeroLineWidth: 1,
|
|
zeroLineColor: "rgba(0,0,0,0.25)",
|
|
},
|
|
|
|
// scale numbers
|
|
beginAtZero: false,
|
|
integersOnly: false,
|
|
override: null,
|
|
|
|
// label settings
|
|
labels: {
|
|
show: true,
|
|
template: "<%=value%>",
|
|
fontSize: 12,
|
|
fontStyle: "normal",
|
|
fontColor: "#666",
|
|
fontFamily: "Helvetica Neue",
|
|
}
|
|
}, {
|
|
scaleType: "linear", // only linear but allow scale type registration. This allows extensions to exist solely for log scale for instance
|
|
display: true,
|
|
position: "right",
|
|
id: "y-axis-2",
|
|
|
|
// grid line settings
|
|
gridLines: {
|
|
show: true,
|
|
color: "rgba(0, 0, 0, 0.05)",
|
|
lineWidth: 1,
|
|
drawOnChartArea: false, // only want the grid lines for one axis to show up
|
|
drawTicks: false,
|
|
zeroLineWidth: 1,
|
|
zeroLineColor: "rgba(0,0,0,0.25)",
|
|
},
|
|
|
|
// scale numbers
|
|
beginAtZero: false,
|
|
integersOnly: false,
|
|
override: null,
|
|
|
|
// label settings
|
|
labels: {
|
|
show: true,
|
|
template: "<%=value%>",
|
|
fontSize: 12,
|
|
fontStyle: "normal",
|
|
fontColor: "#666",
|
|
fontFamily: "Helvetica Neue",
|
|
}
|
|
}],
|
|
}
|
|
}
|
|
});
|
|
};
|
|
|
|
$('#randomizeData').click(function() {
|
|
$.each(barChartData.datasets, function(i, dataset) {
|
|
if (Chart.helpers.isArray(dataset.backgroundColor)) {
|
|
dataset.backgroundColor= [randomColor(), randomColor(), randomColor(), randomColor(), randomColor(), randomColor(), randomColor()];
|
|
} else {
|
|
dataset.backgroundColor= randomColor();
|
|
}
|
|
|
|
dataset.data = [randomScalingFactor(), randomScalingFactor(), randomScalingFactor(), randomScalingFactor(), randomScalingFactor(), randomScalingFactor(), randomScalingFactor()];
|
|
|
|
});
|
|
window.myBar.update();
|
|
});
|
|
</script>
|
|
</body>
|
|
|
|
</html>
|