canvas教程

HTML5表单 HTML5 进阶系列:canvas 动态图表

字号+ 作者:H5之家 来源:H5之家 2017-05-25 16:01 我要评论( )

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

前言

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

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

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

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

效果

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

 HTML5 进阶系列:canvas 动态图表

分析

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

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

实现

定义画布

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

画坐标轴

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

ctx width height padding ..height .padding ..height .height .yLength ) / yNumber)xLength ) / ...(i ixlen .).)(i )).height .height

柱状动画

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

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

1 2 3 下一页

 

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

相关文章
  • html5 canvas飘洒的星星背景动画特效

    html5 canvas飘洒的星星背景动画特效

    2017-05-25 16:03

  • HTML5+CSS3基于canvas实现电子彩票刮刮乐功能

    HTML5+CSS3基于canvas实现电子彩票刮刮乐功能

    2017-05-23 18:01

  • HTML5 Canvas锯齿图代码实例_html5教程技巧

    HTML5 Canvas锯齿图代码实例_html5教程技巧

    2017-05-23 16:00

  • HTML5之Canvas基础绘图教程

    HTML5之Canvas基础绘图教程

    2017-05-22 16:00

网友点评
d