HighCharts.StockChart工具提示悬停数据点不正确
问题描述:
我试图以渐进方式向图表添加新点。添加新点并设置新的最小/最大值后,工具提示标签显示不正确。HighCharts.StockChart工具提示悬停数据点不正确
小提琴:http://jsfiddle.net/aAFLX/
$(function() {
Highcharts.setOptions({
global : {
useUTC : false
},
scrollbar:{
enabled: true
},
lang: {
rangeSelectorZoom: ' '
}
});
var dataPoints = [[1293820200000, 45], [1293733800000, 25], [1293647400000, 65]]
var counter = 0;
var chart = new Highcharts.StockChart({
chart: {
renderTo: 'container'
},
rangeSelector: {
enabled: false
},
navigator: {
enabled: false
},
scrollbar : {
enabled : false
},
yAxis: {
min: 0,
max: null
},
xAxis: {
type: 'datetime',
linecolor: '#bbccdd',
gridLineColor:'#bbccdd',
tickInterval: 86400000,
min: 1293820200000,
max: 1294079400000
},
series: [{
name: 'Count',
data : [[1293906600000, 56]],
type : 'column',
}]
});
$('#button').click(function() {
if(counter == dataPoints.length) {
return;
}
var point = dataPoints[counter++];
var d = new Date(point[0]);
var min = d.setDate(d.getDate() - 1);
chart.xAxis[0].setExtremes(min,null);
chart.series[0].addPoint(point);
});
});
任何想法有什么不好?我错过了一些东西,或者错误地使用了API?
答
Highstock不会自动对输入数据进行排序,所以在给Highstock时必须对其进行排序。我认为这是造成问题的原因。
因此,添加新点时,添加的点必须晚于上一个点。
我已经整理数据点修改您的jsfiddle:
dataPoints.sort(function (a, b) {
return a[0] - b[0];
});
和移动第一点往回赶。 (也删除了setExtremes的调用以保持所有点都在视图中,但是没有连接到问题)。
在我的情况下,批量检索的数据和它的降序。例如batch1 = [[2-Jan-2013,25],[1-Jan-2013,45]],batch2 = [[31-Dec-2012,65],[30-Dec-2012,7]]。另外,我希望在第一批后立即渲染图表,以便渐进渲染。根据你的回答,似乎在不重新渲染整个图表的情况下无法实现这一点。你能否提出更好的建议或者是否有支持这种情况的库? – user2064553 2013-02-12 13:26:45
是的,如果数据未排序,您需要重新渲染图表。恐怕我不知道任何其他解决方案 – eolsson 2013-02-12 13:44:08