Я пытаюсь адаптировать этот пример диаграммы Highstock для использования с моими данными. Вот их работа в JSFiddle.
Итак, у меня есть несколько конечных точек REST, возвращающих JSON в следующем формате (набор меток времени и десятичных знаков):
{
"data" : {
"1440151410002" : 0.00430013850798903,
"1440151420001" : 0.00403626002690655,
"1440151430002" : 0.00376276477784804,
"1440151440001" : 0.00381307106855453,
"1440151450002" : 0.0039385712356139,
"1440151460002" : 0.0038632842565838,
"1440151470002" : 0.00407696207243675,
"1440151480002" : 0.0042298508094211,
"1440151490002" : 0.00411973200243665,
"1440151500002" : 0.00360435516702981,
"1440151510001" : 0.00426992197206649,
"1440151520002" : 0.00354089360750537,
"1440151530002" : 0.00400806659263663
}
}
Как и в примере с HighStock, цель состоит в том, чтобы перебрать конечные точки и получить JSON перед созданием диаграммы.
Чтобы HighStock правильно прочитал его, я понимаю, что мне нужно сопоставить его с чем-то вроде:
[[timestamp, 1.23], [timestamp, 1.24] ...]
У меня возникла проблема с выяснением того, как сопоставить мой формат JSON для каждой серии и формат, необходимый для правильного отображения диаграммы, поэтому в настоящее время я получаю пустую диаграмму.
Мой JS выглядит так:
$(function () {
var seriesOptions = [],
seriesCounter = 0,
names = ['P', 'Q', 'V', 'Q_C'],
// create the chart when all data is loaded
createChart = function () {
$('#chart4').highcharts('StockChart', {
rangeSelector: {
selected: 4
},
yAxis: {
labels: {
formatter: function () {
return (this.value > 0 ? ' + ' : '') + this.value + '%';
}
},
plotLines: [{
value: 0,
width: 2,
color: 'silver'
}]
},
plotOptions: {
series: {
compare: 'percent'
}
},
tooltip: {
pointFormat: '<span style="color:{series.color}">{series.name}</span>: <b>{point.y}</b> ({point.change}%)<br/>',
valueDecimals: 2
},
series: seriesOptions
});
};
$.each(names, function (i, name) {
$.getJSON('/live/data/' + name.toLowerCase(), function (data) {
seriesOptions[i] = {
name: name,
data: data['data']
};
// As we're loading the data asynchronously, we don't know what order it will arrive. So
// we keep a counter and create the chart when all the data is loaded.
seriesCounter += 1;
if (seriesCounter === names.length) {
createChart();
}
});
});
});
Любая помощь будет оценена по достоинству!
Спасибо, Хью.