将实时数据添加到highstock使用json文件

时间:2014-01-06 15:50:02

标签: json highcharts highstock live-update

我正在尝试使用我服务器上的json文件中的实时数据更新highcharts highstock图表。

现在我有一个图表从json文件中获取数据(我使用php创建请求MySQL数据库中的数据),如下所示:

<!DOCTYPE HTML>
<html>
<head>
    <meta http-equiv="Content-Type" content="text/html; charset=utf-8">
    <title>OKcoin Price LTCCNY</title>

    <script type="text/javascript" src="http://ajax.googleapis.com/ajax/libs/jquery/1.8.2/jquery.min.js"></script>
    <script type="text/javascript">
$(function() {
$.getJSON('json/lastTradesOkcoinLTCCNY.json', function(data) {

    Highcharts.setOptions({
        global: {
            useUTC: false
        }
    });
    // create the chart
    $('#container').highcharts('StockChart', {


        rangeSelector : {
            selected : 1
        },

        title : {
            text : 'OkCoin Price LTCCNY'
        },

        rangeSelector: {
            buttons: [{
                type: 'hour',
                count: 1,
                text: '1h'
            }, {
                type: 'hour',
                count: 6,
                text: '6h'
            }, {
                type: 'hour',
                count: 12,
                text: '12h'
            }, {
                type: 'hour',
                count: 24,
                text: '24h'
            }, {
                type: 'day',
                count: 3,
                text: '3d'
            }, {
                type: 'day',
                count: 7,
                text: '7d'
            }, {
                type: 'all',
                text: 'All'
            }],             
            selected: 2
        },

        xAxis: {
            gridLineWidth: 1,
            title: {
                enabled: true,
                text: 'Time',
                style: {
                fontWeight: 'normal'
                }
            }
        },


        yAxis: [{
            title: {
                text: 'Price LTCCNY'
            },
            gridLineWidth: 1,
            minorTickInterval: 'auto',
            minorTickColor: '#FEFEFE',
            labels: {
                align: 'right'
            }               
        }],

        plotOptions: {
            series: {
                lineWidth: 1
            }
        },

    tooltip: {
        valueDecimals: 5,
        valuePrefix: '$ '
    },  

        series : [{
            name : 'LTCCNY Price',
            data : data,
            dataGrouping : {
                units : [
                    ['minute',
                        [1, 5, 10, 15, 30]
                    ], ['hour', // unit name
                        [1] 
                    ]
                ]
            }
        }]
    });

});
});

    </script>
</head>
<body>
<script src="../Highstock/js/highstock.js"></script>
<script src="../Highstock/js/modules/exporting.js"></script>

<div id="container" style="height: 500px; min-width: 500px"></div>
</body>
</html>

到目前为止没有问题,我从json文件中获取了一个图表。但是,如果有新数据可用,它当然不会更新(仅当我重新加载页面时)。

我想要做的是在加载此图表后,在可用时添加实时数据。

类似于this example,但不是随机数据,图表将使用来自我的网络服务器上的(第二个)实时更新json文件的数据进行更新。 json文件将由php创建(这部分工作正常)但我无法弄清楚如何将json文件中的数据添加到我现有的highstock图表中。

我也找到了 this这个例子在highcharts.com上,或多或少做了我尝试做的事情,但我无法将'requestData'功能集成到我现有的图表中。

所以我想要做的是使用第二个例子中的'requestData'函数和我已经拥有的高股票图表。我的第二个json文件(带有实时数据)与第二个示例中的相同(时间戳,价格):

[1389022968000,173.3]

有人可以帮我一点吗?

1 个答案:

答案 0 :(得分:0)

没关系,我自己弄清楚了......

这是我的解决方案:

<!DOCTYPE HTML>
<html>
<head>
    <meta http-equiv="Content-Type" content="text/html; charset=utf-8">

    <title>OKCoin LTCCNY Price</title>

    <script type="text/javascript"     src="http://ajax.googleapis.com/ajax/libs/jquery/1.8.2/jquery.min.js"></script>
    <script type="text/javascript">
    var chart; // global

    function requestData() {
        $.ajax({
            url: 'tickOkCoinLTCCNY.json', 
            success: function(point) {
                var series = chart.series[0],
                    shift = series.data.length > 2; // shift if the series is longer than 20

                // add the point
                chart.series[0].addPoint(eval(point), true, shift);

                // call it again after one second
                setTimeout(requestData, 10000); 
            },
            cache: false
        });
    }


$(function() {
$.getJSON('../okcoin/json/lastTradesOkcoinLTCCNY.json', function(data) {


    // set the allowed units for data grouping
    var groupingUnits = [[
        'minute',                         // unit name
        [1,5,15,30]                             // allowed multiples
    ], [
        'hour',
        [1, 2, 3, 4, 6]
    ]];

    // create the chart
    chart = new Highcharts.StockChart({
        chart: {
            renderTo: 'container',
            events: {
                    load: requestData
                }


        },

        rangeSelector: {
            buttons: [{
                type: 'hour',
                count: 1,
                text: '1h'
            }, {
                type: 'hour',
                count: 6,
                text: '6h'
            }, {
                type: 'hour',
                count: 12,
                text: '12h'
            }, {
                type: 'hour',
                count: 24,
                text: '24h'
            }, {
                type: 'day',
                count: 3,
                text: '3d'
            }, {
                type: 'day',
                count: 7,
                text: '7d'
            }, {
                type: 'all',
                text: 'All'
            }],             
            selected: 2
        },

        title: {
            text: 'OKCoin LTCCNY Price'
        },

        xAxis: {
        type: 'datetime',
            gridLineWidth: 1,
            title: {
                enabled: true,
                text: 'Time',
                style: {
                fontWeight: 'normal'
                }
            }
        },


        yAxis: [{
            title: {
                text: 'LTCCNY'
            },

            lineWidth: 2
        }],

        series: [{
            name: 'LTCCNY',
            data: data,
            dataGrouping: {
                units: groupingUnits
            }
        }]

      });
   });
});

    </script>
</head>
<body>
<script src="../Highstock/js/highstock.js"></script>
<script src="../Highstock/js/modules/exporting.js"></script>

<div id="container" style="height: 500px; min-width: 500px"></div>
</body>
</html>