canvas绘制简易百分比仪表盘dashboard
来源:互联网 发布:宜信好望角 知乎 编辑:程序博客网 时间:2024/04/29 21:36
由于最近工作中,经常会遇到一些动态百分比的仪表盘,一开始都是用图片样式方式实现;
但是随着越来越多的项目,决定用canvas绘制一个简易的仪表盘,便于以后项目中直接使用;
现版本只是书写为方法形式,也许之后会有时间对其优化为插件形式。
但是随着越来越多的项目,决定用canvas绘制一个简易的仪表盘,便于以后项目中直接使用;
现版本只是书写为方法形式,也许之后会有时间对其优化为插件形式。
简简单单而已,以下直接给出代码和执行过程中的三张截图:
<!doctype html><html lang="en"><head> <meta charset="utf-8"> <meta http-equiv="Pragma" content="no-cache"> <meta name="viewport" content="width=device-width, initial-scale=1.0, user-scalable=no"/> <meta name="format-detection" content="telephone=no"/> <meta name="apple-mobile-web-app-capable" content="yes"/> <meta name="apple-mobile-web-app-status-bar-style" content="black"/> <title>canvas绘制简易百分比仪表盘dashboard(建议最好用于移动端)</title> <style type="text/css"> div{margin:1rem;background:#eee;padding:.3rem; position:relative } div canvas{background:#cacaca; -webkit-transform: rotateZ(-270deg); transform:rotateZ(-270deg); -webkit-animation:ani01 1s ease 0s both; animation:ani01 1s ease 0s both; } @-webkit-keyframes ani01 { 0%{ -webkit-transform:scale(.5,.5) rotateZ(-270deg); transform:scale(.5,.5) rotateZ(-270deg); } 100%{ -webkit-transform:scale(1,1) rotateZ(-90deg); transform:scale(1,1) rotateZ(-90deg); } } @keyframes ani01 { 0%{ -webkit-transform:scale(.5,.5) rotateZ(-270deg); transform:scale(.5,.5) rotateZ(-270deg); } 100%{ -webkit-transform:scale(1,1) rotateZ(-90deg); transform:scale(1,1) rotateZ(-90deg); } } </style></head><body><div> <canvas id="myCanvas1" data-percent="80"> 您的浏览器不支持canvas标签。 </canvas> <span style="display:block;position:absolute;top:.94rem;left:.3rem;width:2rem;text-align:center;font-size:.5rem;font-family:microsoft Yahei" id="dushu" >0</span></div><script type="text/javascript" src="../js/flexible.js"></script><script type="text/javascript"> var pper=0; var pper_interal; var dushu=document.getElementById('dushu'); var aaa=drawCanvanPercent('myCanvas1','rem',2,'#0e9cfa',0.2,'#fff'); function drawCanvanPercent(ele_id,dw,cir_r,cir_color,line_w,fill_color){ if(dw=="rem"){ cir_r=cir_r*(window.screen.width/10); line_w=line_w*(window.screen.width/10); } var canvas = document.getElementById(ele_id); var circle = { r : cir_r/2, //圆的半径 per : canvas.getAttribute('data-percent'), //百分比分子 color : cir_color, //圆的颜色 lineWidth : line_w //圆的颜色 }; canvas.width=canvas.height=circle.r*2; canvas.style.borderRadius="50%"; if(canvas.getContext){ var ctx2 = canvas.getContext("2d"); ctx2.fillStyle = fill_color; ctx2.arc(circle.r, circle.r, circle.r-circle.lineWidth/2, 0, Math.PI*2, false); ctx2.fill(); var ctx = canvas.getContext("2d"); pper_interal= setInterval(function () { drawMove(ctx,circle); }, 10); } } function drawMove(ctx,circle){ if(pper>=circle.per){ pper=circle.per; clearTimeout(pper_interal); }else{ pper++; } dushu.innerText=pper+'%'; ctx.beginPath(); ctx.strokeStyle = circle.color; ctx.lineWidth=circle.lineWidth; ctx.arc(circle.r, circle.r, circle.r, 0, Math.PI*(pper/100)*360/180, false); ctx.stroke(); } </script></body></html>
截图如下:
建议:不要因为简单而不去动手,多动手多思考,你会进步的。
0 0
- canvas绘制简易百分比仪表盘dashboard
- canvas绘制简易百分比圆饼效果
- CANVAS绘制仪表盘
- canvas 绘制仪表盘
- Canvas---Canvas绘制钟表,仪表盘
- 3.canvas实现刻度仪表盘的绘制
- canvas绘制动态加载圆形百分比
- H5 canvas 绘制简易时钟
- EXCEL制作dashboard仪表盘
- 自定义仪表盘DashBoard - -kankanstyle
- canvas仪表盘
- canvas绘制圆环百分比进度的动态效果
- H5动画,canvas绘制圆环百分比进度的动态效果
- H5动画,canvas绘制圆环百分比进度的动态效果
- canvas写仪表盘
- Libgdx 简易汽车仪表盘
- 管理SAS DashBoard 仪表盘的安全
- 码表dashboard仪表盘自定义View的开发
- Layer类和Sprite 类的处理
- linux crontab 定时任务被重复执行多次问题
- 附件点击即下载的实现
- matlab 常用命令
- 剖析Disruptor:为什么会这么快?(一)Ringbuffer的特别之处
- canvas绘制简易百分比仪表盘dashboard
- Spring基础学习二 : IOC控制反转
- ruby 安装gem报错:`SSL_set_tlsext_host_name' was not declared in this scope
- 老司机谈APK瘦身套路-图片资源篇
- 查看设备、文件被哪个进程使用
- android4.4默认输入法设置
- python迭代器itertools
- 正确的加载自己写的dll
- 栈的典型应用 —— 括号匹配