用HTML5canvas绘制一个圆环形的进度表示
来源:互联网 发布:下载不了软件怎么办 编辑:程序博客网 时间:2024/04/30 13:20
先看一下画出来的效果,如下图,这样一个圆环形的进度.
我这里使用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方法哦.
转载请注明出处
4 0
- 用HTML5canvas绘制一个圆环形的进度表示
- canvas绘制圆环百分比进度的动态效果
- H5动画,canvas绘制圆环百分比进度的动态效果
- H5动画,canvas绘制圆环百分比进度的动态效果
- 【随心笔录】绘制一个好看的圆环
- 一个自定义圆环进度View
- opengl圆环的绘制
- 用简单的圆环来表示一个任务的完成度
- 绘制一个可以更改进度的圆弧
- 圆环进度
- 圆环进度
- HTML5canvas绘制火柴人
- Android圆环形自定义进度条控件的绘制
- 绘制圆环
- 【android】绘制圆环的三种方式
- 自定义属性和圆环的绘制
- 【android】绘制圆环的三种方式
- 【android】绘制圆环的三种方式
- 知识点整理之Java的Cookie操作
- Javascript面向对象之:一.创建类
- 知识点整理之web.xml中配置error页面
- 内部连接和外部连接
- 另类的package-info.java文件探讨 [转]
- 用HTML5canvas绘制一个圆环形的进度表示
- EXT.NET 选择ComboBox下拉框中的值,另外一个下拉框的显示状态跟着变化
- guacamole搭建,一个基于HTML5的VNC远程桌面
- JSR356标准Java WebSocket
- ubuntu下安装nginx
- ubuntu下安装mysql并配置远程访问
- git常用命令
- JAVA中日期/时间的获取
- git服务器搭建及gitolite权限管理