admin管理员组文章数量:1421262
I am trying to plot 6 time series at once, and update their values every few ms.
Here is how I initially plot the data which works fine:
var d1 = [];
var d2 = [];
var d3 = [];
var d4 = [];
var d5 = [];
var d6 = [];
d1 = getRandomData(d1, totalPoints);
d2 = getRandomData(d2, totalPoints);
d3 = getRandomData(d3, totalPoints);
d4 = getRandomData(d4, totalPoints);
d5 = getRandomData(d5, totalPoints);
d6 = getRandomData(d6, totalPoints);
var plot = $.plot("#placeholder", [{
data: d1,
lines: { show: true, fill: false }
}, {
data: d2,
lines: { show: true, fill: false }
}, {
data: d3,
lines: { show: true, fill: false }
}, {
data: d4,
lines: { show: true, fill: false }
}, {
data: d5,
lines: { show: true, fill: false }
}, {
data: d6,
lines: { show: true, fill: false }
}]);
But my update function doesn't work:
function update() {
d1 = getRandomData(d1, totalPoints);
d2 = getRandomData(d2, totalPoints);
d3 = getRandomData(d3, totalPoints);
d4 = getRandomData(d4, totalPoints);
d5 = getRandomData(d5, totalPoints);
d6 = getRandomData(d6, totalPoints);
plot.setData([d1, d2, d3, d4, d5, d6]);
// Since the axes don't change, we don't need to call plot.setupGrid()
plot.draw();
setTimeout(update, updateInterval);
}
//update();
When I unment and call update()
, the graph goes blank. But I know data is being loaded fine initially without calling it.
How can I update my d arrays and redraw the graph properly?
I am trying to plot 6 time series at once, and update their values every few ms.
Here is how I initially plot the data which works fine:
var d1 = [];
var d2 = [];
var d3 = [];
var d4 = [];
var d5 = [];
var d6 = [];
d1 = getRandomData(d1, totalPoints);
d2 = getRandomData(d2, totalPoints);
d3 = getRandomData(d3, totalPoints);
d4 = getRandomData(d4, totalPoints);
d5 = getRandomData(d5, totalPoints);
d6 = getRandomData(d6, totalPoints);
var plot = $.plot("#placeholder", [{
data: d1,
lines: { show: true, fill: false }
}, {
data: d2,
lines: { show: true, fill: false }
}, {
data: d3,
lines: { show: true, fill: false }
}, {
data: d4,
lines: { show: true, fill: false }
}, {
data: d5,
lines: { show: true, fill: false }
}, {
data: d6,
lines: { show: true, fill: false }
}]);
But my update function doesn't work:
function update() {
d1 = getRandomData(d1, totalPoints);
d2 = getRandomData(d2, totalPoints);
d3 = getRandomData(d3, totalPoints);
d4 = getRandomData(d4, totalPoints);
d5 = getRandomData(d5, totalPoints);
d6 = getRandomData(d6, totalPoints);
plot.setData([d1, d2, d3, d4, d5, d6]);
// Since the axes don't change, we don't need to call plot.setupGrid()
plot.draw();
setTimeout(update, updateInterval);
}
//update();
When I unment and call update()
, the graph goes blank. But I know data is being loaded fine initially without calling it.
How can I update my d arrays and redraw the graph properly?
Share Improve this question edited Apr 19, 2022 at 22:53 halfer 20.4k19 gold badges109 silver badges202 bronze badges asked Sep 12, 2013 at 19:18 JDSJDS 17k47 gold badges171 silver badges234 bronze badges 1-
d1 = getRandomData(d1, totalPoints);
-- why is d1 both assigned from and passed into this function? – Mark Commented Sep 12, 2013 at 23:10
1 Answer
Reset to default 6setData
and the data argument to plot
both take data formatted the same way.
So, create a reusable function:
getSeriesObj = function() {
return [
{
data: getRandomData(d1, totalPoints),
lines: { show: true, fill: false }
}, {
data: getRandomData(d2, totalPoints),
lines: { show: true, fill: false }
}, {
data: getRandomData(d3, totalPoints),
lines: { show: true, fill: false }
}, {
data: getRandomData(d4, totalPoints),
lines: { show: true, fill: false }
}, {
data: getRandomData(d5, totalPoints),
lines: { show: true, fill: false }
}, {
data: getRandomData(d6, totalPoints),
lines: { show: true, fill: false }
}
];
}
For the intial plot:
var plot = $.plot("#placeholder", getSeriesObj());
To reset your data:
plot.setData(getSeriesObj());
plot.draw();
Here's a jsFiddle demo.
本文标签: Flot javascript graphing setData for multiple seriesStack Overflow
版权声明:本文标题:Flot javascript graphing: setData for multiple series - Stack Overflow 内容由网友自发贡献,该文观点仅代表作者本人, 转载请联系作者并注明出处:http://www.betaflare.com/web/1744678174a2619240.html, 本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容,一经查实,本站将立刻删除。
发表评论