手机版

微信小程序之圆形进度条

时间:2021-12-10 来源:互联网 编辑:宝哥软件园 浏览:

需求概要

小程序中使用圆形倒计时,效果图:

微信小程序之圆形进度条(图1)

思路

使用2个帆布一个是背景圆环,一个是彩色圆环。使用setInterval让彩色圆环逐步绘制。

解决方案

第一步先写结构

一个盒子包裹2个帆布以及文字盒子;

盒子使用相对定位作为父级,灵活布局,设置居中;

一个帆布,使用绝对定位作为背景,canvasprogress BG-id=' canvasprogress BG '

另一个帆布,使用相对定位作为进度条,canvasProgress-id=' canvasProgress '

代码如下:

//wxml view class=' container ' view class=' progress _ box ' canvas class=' progress _ BG ' canvasProgress BG-id=' canvasProgress _ canvas ' canvas-id=' canvasProgress '/canvas view class=' progress _ text ' view class=' progress _ dot '/view text class=' progress _ info ' { progress _ txt } }/text/view/view/view//wxss。progress _ box {位置3360相对;宽度宽度:220像素高度: 220 pxdisplay : flex align-items :居中;正义-内容:中心;背景色: # eee}.progress _ BG {位置:绝对;宽度宽度:220像素高度: 220 px}.progress _ canvas { width :220 px;高度: 220 px} .progress _ text { position : absolute;display : flex align-items :居中;正义-内容:中心} .progress _ info { font-size : 36rpx;左填充左: 16rpx字母-spacing: 2rpx} .progress _ dot { width :16 rpxhire : 16 rpx边界半径: 50%;背景色: # FB 9126}

第二步数据绑定

从wxml中可以看到我们使用了一个数据progress_txt,所以在射流研究…中设置数据如下:

data: { progress_txt: '正在匹配中.', },

第三步canvas绘制

敲黑板,划重点

1. 先绘制背景

在射流研究…中封装一个画圆环的函数drawProgressbg,画布画圆在onReady中执行这个函数;小程序帆布组件与H5的帆布有点差别,请查看文档,代码如下

drawing progress BG :函数(){ //使用wx.createContext获取绘图上下文上下文变量CTX=wx。CTX。setline width(4);//设置圆环的宽度CTX。setstrokestyle(' # 20183 b ');//设置圆环的颜色ctx.setLineCap('round') //设置圆环端点的形状ctx.begi

nPath();//开始一个新的路径 ctx.arc(110, 110, 100, 0, 2 * Math.PI, false); //设置一个原点(100,100),半径为90的圆的路径到当前路径 ctx.stroke();//对当前路径进行描边 ctx.draw(); }, onReady: function () { this.drawProgressbg(); },

看一下效果如下:

微信小程序之圆形进度条(图2)

2. 绘制彩色圆环

  1. 在js中封装一个画圆环的函数drawCircle,
  2. 在onReady中执行这个函数;
drawCircle: function (step){      var context = wx.createCanvasContext('canvasProgress');      // 设置渐变      var gradient = context.createLinearGradient(200, 100, 100, 200);      gradient.addColorStop("0", "#2661DD");      gradient.addColorStop("0.5", "#40ED94");      gradient.addColorStop("1.0", "#5956CC");            context.setLineWidth(10);      context.setStrokeStyle(gradient);      context.setLineCap('round')      context.beginPath();       // 参数step 为绘制的圆环周长,从0到2为一周 。 -Math.PI / 2 将起始角设在12点钟位置 ,结束角 通过改变 step 的值确定      context.arc(110, 110, 100, -Math.PI / 2, step * Math.PI - Math.PI / 2, false);      context.stroke();       context.draw()   }, onReady: function () {     this.drawProgressbg();      this.drawCircle(2)   },
this.drawCircle(0.5) 效果如下:this.drawCircle(1) 效果如下:this.drawCircle(2) 效果如下:

微信小程序之圆形进度条(图3)

微信小程序之圆形进度条(图4)

微信小程序之圆形进度条(图5)

3. 设置一个定时器

  1. 在js中的data设置一个计数器 count,一个步骤step,一个定时器
  2. 在js中封装一个定时器的函数countInterval,
  3. 在onReady中执行这个函数;
data: {    progress_txt: '正在匹配中...',      count:0, // 设置 计数器 初始为0    countTimer: null // 设置 定时器 初始为null  },    countInterval: function () {    // 设置倒计时 定时器 每100毫秒执行一次,计数器count+1 ,耗时6秒绘一圈    this.countTimer = setInterval(() => {      if (this.data.count <= 60) {        /* 绘制彩色圆环进度条          注意此处 传参 step 取值范围是0到2,        所以 计数器 最大值 60 对应 2 做处理,计数器count=60的时候step=2        */         this.drawCircle(this.data.count / (60/2))        this.data.count++;      } else {        this.setData({          progress_txt: "匹配成功"        });         clearInterval(this.countTimer);      }    }, 100)  }, onReady: function () {    this.drawProgressbg();    // this.drawCircle(2)     this.countInterval()  },

最终效果

微信小程序之圆形进度条(图6)

版权声明:微信小程序之圆形进度条是由宝哥软件园云端程序自动收集整理而来。如果本文侵犯了你的权益,请联系本站底部QQ或者邮箱删除。