Как добавить динамические данные в старшей диаграмме? - PullRequest
3 голосов
/ 25 января 2012

У меня есть Highchart, который получает данные JSON через AJAX и jQuery.Но мой график не показывает точки, пока я не наведу указатель мыши на график.Даже тогда все точки находятся на самом верху графика.Я не думаю, что добавляю свои очки в серию правильно.Скажите, пожалуйста, что я делаю неправильно в функции jsonpcallback.

Спасибо!

        <script type="text/javascript">
    <!-- Begin Chart options-->

    // define the options
            var options = {
                            chart: {renderTo: 'container'},
                            title: {text: 'Brewery'},
                            subtitle: {text: ' '},
                            xAxis: {text: 'Time',type: 'datetime'},
                            yAxis: [{ // left y axis
                                        title: {text: 'Temperature (℉)'},
                                        labels: {align: 'left', x: 3, y: 16,
                                                formatter: function() {
                                        return Highcharts.numberFormat(this.value, 0);}
                                    },
                                    showFirstLabel: false}, 
                                    { // right y axis
                                        linkedTo: 0, gridLineWidth: 0, opposite: true,
                                        title: {text: 'Temperature (℉)'},
                                                labels: {align: 'right', x: -3, y: 16,
                                                    formatter: function() {
                                        return Highcharts.numberFormat(this.value, 0);}
                                    },
                                    showFirstLabel: false
                            }],
                            legend: {align: 'left', verticalAlign: 'top', y: 20,
                                    floating: true, borderWidth: 0},
                            tooltip: {shared: true, crosshairs: true},
                            plotOptions: {  series: {cursor: 'pointer',
                                                    point: {events: {
                                                    click: function() {
                                                    hs.htmlExpand(null, {
                                                    pageOrigin: {
                                                        x: this.pageX, 
                                                        y: this.pageY
                                                    },
                                                    headingText: this.series.name,
                                                    maincontentText: Highcharts.dateFormat('%A, %b %e, %Y', this.x) +':<br/> '+ 
                                                    this.y +'(℉)',
                                                    width: 200});
                                                    }}},
                            marker: {lineWidth: 1}}},
                            series: [   {name: 'Hot Liqour Tank'},
                                        {name: 'MashTun'},
                                        {name: 'Brew Kettle'},
                                        {name: 'Post Chiller'},
                                        {name: 'Control Box'}
                                    ]
            };
    <!-- End Chart Options -->
    var chart;
    //after DOM is loaded setup timeout to call the ajax method
    $(document).ready(function() {
        //call function to render the chart and setup the options
        renderChart();
    });

    //this function requests the data
    function reqData(){
        $.ajax({
            url: "http://192.168.0.11/"+Math.random(),
            dataType: "jsonp",              
            jsonp: "callback",
            jsonpCallback: "jsonpcallback"
        });
    }

    function jsonpcallback(rtndata) { 
        for(var i = 0; i < rtndata.length; i++){
            if(rtndata[i].sensor=="hlt")
            {
                chart.series[0].addPoint([rtndata[i].time, rtndata[i].temp]);
            }
            else if(rtndata[i].sensor=="mt")
            {
                chart.series[1].addPoint([rtndata[i].time, rtndata[i].temp]);
            }
            else if(rtndata[i].sensor=="bk")
            {
                chart.series[2].addPoint([rtndata[i].time, rtndata[i].temp]);
            }
            else if(rtndata[i].sensor=="pc")
            {
                chart.series[3].addPoint([rtndata[i].time, rtndata[i].temp]);
            }
            else if(rtndata[i].sensor=="box")
            {
                chart.series[4].addPoint([rtndata[i].time, rtndata[i].temp]);
            }       
        }
    }

    function renderChart(){
        chart = new Highcharts.Chart(options);
    }

    //continually poll for data
    setInterval(reqData, 5000);
    </script>

Ответы [ 2 ]

3 голосов
/ 25 января 2012

Я думаю, вы почти у цели;единственная часть, которую, я полагаю, вам не хватает, - это начальный вызов вашей regData функции из события load диаграммы .

в строке после укажите параметры , измените эту строку:

 chart: {renderTo: 'container'},

на эту:

chart: {renderTo: 'container', events: {load: regData}},
1 голос
/ 25 января 2012

Попробуйте преобразовать временные строки в объекты даты и времени Javascript. Highcharts будет правильно читать дату и время. Например, если дата JSON имеет формат «ГГГГ-ММ-ДД», вы можете использовать этот код:

    var dates = [];
    $.each(jsondata[0], function(itemNo, item) {
        year = parseInt(item.split('-')[0], 10);
        month = parseInt(item.split('-')[1], 10);
        day = parseInt(item.split('-')[2], 10);
        dt = Date.UTC(parseInt(year), parseInt(month), parseInt(day));
        series[0].data.push([dt, parseInt(jsondata[2][itemNo], 10)]);
        series[1].data.push([dt, parseInt(jsondata[1][itemNo], 10)]);
        dates.push(dt);
    });

    options.series = series;
...