随着小程序的热度下降,更多的人已经开始静下心来开发微信小程序了,最近在开发一款微信小程序的过程中遇到了一个问题:如何用微信小程序实现一个圆形的进度条?整理一番后,记录下来与大家共享。
代码实现的思路原理:
建立两个canvas标签,先绘制底层的浅灰色圆圈背景,再绘制上层的红色进度条。
.wxml的代码如下:
<view class="wrap">
  <view class="circle-box">
    <canvas class="circle" style="width:200px; height:200px;" canvas-id="canvasarccir">
    </canvas>
    <canvas class="circle" style="z-index: -5; width:200px; height:200px;" canvas-id="canvascircle">
    </canvas>
    <view class="draw_btn" bindtap="drawcircle">开始动态绘制</view>
  </view>
</view>
wxss代码
特别注意:底层的canvas最好使用。
page {
  width: 100%;
  height: 100%;
  background-color: #fff;
}
 
.circle-box {
  text-align: center;
  margin-top: 10vw;
}
 
.circle {
  position: absolute;
  left: 0;
  right: 0;
  margin: auto;
}
 
.draw_btn {
  width: 35vw;
  position: absolute;
  top: 33vw;
  right: 0;
  left: 0;
  margin: auto;
  border: 1px #000 solid;
  border-radius: 5vw;
}
js代码如下:
//获取应用实例
var app = getapp()
 
var interval;
var varname;
var ctx = wx.createcanvascontext('canvasarccir');
 
page({
  data: {
  },
  drawcircle: function () {
    clearinterval(varname);
    function drawarc(s, e) {
      ctx.setfillstyle('white');
      ctx.clearrect(0, 0, 200, 200);
      ctx.draw();
      var x = 100, y = 100, radius = 96;
      ctx.setlinewidth(5);
      ctx.setstrokestyle('#d81e06');
      ctx.setlinecap('round');
      ctx.beginpath();
      ctx.arc(x, y, radius, s, e, false);
      ctx.stroke()
      ctx.draw()
    }
    var step = 1, startangle = 1.5 * math.pi, endangle = 0;
    var animation_interval = 1000, n = 60;
    var animation = function () {
      if (step <= n) {
        endangle = step * 2 * math.pi / n + 1.5 * math.pi;
        drawarc(startangle, endangle);
        step++;
      } else {
        clearinterval(varname);
      }
    };
    varname = setinterval(animation, animation_interval);
  },
  onready: function () {
    //创建并返回绘图上下文context对象。
    var cxt_arc = wx.createcanvascontext('canvascircle');
    cxt_arc.setlinewidth(6);
    cxt_arc.setstrokestyle('#eaeaea');
    cxt_arc.setlinecap('round');
    cxt_arc.beginpath();
    cxt_arc.arc(100, 100, 96, 0, 2 * math.pi, false);
    cxt_arc.stroke();
    cxt_arc.draw();
  },
  onload: function (options) {
 
  }
})
注意的要点
1、关于小程序canvas绘制,请观看 微信小程序官方文档绘制
2、开始绘制的路径可以根据 js代码中的变量startangle 来选择从哪里开始绘制
圆形进度条的效果图如下:
初始状态
点击中间按钮开始绘制
绘制过程
绘制结束
更多用微信小程序实现一个圆形的进度条。
   
 
   