canvas绘制百分比圆环进度条
开发项目,PM会跟踪项目进度;完成某个事情,也可以设置一个完成的进度。
这里用canvas绘制一个简单百分比圆环进度条。
看下效果:
1. 动画方式
2. 静默方式
贴上代码,仅供参考
/**
* LBS drawRing
* Date: 2015-04-24
* ==================================
* opts.parent 插入到哪里 一个JS元素对象
* opts.width 宽度 = 2* (半径+弧宽)
* opts.radius 半径
* opts.arc 弧宽
* opts.perent 百分比
* opts.color 弧渲染颜色 [底色,进度色]
* opts.textColor 文字渲染颜色
* opts.textSize 文字渲染大小
* opts.animated 是否以动画的方式绘制 默认false
* opts.after 绘制完成时执行函数
* ==================================
**/ function drawRing(opts) {
var _opts = {
parent: document.body,
width: 100,
radius: 45,
arc: 5,
perent: 100,
color: ['#ccc', '#042b61'],
textColor: '#000',
textSize: '14px',
animated: false,
after: function() {}
}, k;
for (k in opts) _opts[k] = opts[k]; var parent = _opts.parent,
width = _opts.width,
radius = _opts.radius,
arc = _opts.arc,
perent = parseFloat(_opts.perent),
color = _opts.color,
textSize = _opts.textSize,
textColor = _opts.textColor,
c = document.createElement('canvas'),
ctx = null,
x = 0,
animated = _opts.animated,
after = _opts.after; parent.appendChild(c);
ctx = c.getContext("2d");
ctx.canvas.width = width;
ctx.canvas.height = width; function clearFill() {
ctx.clearRect(0, 0, width, width);
} function fillBG() {
ctx.beginPath();
ctx.lineWidth = arc;
ctx.strokeStyle = color[0];
ctx.arc(width / 2, width / 2, radius, 0, 2 * Math.PI);
ctx.stroke();
} function fillArc(x) {
ctx.beginPath();
ctx.lineWidth = arc;
ctx.strokeStyle = color[1];
ctx.arc(width / 2, width / 2, radius, -90 * Math.PI / 180, (x * 3.6 - 90) * Math.PI / 180);
ctx.stroke();
} function fillText(x) {
ctx.font = textSize + ' Arial';
ctx.fillStyle = textColor;
ctx.textBaseline = "middle";
ctx.textAlign = 'center';
ctx.fillText(x.toFixed(1) + '%', width / 2, width / 2);
} function fill(x) {
fillBG();
fillArc(x);
fillText(x);
} if (!animated) return fill(perent); fill(x);
!function animate() {
if (++x > perent) return after && after();
setTimeout(animate, 10);
clearFill();
fill(x);
}();
}
很简单的一段代码
先创建一个canvas画布对象,设置宽高。
var c = document.createElement('canvas');
document.body.appendChild(c);
var ctx = c.getContext("2d");
ctx.canvas.width = width;
ctx.canvas.height = width;
圆环由两部分组成,底部灰色完整的环,根据百分比变动的环。
先绘制底部完整的环。
//起始一条路径
ctx.beginPath();
//设置当前线条的宽度
ctx.lineWidth = 10; //10px
//设置笔触的颜色
ctx.strokeStyle = '#ccc';
//arc() 方法创建弧/曲线(用于创建圆或部分圆)
ctx.arc(100, 100, 90, 0, 2 * Math.PI);
//绘制已定义的路径
ctx.stroke();
重点理解:canvas arc() 方法 :HTML5 canvas arc() 方法
arc方法默认是从3点钟方向(90度)开始绘制的,一般要把这个开始处设置平常习惯的0点方向。
也需要理解弧度和角度的互相转换。
degrees = radians * 180/Math.PI
角度等于弧度乘于180再除于PI radians = degrees * Math.PI/180
弧度等于角度度乘于PI再除于180
绘制根据百分比变动的环。
ctx.beginPath();
ctx.lineWidth = 10;
ctx.strokeStyle = '#f30';
//设置开始处为0点钟方向(-90 * Math.PI / 180)
//x为百分比值(0-100)
ctx.arc(100, 100, 90, -90 * Math.PI / 180, (x * 3.6 - 90) * Math.PI / 180);
ctx.stroke();
绘制中间的文字
ctx.font = '40px Arial';
ctx.fillStyle = '#f30';
ctx.textBaseline = 'middle';
ctx.textAlign = 'center';
ctx.fillText('50.0%', 100, 100);
到此一个静止的百分比圆环进度条就绘制完成了。
不满足于绘制静态的,动态的更生动有趣一些。
canvas动态绘制就是在一段时间内:绘制一个区域的内容,清除这个区域内容,再重新绘制内容,重复这个过程(绘制-清除-绘制)。
有兴趣可以去研究一下,上面的代码也可以参考,如果结合动画函数和运动公式可以绘制更生动的百分比圆环进度条哦。
--------------------------------------------
参考:
canvas绘制百分比圆环进度条的更多相关文章
- canvas 绘制动态圆环进度条
由于使用的是vue开发,所以就展示一下绘制函数好了,上图是效果图 drawMain(drawing_elem, percent, forecolor, bgcolor) { /* @drawing_e ...
- Vue/React圆环进度条
数据展示,一直是各行各业乐此不疲的需求,具体到前端开发行业,则是各种各种图表数据展示,各种表格数据展示,烦不胜烦(繁不胜繁)! 前几天刚做了折线图.柱状图.饼状图之类的图表数据展示效果,今天又碰到了类 ...
- css3 制作圆环进度条
引子 移动端做一个 loadiing 加载的图标,跟以往沿用的都不太一样,是一个圆环进度条,圆环进度条也就罢了,还得能用百分比控制. CSS3 实现圆环 demo 刚开始写这个圆环的时候是参照帖子上给 ...
- 两种CSS3圆环进度条详解
晚上睡觉之前,我抽了1个多小时,研究了一下圆环进度条,结合从网上查阅的资料,我终于掌握了两种圆环的生成方法. 这次的效果就是单纯的CSS3效果,也没有写具体的JS,等以后有时间在好好整理一下吧~. 第 ...
- 简单实用的纯CSS百分比圆形进度条插件
percircle是一款简单实用的纯CSS百分比圆形进度条插件.你不需要做任何设置,只需要按该圆形进度条插件提供的标准HTML结构来编写代码,就可以生成一个漂亮的百分比圆形进度条. 首先要做的就是引入 ...
- svg实现圆环进度条
开源实现:https://github.com/lugolabs/circles 自行实现:圆环与svg画布间剩的空间太多. <!DOCTYPE html> <html> &l ...
- CSS3实现圆环进度条
摘要:圆环进度条被应用于各个场景,比如我们可以用来表示加载进度等.通常我们可以用 css3 的动画去实现. 详解 css3 实现圆环进度条 简单的画一个圆环,我们都知道如何使用 css 画一个圆环.( ...
- 浅谈一下关于使用css3来制作圆环进度条
最近PC端项目要做一个这样的页面出来,其他的都很简单,关键在于百分比的圆环效果.我最初打算是直接使用canvas来实现的,因为canvas实现一个圆是很简便的. 下面贴出canvas实现圆环的代码,有 ...
- Android 自定义view --圆形百分比(进度条)
转载请注明出处:http://blog.csdn.net/wingichoy/article/details/50334595 注:本文由于是在学习过程中写的,存在大量问题(overdraw onDr ...
随机推荐
- python语言学习8——字符串和编码
Unicode编码 计算机只能处理数字,如果要处理文本,就必须把文本转化为数字才能处理 有许多编码标准,但是不同的编码标准有时候会混乱,所以Unicode应运而生 Unicode把所有语言统一到一套编 ...
- iOS 同步GET
(注意: 能够整片复制)
- [ACM] hdu 4418 Time travel (高斯消元求期望)
Time travel Problem Description Agent K is one of the greatest agents in a secret organization calle ...
- SE 2014年4月16日
一. 描述BGP路由协议中 BGP路由携带 AS-PATH/ next-hop / ORIGIN / local-preference 属性的特点! BGP协议中的AS-PATH是AS列表,用来 ...
- 中国科学院信息project研究所 第四研究室实习生/应届生招聘
watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvU2hpWmhpeGlu/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA ...
- auto_ptr and scoped_ptr
#include "boost/scoped_ptr.hpp" #include <iostream> #include <memory>//contain ...
- Linux内核——进程管理与调度
进程的管理与调度 进程管理 进程描写叙述符及任务结构 进程存放在叫做任务队列(tasklist)的双向循环链表中.链表中的每一项包括一个详细进程的全部信息,类型为task_struct,称为进程描写叙 ...
- 非洲儿童(南阳oj1036)(馋)
非洲小孩 时间限制:1000 ms | 内存限制:65535 KB 难度:2 描写叙述 家住非洲的小孩,都非常黑.为什么呢? 第一.他们地处热带,太阳辐射严重. 第二,他们不常常洗澡.(常年缺水, ...
- mongoDB 查询附近的人的语句
mongoDB 自带LBS查询附近的人 {"location":{ $nearSphere: { $geometry: { type : "Point", co ...
- ServiceStack.Redis里List的Insert操作
最近用Redis的c#驱动,发现ServiceStack.Redis里List类型的Insert方法调用的时候始终报错,结果反编译dll后,这个方法居然是这样写的: public void Inser ...