HTML5技术

HTML5 进阶系列:canvas 动态图表 - _林鑫

字号+ 作者:H5之家 来源:H5之家 2017-05-24 10:00 我要评论( )

前言 canvas 强大的功能让它成为了 HTML5 中非常重要的部分,至于它是什么,这里就不需要我多作介绍了。而可视化图表,则是 canvas 强大功能的表现之一。 现在已经有了很多成熟的图表插件都是用 canvas 实现的,Chart.js、ECharts等可以制作出好看炫酷的图表

前言

canvas 强大的功能让它成为了 HTML5 中非常重要的部分,至于它是什么,这里就不需要我多作介绍了。而可视化图表,则是 canvas 强大功能的表现之一。

现在已经有了很多成熟的图表插件都是用 canvas 实现的,Chart.js、ECharts等可以制作出好看炫酷的图表,而且几乎覆盖了所有图表的实现。

有时候自己只想画个柱状图,自己写又觉得麻烦,用别人插件又感觉累赘,最后打开百度,拷段代码,粘贴上来修修改改。还不如自己撸一个呢。

原文作者:林鑫,作者博客:https://github.com/lin-xin/blog

效果

动画效果图片显示不出来,可以到最下面找demo地址

image

分析

可以这个图表由 xy轴、数据条形和标题组成。

这样看来,似乎并没有多难。

实现 定义画布

canvas 标签只是个容器,真正实现画图的还是 JavaScript。

画坐标轴

坐标轴就是两条横线,也就是canvas里最基础的知识。

ctx width height padding ..height .padding ..height .height .stroke();

画坐标点

y轴上多少坐标点由自己来定义,需要获取到数据的最大值来计算y轴上的坐标值。x轴的点则由传入的数据长度决定,坐标值由传入数据的 xAxis 属性决定。

yLength ) / yNumber)xLength ) / ...(i ixlen .).)(i )).height .height

柱状动画

接下来要把数据通过柱状的高低显示出来,这里有个动画效果,柱状会从0升到对应的值。在 canvas 上实现动画我们可以使用 setInterval、setTimeout 和 requestAnimationFrame。

requestAnimationFrame 不需要自己设置定时时间,而是跟着浏览器的绘制走。这样就不会掉帧,自然就流畅。
requestAnimationFrame 原本只支持IE10以上,不过可以通过兼容的写法实现兼容到IE6都行。

function looping() { looped (current current : (current ().cancelAnimationFrame(looped); looped () i i.yRatio).x); // 保存每个柱状的信息 data[i].xLength * i; data[i].top = y; data[i].xLength / 4 + xLength * i; data[i].();

  • 柱状即是画矩形,由 ctx.fillRect(x, y, width, height) 实现,x y 为矩形左上角的坐标,width height 为矩形的宽高,单位为像素
  • ctx.fillStyle='#1E9FFF' 设置填充颜色
  • 到这里,一个最基本的柱状图就完成了。接下来,我们可以为他添加标题。

    标题

    要放置标题,就会发现我们一大早定义的 padding 内边距确实有用,总不能把标题给覆盖到柱状图上吧。但是标题有的是在顶部,有的在底部,那么就不能写死了。定一个变量 position 来判断位置去画出来。这个简单。

    ...(titlePosition padding .fillText(title,width/2,height-5) .fillText(title,width/2,padding/2) } }

    监听鼠标移动事件

    我们看到,有些图表,把鼠标移上去,当前的柱状就变色了,移开之后又变回原来的颜色。这里就需要监听 mouseover 事件,当鼠标的位置位于柱状的面积内,触发事件。

    那我怎么知道在柱状里啊,发现在 drawAnimation() 里会有每个柱状的坐标,那我干脆把坐标给保存到 data 里。那么鼠标在柱状里的条件应该是:

    (ev).(iiiidata[i].....))

    总结

    为了更方便的使用,封装成构造函数。通过

    var chart = new sBarChart('canvas',data,{ title: 'xxx公司年度盈利', // 标题 titleColor: '#000000', // 标题颜色 titlePosition: 'top', // 标题位置 bgColor: '#ffffff', // 背景色 fillColor: '#1E9FFF', // 柱状填充色 axisColor: '#666666', // 坐标轴颜色 contentColor: '#a5f0f6' // 内容横线颜色 });

    参数可配置,很简单就生成一个个性化的柱状图。代码地址:canvas-demo

    更多文章:lin-xin/blog

     

    1.本站遵循行业规范,任何转载的稿件都会明确标注作者和来源;2.本站的原创文章,请转载时务必注明文章作者和来源,不尊重原创的行为我们将追究责任;3.作者投稿可能会经我们编辑修改或补充。

    相关文章
    • HTML5全局属性——原创(要借鉴的伙伴请标注来源) - YYNSunny

      HTML5全局属性——原创(要借鉴的伙伴请标注来源) - YYNSunny

      2017-05-22 10:01

    • HTML5初学 - YYNSunny

      HTML5初学 - YYNSunny

      2017-05-21 14:04

    • HTML5支持服务器发送事件(Server-Sent Events)-单向消息传递数据推送(C#示例) - 熊仔其人

      HTML5支持服务器发送事件(Server-Sent Events)-单向消息传递数据推送

      2017-05-19 11:02

    • HTML5的表单所有type类型 - 菩提树下的小乌龟

      HTML5的表单所有type类型 - 菩提树下的小乌龟

      2017-05-16 11:05

    网友点评
    a