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线图的实例。

转载于:https://www.cnblogs.com/onetwo/p/6085179.html

Highstock 是用纯 JavaScript 编写的股票图表控件,可以开发股票走势或大数据量的时间轴图表。它包含多个高级导航组件:预设置数据时间范围,日期选择器、滚动条、平移、缩放功能。 主要优势(功能特点) browsers兼容性 Highstock 可以在所有的移动设备及电脑上的浏览器中使用,包括 iPhone,iPad 和 IE6 以上的版本。在 IOS 和 Android 系统中 Highstock 支持多点触摸功能,因而可以给您提供极致的用户体验。在现代的浏览器中使用 SVG 技术进行图形绘制,在低版本 IE 则使用 VML 进行图形绘制。 free非商业使用免费 在个人网站、学校网站及非盈利机构中使用 Highstock 完全不需要经过我们的许可,直接可以任意使用! 商业网站或网站,请查看我们的 使用协议及价格。 open开源 Highstock 最重要的特点之一就是:无论免费版还是付费版,你都可以下载源码并可以对其进行编辑。 基于开源社区我们可以第一时间获取用户的需求、Bug 修复及吸收社区贡献。 no-backend纯 JavaScript Highstock 完全基于 HTML5 技术,不需要再客户端安装任何插件,如 Flash 或 Java。此外你也不用配置任何服务端环境,不需要 PHP、Tomcat、ASP.NET 等,只需要两个 JS 文件即可运行。 chart-types图表种类丰富 Highstock 支持直线图、折线图、面积图、面积曲线图、柱形图、散点图、蜡烛图(OHLC)、K线图、标签图、面积范围图、柱形范围图等多种图表, 其中很多图表可以集成在同一个图形中形成混合图 config-syntax简单的配置语法 在 Highstock 中设置配置选项不需要任何高级的编程技术,所有的配置都是 JSON 对象,只包含用冒号连接的键值对、用逗号进行分割、用括号进行对象包裹。JSON 具有易于人阅读和编写,同时也易于机器解析和生成的特点。 动态交互性 Highstock 支持丰富交互性,在图表创建完毕后,可以用丰富的 API 进行添加、移除或修改数据列、数据点、坐标轴等操作。 结合 jQuery 的 ajax 功能,可以做到实时刷新数据、用户手动修改数据等功能,结合事件处理,可以做到各种交互功能。 范围选择器 在处理大数据集时,我们可能需要查看不同时间范围的数据。Highstock 提供了范围选择器,方便的用它来选择预设范围的时间,例如 1个月、一季度、1年等,你可以通过时间输入框来选择自己想要查看数据范围。 滚动条和导航器 通过滚动条和导航器可以更加直观的操作和查看特定范围的数据。 事件标记 通过添加标志数据列可以为数据相关的事件做标记和注释。 支持多坐标轴 多个数据进行对比这是非常常见的需求,Highstock 可以让你为每个类型的数据添加坐标轴,每个轴可以定义放置的位置,所有的设置都可以独立生效,包括旋转、样式设计和定位,当然也支持多个数据共用一个坐标轴。 tooltip数据提示框 当鼠标划过图形时,Highstock 可以将数据点或数据列的信息展示在提示框中,并且提示框会跟随用户的鼠标;我们做了大量工作,可以智能的显示离鼠标最近的点或被遮盖点的信息。 datetime时间轴 Highstock 对时间轴的处理非常智能,可以精确的计算出月、周、日、小时、分钟等时间刻度的位置。 data grouping数据分组与合并 如果数据集包含 10 万个,浏览器对每个点进行计算并渲染的话效率会非常低。Highstock 具有数据分类功能,可以以飞速的进行数据分组;放大至小范围的数据是会重新分组,因为你可以查看高度清晰的数据又不失效率和速度。 exporting导出和打印 Highstock 支持导出功能,用户可以一键导出 PNG、JPEG、PDF 或 SVG 文件,通过插件可以实现导出为 Excel 文件功能;另外,用户还可以从网页上直接打印图表。 zooming缩放和平移 除了通过滚动条或导航器控制放大和平移功能,你还可以通过鼠标和手指来进行这两个操作。 ajax方便加载外部数据 Highstock 的数据是 JavaScript 数组或对象,这些数据可以是本地的配置对象,独立的数据文件(JSON、CVS)甚至是不同的网站上定义。另外,这些数据可以用任何形式处理好并加载到 Highstock 中。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值