HTML5canvas 绘制一个圆环形的进度表示实例


Posted in Javascript onDecember 16, 2016

HTML5 canvas 绘制圆环形进度

先看一下画出来的效果,如下图,这样一个圆环形的进度.
HTML5canvas 绘制一个圆环形的进度表示实例

 我这里使用HTML5的Canvas来要制作这样一个圆环形的进度,

首先是HTML页面,HTML5的文档标识是:

<!DOCTYPE html>

 这个文档标识要比HTML4的简单多了.

 第二步,在页面上创建一个Canvas画布元素:

<canvas class="process" width="48px" height="48px">61%</canvas>

 我这里创建了一个长宽都是48像素的画布,因为我要画的圆外直径是48个像素的,在canvas元素中间写的是"61%",这个文字可不是显示在圆环中间的那个哦,这个61%是当老的浏览器不支持canvas元素时显示的文字.

好了,到此为止HTML页面的内容就基本完成了,接下来就交给Javascript了,用Javascript来描绘圆环. 

function drawProcess() { 
  // 选出页面上所有class为process的canvas元素,然后迭代每一个元素画图(这里用Jquery的选择器选的) 
  $('canvas.process').each(function() { 
      // 第一部先拿到canvas标签中间的文字,就是那个61%(这里的stringTrim方法是我自己的方法,去前后空格的方法很多的,这里就不贴出来了) 
    var text = commonutil.stringTrim($(this).text()); 
    var process = text.substring(0, text.length-1); 
         
      // 一个canvas标签 
    var canvas = this; 
      // 拿到绘图上下文,目前只支持"2d" 
    var context = canvas.getContext('2d'); 
  // 将绘图区域清空,如果是第一次在这个画布上画图,画布上没有东西,这步就不需要了 
    context.clearRect(0, 0, 48, 48); 
     
  // ***开始画一个灰色的圆 
    context.beginPath(); 
      // 坐标移动到圆心 
    context.moveTo(24, 24); 
      // 画圆,圆心是24,24,半径24,从角度0开始,画到2PI结束,最后一个参数是方向顺时针还是逆时针 
    context.arc(24, 24, 24, 0, Math.PI * 2, false); 
    context.closePath(); 
      // 填充颜色 
    context.fillStyle = '#ddd'; 
    context.fill(); 
      // ***灰色的圆画完 
     
    // 画进度 
    context.beginPath(); 
      // 画扇形的时候这步很重要,画笔不在圆心画出来的不是扇形 
    context.moveTo(24, 24); 
      // 跟上面的圆唯一的区别在这里,不画满圆,画个扇形 
    context.arc(24, 24, 24, 0, Math.PI * 2 * process / 100, false); 
    context.closePath(); 
    context.fillStyle = '#e74c3c'; 
    context.fill(); 
 
    // 画内部空白 
    context.beginPath(); 
    context.moveTo(24, 24); 
    context.arc(24, 24, 21, 0, Math.PI * 2, true); 
    context.closePath(); 
    context.fillStyle = 'rgba(255,255,255,1)'; 
    context.fill(); 
     
  // 画一条线 
    context.beginPath(); 
    context.arc(24, 24, 18.5, 0, Math.PI * 2, true); 
    context.closePath(); 
      // 与画实心圆的区别,fill是填充,stroke是画线 
    context.strokeStyle = '#ddd'; 
    context.stroke(); 
     
      //在中间写字 
    context.font = "bold 9pt Arial"; 
    context.fillStyle = '#e74c3c'; 
    context.textAlign = 'center'; 
    context.textBaseline = 'middle'; 
    context.moveTo(24, 24); 
    context.fillText(text, 24, 24); 
  }

好了,画完了.要看到效果别忘了调用一下画图的drawprocess方法哦.

HTML5canvas 绘制一个圆环形的进度表示实例大小: 2.4 KB 查看图片附件

感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!

Javascript 相关文章推荐
Jquery Ajax学习实例 向页面发出请求,返回XML格式数据
Mar 14 Javascript
JavaScript 更严格的相等 [译]
Sep 20 Javascript
js字符串转换成数字与数字转换成字符串的实现方法
Jan 08 Javascript
javascript生成img标签的3种实现方法(对象、方法、html)
Dec 25 Javascript
jQuery中bind(),live(),delegate(),on()绑定事件方法实例详解
Jan 19 Javascript
微信js-sdk上传与下载图片接口用法示例
Oct 12 Javascript
JS常用函数和常用技巧小结
Oct 15 Javascript
JS中用三种方式实现导航菜单中的二级下拉菜单
Oct 31 Javascript
基于Node.js模板引擎教程-jade速学与实战1
Sep 17 Javascript
JS实现统计字符串中字符出现个数及最大个数功能示例
Jun 04 Javascript
JavaScript canvas实现跟随鼠标事件
Feb 10 Javascript
JavaScript对象访问器Getter及Setter原理解析
Dec 08 Javascript
JS数字千分位格式化实现方法总结
Dec 16 #Javascript
jquery插件锦集【推荐】
Dec 16 #Javascript
jQuery Easyui 下拉树组件combotree
Dec 16 #Javascript
JS实现字符串转驼峰格式的方法
Dec 16 #Javascript
详解js数组的完全随机排列算法
Dec 16 #Javascript
JS返回只包含数字类型的数组实例分析
Dec 16 #Javascript
基于Vue如何封装分页组件
Dec 16 #Javascript
You might like
通过PHP的内置函数,通过DES算法对数据加密和解密
2012/06/21 PHP
PHP验证码函数代码(简单实用)
2013/09/29 PHP
py文件转exe时包含paramiko模块出错解决方法
2016/08/12 PHP
PHP5.6新增加的可变函数参数用法分析
2017/08/25 PHP
在 Laravel 中动态隐藏 API 字段的方法
2019/10/25 PHP
论坛里点击别人帖子下面的回复,回复标题变成“回复 24# 的帖子”
2009/06/14 Javascript
Javascript 设计模式(二) 闭包
2010/05/26 Javascript
用Jquery实现多级下拉框无刷新的联动
2010/12/22 Javascript
css transform 3D幻灯片特效实现步骤解读
2013/03/27 Javascript
JQuery文本改变触发事件如聚焦事件、失焦事件
2014/01/15 Javascript
toggle()隐藏问题的解决方法
2014/02/17 Javascript
jquery获取一个元素下面相同子元素的个数代码
2014/07/31 Javascript
javascript实现查找数组中最大值方法汇总
2016/02/13 Javascript
Highcharts学习之数据列
2016/08/03 Javascript
Angular2使用Angular-CLI快速搭建工程(二)
2017/05/21 Javascript
vue 粒子特效的示例代码
2017/09/19 Javascript
30分钟快速入门掌握ES6/ES2015的核心内容(下)
2018/04/18 Javascript
jquery轮播图插件使用方法详解
2020/07/31 jQuery
[48:20]OpTic vs Serenity 2018国际邀请赛小组赛BO2 第二场 8.18
2018/08/19 DOTA
python获取mp3文件信息的方法
2015/06/15 Python
Python安装官方whl包和tar.gz包的方法(推荐)
2017/06/04 Python
Python 高级专用类方法的实例详解
2017/09/11 Python
解析Python中的eval()、exec()及其相关函数
2017/12/20 Python
python实现将多个文件分配到多个文件夹的方法
2019/01/07 Python
python3实现猜数字游戏
2020/12/07 Python
python实现门限回归方式
2020/02/29 Python
HTML5实现一个能够移动的小坦克示例代码
2013/09/02 HTML / CSS
如何利用input事件来监听移动端的输入
2016/04/15 HTML / CSS
香港时装购物网站:ZALORA香港
2017/04/23 全球购物
毕业生自荐信如何写
2014/03/24 职场文书
职业规划实施方案
2014/06/10 职场文书
纪念九一八事变演讲稿1000字
2014/09/14 职场文书
优秀团员个人总结
2015/02/26 职场文书
广告公司文案策划岗位职责
2015/04/14 职场文书
英语投诉信范文
2015/07/03 职场文书
2015秋季开学典礼致辞
2015/07/16 职场文书