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 相关文章推荐
WordPress JQuery处理沙发头像
Jun 22 Javascript
jquery表单验证使用插件formValidator
Nov 10 Javascript
动态的改变IFrame的高度实现IFrame自动伸展适应高度
Dec 28 Javascript
JavaScript实现维吉尼亚(Vigenere)密码算法实例
Nov 22 Javascript
php利用curl获取远程图片实现方法
Oct 26 Javascript
jquery验证手机号是否正确实例讲解
Nov 17 Javascript
学习Vue组件实例
Apr 28 Javascript
浅谈Angular6的服务和依赖注入
Jun 27 Javascript
利用Blob进行文件上传的完整步骤
Aug 02 Javascript
countUp.js实现数字滚动效果
Oct 18 Javascript
jQuery实现获取多选框的值示例
Feb 07 jQuery
js实现鼠标点击飘爱心效果
Aug 19 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
Yii框架日志记录Logging操作示例
2018/07/12 PHP
再谈Yii Framework框架中的事件event原理与应用
2020/04/07 PHP
7款吸引人眼球的jQuery/CSS3特效实例分享
2013/04/25 Javascript
jquery图片滚动放大代码分享(2)
2015/08/28 Javascript
jquery中val()方法是从最后一个选项往前读取的
2015/09/06 Javascript
jQuery移动页面开发中的触摸事件与虚拟鼠标事件简介
2015/12/03 Javascript
vue组件watch属性实例讲解
2017/11/07 Javascript
html中通过JS获取JSON数据并加载的方法
2017/11/30 Javascript
AngularJS与后端php的数据交互方法
2018/08/13 Javascript
Vue.js点击切换按钮改变内容的实例讲解
2018/08/22 Javascript
小程序scroll-view组件实现滚动的示例代码
2018/09/20 Javascript
jQuery实现王者荣耀手风琴效果
2020/01/17 jQuery
解决ant-design-vue中menu菜单无法默认展开的问题
2020/10/31 Javascript
[02:20]2014DOTA2西雅图邀请赛 MVP外卡赛首胜采访
2014/07/09 DOTA
Python下的twisted框架入门指引
2015/04/15 Python
python numpy函数中的linspace创建等差数列详解
2017/10/13 Python
Python实现mysql数据库更新表数据接口的功能
2017/11/19 Python
python 匹配url中是否存在IP地址的方法
2018/06/04 Python
selenium处理元素定位点击无效问题
2019/06/12 Python
numpy np.newaxis 的实用分享
2019/11/30 Python
Python中base64与xml取值结合问题
2019/12/22 Python
Python selenium抓取虎牙短视频代码实例
2020/03/02 Python
python matplotlib包图像配色方案分享
2020/03/14 Python
加拿大消费电子和手机购物网站:The Source
2017/01/28 全球购物
澳大利亚游乐场设备品牌:Lifespan Kids
2019/05/24 全球购物
哪些情况下不应该使用索引
2015/07/20 面试题
物理研修随笔感言
2014/02/14 职场文书
消防安全标语
2014/06/07 职场文书
教师查摆问题及整改措施
2014/10/11 职场文书
家长高考寄语
2015/02/27 职场文书
大学生求职自荐信
2015/03/24 职场文书
资金申请报告范文
2015/05/14 职场文书
关于Vue Router的10条高级技巧总结
2021/05/06 Vue.js
用Python实现屏幕截图详解
2022/01/22 Python
【js设计模式】SOLID五大设计原则
2022/03/24 Javascript
Win10本地连接不见了怎么恢复? win10系统电脑本地连接不见了解决方法
2023/01/09 数码科技