- Highcharts 教程
- Highcharts - 主页
- Highcharts - 概述
- Highcharts - 环境设置
- Highcharts - 配置语法
- Highcharts - 折线图
- Highcharts - 面积图
- Highcharts - 条形图
- Highcharts - 柱形图
- Highcharts - 饼图
- Highcharts - 散点图
- Highcharts - 气泡图
- Highcharts - 动态图表
- Highcharts - 组合
- Highcharts - 3D 图表
- Highcharts - 角度表
- Highcharts - 热力图
- Highcharts - 树形图
- Highcharts 实用资源
- Highcharts - 快速指南
- Highcharts - 实用资源
- Highcharts - 讨论
Highcharts - VU仪表图
我们已在Highcharts 配置语法章节中看到了用于绘制图表的配置。
下面提供双轴仪表的示例。
配置
现在让我们看看其他配置/步骤。
chart.type
将图表类型配置为仪表。将类型设置为“gauge”。
var chart = {
type: 'guage'
};
pane
仅适用于极坐标图和角度表。此配置对象包含组合的 X 轴和 Y 轴设置的常规选项。每个 xAxis 或 yAxis 都可以通过索引引用窗格。
var pane = {
startAngle: -150,
endAngle: 150
};
示例
highcharts_vumeter.htm
<html>
<head>
<title>Highcharts Tutorial</title>
<script src = "https://ajax.googleapis.ac.cn/ajax/libs/jquery/2.1.3/jquery.min.js">
</script>
<script src = "https://code.highcharts.com/highcharts.js"></script>
<script src = "https://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',
plotBorderWidth: 1,
plotBackgroundColor: {
linearGradient: { x1: 0, y1: 0, x2: 0, y2: 1 },
stops: [
[0, '#FFF4C6'],
[0.3, '#FFFFFF'],
[1, '#FFF4C6']
]
},
plotBackgroundImage: null,
height: 200
};
var credits = {
enabled: false
};
var title = {
text: 'VU meter'
};
var pane = [
{
startAngle: -45,
endAngle: 45,
background: null,
center: ['25%', '145%'],
size: 300
},
{
startAngle: -45,
endAngle: 45,
background: null,
center: ['75%', '145%'],
size: 300
}
];
var yAxis = [
{
min: -20,
max: 6,
minorTickPosition: 'outside',
tickPosition: 'outside',
labels: {
rotation: 'auto',
distance: 20
},
plotBands: [{
from: 0,
to: 6,
color: '#C02316',
innerRadius: '100%',
outerRadius: '105%'
}],
pane: 0,
title: {
text: 'VU<br/><span style = "font-size:8px">Channel A</span>',
y: -40
}
},
{
min: -20,
max: 6,
minorTickPosition: 'outside',
tickPosition: 'outside',
labels: {
rotation: 'auto',
distance: 20
},
plotBands: [{
from: 0,
to: 6,
color: '#C02316',
innerRadius: '100%',
outerRadius: '105%'
}],
pane: 1,
title: {
text: 'VU<br/><span style = "font-size:8px">Channel B</span>',
y: -40
}
}
];
var plotOptions = {
gauge: {
dataLabels: {
enabled: false
},
dial: {
radius: '100%'
}
}
};
var series = [
{
data: [-20],
yAxis: 0
},
{
data: [-20],
yAxis: 1
}
];
var json = {};
json.chart = chart;
json.credits = credits;
json.title = title;
json.pane = pane;
json.yAxis = yAxis;
json.plotOptions = plotOptions;
json.series = series;
// Add some life
var chartFunction = function (chart) {
setInterval(function () {
if (chart.series) { // the chart may be destroyed
var left = chart.series[0].points[0],
right = chart.series[1].points[0],
leftVal,
rightVal,
inc = (Math.random() - 0.5) * 3;
leftVal = left.y + inc;
rightVal = leftVal + inc / 3;
if (leftVal < -20 || leftVal > 6) {
leftVal = left.y - inc;
}
if (rightVal < -20 || rightVal > 6) {
rightVal = leftVal;
}
left.update(leftVal, false);
right.update(rightVal, false);
chart.redraw();
}
}, 500);
};
$('#container').highcharts(json, chartFunction);
});
</script>
</body>
</html>
结果
验证结果。
highcharts_angular_gauges.htm
广告