highcharts散布1秒更新,每个点在x轴上使用用户定义的标签

时间:2013-04-23 07:25:34

标签: highcharts highstock

以下是实时散点图http://jsfiddle.net/ashwinp/z6QXW/8/

的简化版

现在我在x轴上得到0 1 2等。我想在x轴上使用用户定义的名称.X轴标签应该从XLables数组中取出。

我在这里添加了与jsfiddle相同的代码

 var InfluenceCnt=0;
 var QResiduals=[];
 var XLables=[];
 var HottelingT2=[];
 var EllipseChartData;
 var EllipseShift;
 QResiduals.push('0.5356899');
 QResiduals.push('0.5356899');
 QResiduals.push('0.6356899');
 QResiduals.push('0.2356899');
 QResiduals.push('0.3356899');
 QResiduals.push('0.1356899');

 HottelingT2.push('0.1')
 HottelingT2.push('0.2');
 HottelingT2.push('0.3');
 HottelingT2.push('0.4');
 HottelingT2.push('0.5');
 HottelingT2.push('0.6');

XLables.push('a')
XLables.push('b');
XLables.push('c');
XLables.push('d');
XLables.push('e');
XLables.push('f');

 $(function () {
         $(document).ready(function () {        
             Highcharts.setOptions({
                 global: {
                     useUTC: false
                 }
             });
 // Ellipse Plot
      EllipseChartData = new Highcharts.Chart({
                 chart: {
                     renderTo: 'EllipseContainer',
                     type: 'scatter',
                     marginRight: 10,
                     zoomType: 'xy',
                     events: {
                         load: function () {                             

                             // set up the updating of the chart each second
                            EllipseSeries = this.series[0];                                
                              setInterval(function () {                                    
                                EllipseShift = EllipseSeries.data.length > 20;                         

                                if (!isNaN(QResiduals[InfluenceCnt]) &&             $.isNumeric(QResiduals[InfluenceCnt]) && typeof (QResiduals[InfluenceCnt]) != "undefined") {  //alert(QResiduals[InfluenceCnt]); 
                                     var x = HottelingT2[InfluenceCnt], // current time 
                                         y = parseFloat(QResiduals[InfluenceCnt]);    
                                     InfluenceCnt++;                                                                          
                                     EllipseSeries.addPoint([x, y], true, EllipseShift);                                         
                                   }                                     
                             }, 1000);
                         }
                     }
                 },
                 title: {
                     text: 'Ellipse Plot'
                 },
                 xAxis: {
                     title: {
                         text: 'Sample'
                     },
                     plotLines: [{                           
                        value:2.5,
                        color: 'red',
                        dashStyle: 'shortdash',
                        width: 2,
                        label: {
                            text: ''
                        }
                     }]
                 },
                 yAxis: {
                     title: {
                         text: ''
                     },
                     plotLines: [{                            
                        value: 0.4,
                        color: 'red',
                        dashStyle: 'shortdash',
                        width: 2,
                        label: {
                            text: ''
                        }
                     }]
                 },
                 tooltip: {
                     formatter: function () {
                         return '<b>' + this.series.name + '</b><br/>X: ' +
                    Highcharts.numberFormat(this.x, 2) + '<br/> Y: ' +
                    Highcharts.numberFormat(this.y, 2);
                     }
                 },
                 legend: {
                     enabled: false
                 },
                 exporting: {
                     enabled: true
                 },
                series: [{
                    name: 'Ellipse Plot',
                    data: []
                }]
             });


         });

     });

2 个答案:

答案 0 :(得分:1)

您需要的选项是&#39;类别&#39;在xAxis上。试试这个:

xAxis: {
      title: {
           text: 'Sample'
      },
      categories:XLables,

http://jsfiddle.net/euVvy/

要修复工具提示,您只需要参考&#39; this.x&#39;,它将返回类别名称:

                tooltip: {
                     formatter: function () {
                         return '<b>' + this.series.name + '</b><br/>X: ' +
                    this.x + '<br/> Y: ' +
                    Highcharts.numberFormat(this.y, 2);
                     }
                 },

http://jsfiddle.net/4aDQ2/

答案 1 :(得分:0)

您可以使用类别或标签格式化程序,以便定义“显示的标签http://api.highcharts.com/highstock#xAxis.labels.formatter