资讯

精准传达 • 有效沟通

从品牌网站建设到网络营销策划,从策略到执行的一站式服务

js和canvas如何实现适用于移动端的百分比仪表盘dashboard

小编给大家分享一下js和canvas如何实现适用于移动端的百分比仪表盘dashboard,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!

创新互联是一家专注于成都网站建设、成都网站设计与策划设计,任城网站建设哪家好?创新互联做网站,专注于网站建设十余年,网设计领域的专业建站公司;建站业务涵盖:任城等地区。任城做网站价格咨询:13518219792

具体内容如下

由于最近工作中,经常会遇到一些动态百分比的仪表盘,一开始都是用图片样式方式实现;

但是随着越来越多的项目,决定用canvas绘制一个简易的仪表盘,便于以后项目中直接使用;

现版本只是书写为方法形式,也许之后会有时间对其优化为插件形式。

简简单单而已,以下直接给出代码和执行过程中的三张截图:

 
 
 
   
   
   
   
   
   
  canvas绘制简易百分比仪表盘dashboard(建议最好用于移动端) 
   
    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); 
      } 
    } 
   
 
 
 
          您的浏览器不支持canvas标签。        
          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();    }         

截图如下:

js和canvas如何实现适用于移动端的百分比仪表盘dashboard

js和canvas如何实现适用于移动端的百分比仪表盘dashboard

js和canvas如何实现适用于移动端的百分比仪表盘dashboard

建议:不要因为简单而不去动手,多动手多思考,你会进步的。

JavaScript的特点

1.JavaScript主要用来向HTML页面添加交互行为。 2.JavaScript可以直接嵌入到HTML页面,但写成单独的js文件有利于结构和行为的分离。 3.JavaScript具有跨平台特性,在绝大多数浏览器的支持下,可以在多种平台下运行。

以上是“js和canvas如何实现适用于移动端的百分比仪表盘dashboard”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注创新互联行业资讯频道!


文章题目:js和canvas如何实现适用于移动端的百分比仪表盘dashboard
文章出自:http://cdkjz.cn/article/jipoeo.html
多年建站经验

多一份参考,总有益处

联系快上网,免费获得专属《策划方案》及报价

咨询相关问题或预约面谈,可以通过以下方式与我们联系

大客户专线   成都:13518219792   座机:028-86922220