• highstock高级篇之股票分时图


    一直在用 highchart 在做图表,最近一段时间突然接到一活,需要用 highstock 帮客户完成一个股票K线图和分时图。虽然用法和 api上与 highchart 没什么区别,但还是研究一番做出了对应的DEMO,于是抽空与大家分享下。

    预期想要达成的效果图

    highstock 开发股票或者财经的分时图

    准备工作

    引入 highstock 文件 
    这里需要重点注意了,需要引入 highstock 的版本 为 v1.2.5 版本,最新版和老版本有很大的区别,至于为什么随后在代码结束后为大家解释 ! ]

    图表的初始化

    1. UTC时间的设置和一些公共设置

    Highcharts.setOptions({
            global: {                                                               
                useUTC: true                                                       
            }, 
            lang : {
                rangeSelectorZoom : '',
                months : [ '一月', '二月', '三月', '四月', '五月', '六月', '七月', '八月', '九月', '十月', '十一月', '十二月' ],
                shortMonths : [ '1月', '2月', '3月', '4月', '5月', '6月', '7月', '8月',
                        '9月', '10月', '11月', '12月' ],
                weekdays : [ '周日', '周一', '周二', '周三', '周四', '周五', '周六' ]
            }
        });

    2. 渲染图表方法

    function initHourChart(){
        var chart=null;
        //需要请求的api action 地址
        var path="/highstock/hour.json";
        $.getJSON(path,function(data) {
            if(data.datas.length==0)
            {
                return;
            }
            var Price = [];
            //获取首个变量的时间,用来计算获取时间的最小值和最大值
            var firstData=data.datas[0].updatetime;
            var minTime=Date.UTC(parseInt(firstData.substring(0,4)), parseInt(firstData.substring(4,6))-1, parseInt(firstData.substring(6,8)), 8);
            var maxTime=Date.UTC(parseInt(firstData.substring(0,4)), parseInt(firstData.substring(4,6))-1, parseInt(firstData.substring(6,8)), 20);
            for (i = 0; i < data.datas.length; i++)
            {
                   Price.push([
                       UTC(data.datas[i].updatetime),
                       parseFloat(data.datas[i].open) 
                   ]);
            }
            Price.sort();
            var option={
                colors:['#4d73a8'],
                chart: {             
                  renderTo:"container",// 需要渲染的DIV 的ID名称
                  alignTicks: true
                }, 
                 navigator: false,
                 scrollbar: false,
                 rangeSelector: false,
                 plotOptions: {
                     line: {
                       lineWidth: 1
                     }
                 },
                 xAxis:[{
                        tickInterval:60 * 1000 * 60 *2.5,
                        min:minTime,
                        max:maxTime,
                        startOnTick:true,
                        endOntick:true,
                        gridLineColor: '#ccc',
                        gridLineDashStyle: 'dotted',
                        gridLineWidth: 1,
                        tickColor:'none',
                        lineColor: '#ccc',
                           labels:{
                               formatter:function(){
                                 var date = new Date(this.value)
                                 var hours = date.getHours()
                                 if(hours<8){
                                   hours = hours + 24
                                 }
                                 return addZero(hours-8)+':'+addZero(date.getMinutes())
                                 }
                           }
                 }],
                 yAxis:[{ 
                          gridLineWidth: 1,
                          lineColor: '#f00',
                          labels: {
                              align: 'right'
                          },
                          offset:15,
                          min:0,
                          gridLineColor: '#ccc',
                          gridLineDashStyle: 'solid'
                    }],
                 credits: false,
                 series : [{
                    name : '当前价',
                       color: '#30527e',
                       lineWidth: 1,
                       type:'line',
                       yAxis:0,
                       xAxis:0,
                       pointStart: minTime,
                    data:Price
                 }]
            }
            chart=new Highcharts.StockChart(option);            
        });
    }

    3. 渲染方法里需要用到的辅助方法,如UTC 的格式化,X轴时间的格式化等等

    function addZero(str){
            if(str<10){
              return str = '0' + str
            }
            return str
    }
    function UTC(time){
            if(time==undefined) return
              if (time.length < 10) {
                time = '' + time;
                return Date.UTC(time.substring(0, 4), time.substring(4, 6) - 1, time.substring(6,8));
              } else {
                time = '' + time;
                return Date.UTC(time.substring(0, 4), time.substring(4, 6) - 1, time.substring(6, 8), time.substring(9, 11), time.substring(12, 14), time.substring(15, 17));
              }      
    }

    4. 请求的 json 格式,当然格式可以自己定义 ,但是需要修改上面方法里的属性

    {
       "datas": [
           {
               "open": 2055,
               "updatetime": "20150129 08:00:00",
               "status": 1,
               "high": 2055,
               "low": 2053,
               "close": 2054
           },
           {
               "open": 2055,
               "updatetime": "20150129 08:01:00",
               "status": 1,
               "high": 2055,
               "low": 2054,
               "close": 2054
           },
           {
               "open": 2055,
               "updatetime": "20150129 08:02:00",
               "status": 1,
               "high": 2055,
               "low": 2055,
               "close": 2055
           }]
    }

    5. 最后完成的效果图(当然样式和其他方面还得做调整)

      1. 初始化的效果图 
        鼠标移上去的效果图

        方法解释说明

        initHourChart 方法为渲染的核心方法,它先请求服务端的 json数据 ,拿到 json数据 后,循环遍历开始组建图表所需要的data格式 ,一个 UTC 时间戳,另外一个就是对应的数据值 。需要注意的是 xAxis 属性里需要设置 tickInterval 、 min 和 max参数,而且必须要设置。因为股票的分时图一般会有开盘时间和收盘时间,这里的 min 和 max 决定了 轴时间的 开始 和 结束 tickInterval 决定了 的间隔时间(例子里我以2小时为间隔展示了一天的数据)。

      接着我来解释为什么前面我说必须要用 v1.2.5 版本

      1. 旧版支持时间段固定显示模式,例如上图初始化 就可以显示 早上8点到晚上8点的刻度值,即使当前的数据没有16点以后的数据。而新版当没有16点以后的数据时,会无法显示后面时间段的空白区域,除非将时间点填充null的值,如果后面点有值了动态去更新
      2. 定时器功能,我们会在load事件里增加一个定时器,动态为图表增加新的点。因为从开盘后,不是所有时间段的数据都会有。然而这点上,新版增加数据后整个线会向左移动,然后新添加的点才增加进来,具体看官网的DEMO。旧版的处理方式是图表不懂,自动在最后一个点上增加新的数据 

      附上2张图分别采用新版和旧版,解释上面2个观点 
      新版js初始化的图表 
      旧版js初始化的图表

    大家可以对比看看2张图的效果!也许新版有其他的解决方案。如果有也可以联系我与大家分享。今天就讲到这里,下篇为大家带来K线图的实例。

  • 相关阅读:
    p1229
    2017.01.21
    P1136 超车 归并排序 求逆序对个数
    2017年寒假计划
    递归一题总结(OJ P1117倒牛奶)
    原来scanf读入字符串还能这样..
    2016NOIP总结
    公式推♂倒题
    kmp+DP x 子串相关的计数问题
    XXXXXXXX不会太多吧?
  • 原文地址:https://www.cnblogs.com/onetwo/p/6085179.html
Copyright © 2020-2023  润新知