Canvas 实现 progress 效果

作者:梁伟盛

据说本贵族圈每月不分享就邀请雪糕。所以分享下一个简单的Canvas插件,Canvas元素是HTML5的一部分,允许脚本语言动态渲染位图像,你可以使用javascript用它来绘制图形、图标、以及其它任何视觉性图像。它也可用于创建图片特效和动画(反正就是好东西)

既然是HTML5的特性,那必须是只有支持HTML5的浏览器才能使用,兼容性如下图:

使用到的API

参考资料~W3School

beginPath

定义:开始一条路径,或重置当前的路径。

      context.beginPath();

arc

定义:创建弧/曲线(用于创建圆或部分圆)。

      context.arc(x, y , r, sAngle, eAngle, counterclockwise);
参数
  • x:圆的中心的 x 坐标。
  • y:圆的中心的 y 坐标。
  • r:圆的半径。
  • sAngle:起始角,以弧度计。(弧的圆形的三点钟位置是 0 度)。
  • eAngle:结束角,以弧度计。
  • counterclockwise:可选。规定应该逆时针还是顺时针绘图。false = 顺时针,true = 逆时针。

stroke

定义:绘制当前路径的边框

    context.stroke()

measureText

    context.measureText(text).width;

定义:返回包含一个对象,该对象包含以像素计的指定字体宽度。

参数
  • text:要测量的文本

fillText

定义:在画布上绘制填色的文本

    context.fillText(text, x, y, maxWidth);
参数
  • text:规定在画布上输出的文本。
  • x:开始绘制文本的 x 坐标位置(相对于画布)。
  • y:开始绘制文本的 y 坐标位置(相对于画布)。
  • maxWidth:可选。允许的最大文本宽度,以像素计。

clearRect

定义:清空给定矩形内的指定像素。

    context.clearRect(x, y, width, height);
参数
  • x:要清除的矩形左上角的 x 坐标
  • y:要清除的矩形左上角的 y 坐标
  • width:要清除的矩形的宽度,以像素计
  • height:要清除的矩形的高度,以像素计

实现思路

了解了以上API后,我们就可以动手干活了,其实很简单。实现只有3个步骤。

1,画出带有透明度的内圆
    context.beginPath();

    //设置透明度,样式与线条宽度
    this.extend(context, {
        globalAlpha: inSideCircle.alpha,
        strokeStyle: inSideCircle.style,
        lineWidth: inSideCircle.lineWidth
    })            

    //绘制圆
    context.arc(this.hElWidth, this.hElHeight, option.radius + outSideCircle.lineWidth - inSideCircle.lineWidth, 0, pi * 2, false);

    //画出圆形
    context.stroke();
2,根据进度画出外圆
    context.beginPath();

    //设置透明度,样式与线条宽度
    this.extend(context, {
        globalAlpha: outSideCircle.alpha,
        strokeStyle: outSideCircle.style,
        lineWidth: outSideCircle.lineWidth
    })                            

    //根据当前进度绘制圆
    context.arc(this.hElWidth, this.hElHeight, option.radius, -(pi / 2), pi * 2 / 100 * (n - 25), false);

    //画出圆形
    context.stroke();
3,根据进度画出数值(0-100%)
    context.beginPath();

    this.extend(context, {
        font: textObj.font,
        fillStyle: textObj.style,
        globalAlpha: textObj.alpha
    })            

    //得出数值宽度
    numberWidth = context.measureText(number).width;

    context.fillText(number, this.hElWidth - numberWidth / 2, this.hElHeight + 10 / 3)
最后暴露出setProgress设置进度函数给外部调用即可
    //清除canvas内容
    this.context.clearRect(0, 0, this.elWidth, this.elHeight);                            

    this._drawCircle(n);

    this._drawText(n);

测试用例

    <!DOCTYPE html>
    <html>
    <head>
        <meta charset="UTF-8">
        <meta name="viewport" content="width=device-width, initial-scale=1, user-scalable=no, minimal-ui" />
        <meta content="yes"name="apple-mobile-web-app-capable"/>
        <meta content="black"name="apple-mobile-web-app-status-bar-style"/>
        <meta name="format-detection"content="telphone=no"/>
        <title>canvasProgress</title>
    </head>
    <body>    
    <canvas id="canvasEl" style="background-color:#000" height="100px" width="100px"></canvas>
    </body>
    <script type="text/javascript" src="progress.js"></script>
    <script type="text/javascript">
        var progress = new Progress({element: document.getElementById('canvasEl')})

        var n = 0;

        var timer = setInterval(function() {
            if (n++ !== 100) {
                progress.setProgress(n);        
            } else {
                clearInterval(timer);
            }
        }, 100)

    </script>
    </html>

实现效果

背景与进度颜色根据喜好变换

最后

今天分享就到此位置了,有兴趣的可以去github看下代码。

原文链接:http://ivweb.io/topic/559f2ff03d7bb8096b69cfdc

原创声明,本文系作者授权云+社区-专栏发表,未经许可,不得转载。

如有侵权,请联系 yunjia_community@tencent.com 删除。

编辑于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏IMWeb前端团队

Canvas实现progress效果

据说本贵族圈每月不分享就邀请雪糕。。。所以分享下一个简单的Canvas插件   Canvas元素是HTML5的一部分,允许脚本语言动态渲染位图像,你可以使用j...

1787
来自专栏CDA数据分析师

【图表大师二】 纯Excel图表制作高仿真决策仪表盘

一、什么是仪表盘 仪表盘(guage,speedometer,dial chart,dashboard),是模仿汽车速度表的一种图表,常用来反映预算完成...

1907
来自专栏企鹅号快讯

6个超实用的AI小工具

? 6个超实用的AI小工具 BGM:鬼火の童・鬼切、虎徹にございます! 今天学习的AI实用小工具,分分钟帮我们提高666倍工作效率,让我们听着这首欢快魔性的小...

1968
来自专栏Python爱好者

Python绘制分形树(一)

1178
来自专栏GopherCoder

charts: 图表工具

1853
来自专栏24K纯开源

ChartDirector应用笔记(三)

前言 继上篇文章(Simple bar chart)推出之后,本篇文章继续ChartDirector的使用。在这篇Blog中,博主实现的是soft lighti...

18610
来自专栏葡萄城控件技术团队

HTML5 & CSS3初学者指南(4) – Canvas使用

介绍 传统的HTML主要用于文本的创建,可以通过<img>标签插入图像,动画的实现则需要第三方插件。在这方面,传统的HTML极其缺乏满足现代网页多媒体需求的能力...

1836
来自专栏程序员的诗和远方

一个比想象中更骚气的圆-svg实现

之前写了一篇Canvas画图-一个比想象中更骚气的圆(渐变圆环),其实SVG也可以实现类似的效果,而且两者api惊人的相似。 关于SVG SVG是一种矢量...

2717
来自专栏数据小魔方

parklines迷你图系列1——Scales

按照之前的计划,今天开始按照sparklines插件的图表分类标准开始跟大家分享详细的做法。 按照该插件在excel菜单中的顺序,先来看测量尺度(Scales)...

2686
来自专栏wOw的Android小站

[Tensorflow] 使用SSD-MobileNet训练模型

因为Android Demo里的模型是已经训练好的,模型保存的label都是固定的,所以我们在使用的时候会发现还有很多东西它识别不出来。那么我们就需要用它来训练...

1111

扫码关注云+社区