Ленивые старшие диаграммы и загрузка данных Json
Я использую LazyHighCharts и пытаюсь собрать данные json для отображения только последних 24 часов, но это не отображение данных, только дата, а только один раз (температура должна быть каждый час дня).
структура данных
{"status": "ok", "data": [{"2014-06-16 16:00:00": 24.2},{"2014-06-17 12:00:00": 30.2},{"2014-06-18 17:00:00": 42.9}]} etc
контроллер
@data = JSON.parse(open(@temperature.url).read)
dates = []
temps = []
@data['data'].each do |data|
dates << data.keys
temps << data.values
end
@graph = LazyHighCharts::HighChart.new('graph') do |f|
f.chart(:height => '400')
f.yAxis [:title => {:text => "Temperature", :margin => 20, style: { color: '#333'}}]
f.series(:pointInterval => 1.hour, :pointStart => 30.day.ago, :type => 'area', :name => '24hrs', :data => [[dates, temps]])
f.options[:xAxis] = { :minTickInterval => 24 * 3600 * 1000, :type => "datetime", :dateTimeLabelFormats => { day: "%b %e"}, :title => { :text => nil }, :labels => { :enabled => true } }
end
Образ
2 ответа
Решение
Чтобы преобразовать ваш объект datetime в соглашение о миллисекундах JS, просто вызовите
DateTime.now.to_i*1000
или в вашем случае
def index
@data = {"status" => "ok", "data" => [{"2014-06-16 16:00:00" => 24.2},{"2014-06-17 12:00:00" => 30.2},{"2014-06-18 17:00:00" => 42.9}]}
d = []
@data['data'].each do |data|
d << [DateTime.parse(data.keys.first).to_i*1000, data.values.first]
end
@chart = LazyHighCharts::HighChart.new('chart') do |f|
f.chart(:height => '400')
f.yAxis [:title => {:text => "Temperature", :margin => 20, style: { color: '#333'}}]
f.xAxis(type: 'datetime')
f.series(:type => 'area', :name => '24hrs', :data => d)
end
end
Ваши даты должны быть временными метками (время в миллисекундах, например, 12323311000), а не в такой форме: "2014-06-16 16:00:00". Поэтому вам необходимо преобразовать ее.