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 相关文章推荐
ext 列表页面关于多行查询的办法
Mar 25 Javascript
javascript 常用功能总结
Mar 18 Javascript
常用的JavaScript验证正则表达式汇总
Nov 26 Javascript
JavaScript中使用Object.create()创建对象介绍
Dec 30 Javascript
JavaScript 基本概念
Jan 20 Javascript
JavaScript使用位运算符判断奇数和偶数的方法
Jun 01 Javascript
require.js的用法详解
Oct 20 Javascript
jQuery中判断对象是否存在的方法汇总
Feb 24 Javascript
jQuery实现两列等高并自适应高度
Dec 22 Javascript
js微信应用场景之微信音乐相册案例分享
Aug 11 Javascript
对于js垃圾回收机制的理解
Sep 14 Javascript
vue实现城市列表选择功能
Jul 16 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
咖啡店都有些什么常规豆子呢?有什么风味在里面
2021/03/04 咖啡文化
php fsockopen中多线程问题的解决办法[翻译]
2011/11/09 PHP
PHP判断数据库中的记录是否存在的方法
2014/11/14 PHP
PHP调用MySQL存储过程并返回值的方法
2014/12/26 PHP
Yii2选项卡的简单使用
2017/05/26 PHP
PHP 记录访客的浏览信息方法
2018/01/29 PHP
thinkPHP5框架路由常用知识点汇总
2019/09/15 PHP
在多个页面使用同一个HTML片段的代码
2011/03/04 Javascript
JS打印组合功能
2016/08/04 Javascript
使用json来定义函数,在里面可以定义多个函数的实现方法
2016/10/28 Javascript
详解Vue中使用v-for语句抛出错误的解决方案
2017/05/04 Javascript
vue2.0设置proxyTable使用axios进行跨域请求的方法
2017/10/19 Javascript
Angular2+如何去除url中的#号详解
2017/12/20 Javascript
Vue实现按钮旋转和移动位置的实例代码
2018/08/09 Javascript
vue使用echarts图表的详细方法
2018/10/22 Javascript
vue里如何主动销毁keep-alive缓存的组件
2019/03/21 Javascript
基于Element封装一个表格组件tableList的使用方法
2020/06/29 Javascript
js动态添加带圆圈序号列表的实例代码
2021/02/18 Javascript
python自动化测试之连接几组测试包实例
2014/09/28 Python
Python的Bottle框架的一些使用技巧介绍
2015/04/08 Python
python爬虫框架scrapy实现模拟登录操作示例
2018/08/02 Python
python之生产者消费者模型实现详解
2019/07/27 Python
利用Python检测URL状态
2019/07/31 Python
python3 selenium自动化 frame表单嵌套的切换方法
2019/08/23 Python
Python使用scipy模块实现一维卷积运算示例
2019/09/05 Python
Python selenium使用autoIT上传附件过程详解
2020/05/26 Python
python 实现的IP 存活扫描脚本
2020/12/10 Python
Pytorch如何切换 cpu和gpu的使用详解
2021/03/01 Python
Betsey Johnson官网:妖娆可爱的连衣裙及鞋子、手袋和配件
2016/12/30 全球购物
影视制作岗位职责
2013/12/04 职场文书
单位门卫岗位职责
2013/12/20 职场文书
单位创先争优活动方案
2014/01/26 职场文书
学生党员的自我评价范文
2014/03/01 职场文书
工厂仓库管理员岗位职责
2015/04/09 职场文书
毕业设计致谢语
2015/05/14 职场文书
python爬取豆瓣电影TOP250数据
2021/05/23 Python