Highcharts 雙軸車速表
以下實例演示了雙軸車速表。
我們在前面的章節已經瞭解了 Highcharts 基本配置語法。接下來讓我們來看下其他的配置。
配置
chart.type 配置
配置 chart 的 type 為 'gauge' 。chart.type 描述了圖表類型。默認值為 "line"。
var chart = {
type: 'gauge'
};
pane 配置
pane 只適用在極座標圖和角度測量儀。此可配置對象持有組合x軸和y周的常規選項。每個x軸和y軸都可以通過索引關聯到窗格中。
var pane = {
startAngle: -150, // x軸或測量軸的開始度數,以度數的方式給出。0是北
endAngle: 150 //x軸極座標或角度軸的最終度數,以度數的方式給出。0是北
};
實例
檔案名:highcharts_guage_dualaxes.htm
<html>
<head>
<meta charset="UTF-8" />
<title>Highcharts 教學 | IT研修(xuhuhu.com)</title>
<script src="http://apps.bdimg.com/libs/jquery/2.1.4/jquery.min.js"></script>
<script src="http://code.highcharts.com/highcharts.js"></script>
<script src="http://code.highcharts.com/highcharts-more.js"></script>
</head>
<body>
<div id="container" style="width: 550px; height: 400px; margin: 0 auto"></div>
<script language="JavaScript">
$(document).ready(function() {
var chart = {
type: 'gauge',
plotBackgroundColor: null,
plotBackgroundImage: null,
plotBorderWidth: 0,
plotShadow: false
};
var credits = {
enabled: false
};
var title = {
text: '雙軸車速表'
};
var pane = {
startAngle: -150,
endAngle: 150
};
// the value axis
var yAxis = [{
min: 0,
max: 200,
lineColor: '#339',
tickColor: '#339',
minorTickColor: '#339',
offset: -25,
lineWidth: 2,
labels: {
distance: -20,
rotation: 'auto'
},
tickLength: 5,
minorTickLength: 5,
endOnTick: false
}, {
min: 0,
max: 124,
tickPosition: 'outside',
lineColor: '#933',
lineWidth: 2,
minorTickPosition: 'outside',
tickColor: '#933',
minorTickColor: '#933',
tickLength: 5,
minorTickLength: 5,
labels: {
distance: 12,
rotation: 'auto'
},
offset: -20,
endOnTick: false
}];
var series= [{
name: 'Speed',
data: [80],
dataLabels: {
formatter: function () {
var kmh = this.y,
mph = Math.round(kmh * 0.621);
return '<span style="color:#339">' + kmh + ' km/h</span><br/>' +
'<span style="color:#933">' + mph + ' mph</span>';
},
backgroundColor: {
linearGradient: {
x1: 0,
y1: 0,
x2: 0,
y2: 1
},
stops: [
[0, '#DDD'],
[1, '#FFF']
]
}
},
tooltip: {
valueSuffix: ' km/h'
}
}];
var json = {};
json.chart = chart;
json.credits = credits;
json.title = title;
json.pane = pane;
json.yAxis = yAxis;
json.series = series;
// Add some life
var chartFunction = function (chart) {
setInterval(function () {
var point = chart.series[0].points[0],
newVal,
inc = Math.round((Math.random() - 0.5) * 20);
newVal = point.y + inc;
if (newVal < 0 || newVal > 200) {
newVal = point.y - inc;
}
point.update(newVal);
}, 3000);
};
$('#container').highcharts(json, chartFunction);
});
</script>
</body>
</html>
以上實例輸出結果為:

Highcharts 測量圖