微信小程序用canvas实现圆形进度条
作者:星星之火M 发布时间:2024-11-10 08:47:48
本文实例为大家分享了微信小程序用canvas实现圆形进度条的具体代码,供大家参考,具体内容如下
先放效果图,如下:
1. wxml文件代码如下
对于圆形进度条中间的文字,如果是简单的,可以用它自带的属性去填充。 比较复杂的,就可以像下面,通过样式将文字定位到圆形进度条中间合适位置。
<view class='circlePage'>
<view class='wrap'>
<!-- 圆形中间的文字 -->
<view class="circleText">
<text class='num'>{{total}}</text>
<view class='line'></view>
<text class="text">总数量</text>
</view>
<!-- 第一个canvas用于绘制白色圆形 第二个canvas用于绘制橙色圆形进度条 -->
<canvas canvas-id='canvas' class="canvas progress"></canvas>
<canvas canvas-id='canvas_p' class="canvas" />
</view>
</view>
wxss文件样式如下:
.circlePage{
background:#00B26A;
padding: 20rpx 0;
}
.wrap {
position:relative;
display: flex;
flex-direction: column;
align-items: center;
justify-content: center;
}
.circleText{
text-align:center;
position:absolute;
display: flex;
flex-direction: column;
justify-content: center;
align-items: center;
}
.num {
font-size: 16px;
font-weight: 200;
color: #fff;
line-height: 12px;
}
.line {
width: 70rpx;
height: 2rpx;
background: rgba(255, 255, 255, 0.4);
margin-top: 12rpx;
margin-bottom: 9rpx;
}
.text {
font-size: 12px;
font-weight: 200;
color: #fff;
line-height: 12px;
}
.canvas{
width: 200rpx;
height: 200rpx;
}
.progress {
position: absolute;
}
2. js文件
1)绘制白色圆形背景
drawCircleBg(),该方法用于绘制白色圆形背景,第一个参数为prefix为canvas标签的canvas-id属性值,第二参数为数据,在此方法中暂时用不到。
在此方法中,重点是cxt_arc.arc(50, 40, 33, 0, 2 * Math.PI, false);看注释每个参数所代表的意思。在圆形中间文字样式比较复杂时,是在外面标签中写,然后再通过样式定位到圆形中间,这过程中,可以结合cxt_arc.arc中的第一个参数(圆心的x坐标)和第二个参数(圆心的y坐标)进行调整。
绘制完后,调用drawCirclePg()方法绘制橙色圆形进度条。
//绘制白色圆形背景
drawCircleBg: function (prefix, data) {
var that = this;
//创建并返回绘图上下文context对象。
let cxt_arc = wx.createCanvasContext(prefix);
cxt_arc.setLineWidth(4); //线条的宽度
cxt_arc.setStrokeStyle('#FFFFFF');//边框颜色
cxt_arc.setLineCap('round');
cxt_arc.beginPath();
// 参数分别:圆心的x坐标;圆心的y坐标;圆半径;起始弧度,单位弧度(在3点钟方向);终止弧度;弧度的方向是否是逆时针
cxt_arc.arc(50, 52, 33, 0, 2 * Math.PI, false);//创建一条弧线
cxt_arc.stroke(); //对当前路径进行描边
cxt_arc.draw();
that.drawCirclePg(prefix, data);
},
2)绘制橙色进度条
该方法中,cxt_arc.arc中的第四个参数【起始弧度】和第五个参数【终止弧度】。
看官方api文档中,如下图中。圆形的起始在右边(3点钟方向),但是一般我们都是以“12点钟方向”为起始点。因此,在该属性的第四个参数中将0改为“-0.5 * Math.PI”就可以了,而相应的,终止点也需要减掉“-0.5 * Math.PI”,具体看如下代码。
//绘制橙色进度条
drawCirclePg: function (prefix, data) {
console.log(data);
var that = this;
//创建并返回绘图上下文context对象。
let cxt_arc = wx.createCanvasContext(prefix + '_p');
var value = (data.num / data.total) * 2;
console.log(value);
cxt_arc.setLineWidth(6);
cxt_arc.setStrokeStyle('#FFC000');
cxt_arc.setLineCap('round');
cxt_arc.beginPath();
cxt_arc.arc(50, 52, 33, -0.5 * Math.PI, Math.PI * (value - 0.5), false);
cxt_arc.stroke();
cxt_arc.draw();
},
全部js文件代码如下:
Page({
/**
* 页面的初始数据
*/
data: {
total:10,
num:3,
},
/**
* 生命周期函数--监听页面加载
*/
onLoad: function (options) {
var that = this;
var data={
total:this.data.total,
num:this.data.num
}
that.drawCircleBg('canvas',data);
},
//绘制白色圆形背景
drawCircleBg: function (prefix, data) {
var that = this;
//创建并返回绘图上下文context对象。
let cxt_arc = wx.createCanvasContext(prefix);
cxt_arc.setLineWidth(4); //线条的宽度
cxt_arc.setStrokeStyle('#FFFFFF');//边框颜色
cxt_arc.setLineCap('round');
cxt_arc.beginPath();
// 参数分别:圆心的x坐标;圆心的y坐标;圆半径;起始弧度,单位弧度(在3点钟方向);终止弧度;弧度的方向是否是逆时针
cxt_arc.arc(50, 40, 33, 0, 2 * Math.PI, false);//创建一条弧线
cxt_arc.stroke(); //对当前路径进行描边
cxt_arc.draw();
that.drawCirclePg(prefix, data);
},
//绘制橙色进度条
drawCirclePg: function (prefix, data) {
console.log(data);
var that = this;
//创建并返回绘图上下文context对象。
let cxt_arc = wx.createCanvasContext(prefix + '_p');
var value = (data.num / data.total) * 2;
console.log(value);
cxt_arc.setLineWidth(6);
cxt_arc.setStrokeStyle('#FFC000');
cxt_arc.setLineCap('round');
cxt_arc.beginPath();
cxt_arc.arc(50, 39, 33, -0.5 * Math.PI, Math.PI * (value - 0.5), false);
cxt_arc.stroke();
cxt_arc.draw();
},
})
来源:https://blog.csdn.net/qq_41638795/article/details/96473911


猜你喜欢
- 链表一种物理存储单元上非连续、非顺序的存储结构,数据元素的逻辑顺序是通过链表中的指针链接次序实现的。链表由一系列结点(链表中每一个元素称为结
- 下面都是我收集的一些比较常用的正则表达式,因为平常可能在表单验证的时候,用到的比较多。特发出来,让各位朋友共同使用。呵呵。匹配中文字符的正则
- 很多人可能发现,无论是在sql 2000, 还是在 sql 2005 中,都没有提供字符串的聚合函数, 所以, 当我们在处理下列要求时,会比
- 今早打开 腾讯ISD的博客 ,看到一篇新的文章,《迷你屋视觉规范简介》,赶紧看了来学习。不过给我抓到问题咯,臭鱼不介意我在这说下吧:这套规范
- 一、聚合函数聚合函数:又叫组函数,用来对表中的数据进行统计和计算,结合group by分组使用,用于统计和计算分组数据常用聚合函数count
- 直接上代码import pygameimport randomdef main(): # 初始化pygame &n
- 下载python3.6.5安装包1. 上传安装包。打开终端,利用命令cd 进入文件所在文件夹里python@ubun
- 一份完全按照李航<<统计学习方法>>介绍的HMM代码,供大家参考,具体内容如下#coding=utf8 '&
- 案例以论坛为例,有个接口返回帖子(posts)信息,然后呢,来了新需求,说需要显示帖子的 author 信息。此时会有两种选择:在 post
- 在最新版的pandas中(不知道之前的版本有没有这个问题),当我们对具有多层次索引的对象做切片或者通过df[bool_list]的方式索引的
- 让我们面对现实吧,你的模型可能还停留在石器时代。我敢打赌你仍然使用32位精度或GASP甚至只在一个GPU上训练。我明白,网上都是各种神经网络
- 阅读上一章:Css布局Chapter 13 为文字指定样式我想以一章的篇幅来讨论用CSS设定文字样式的做法是个好点子.一般处理文字内容大概是
- 前言本文主要给大家介绍了关于使用Python通过subprocess调用adb命令,subprocess包主要功能是执行外部命令(相对Pyt
- 我们一起来回顾一下上一次说到的 interface{}可以用来做多态接口类型分为空接口类型和非空接口类型,他们的底层数据结构不太一
- 将图片放入到白色或黑色背景图中,前提是图片小于背景图片的尺寸,原图为如下,长为192,宽为64。1.将图片放入到白色背景图(224,224)
- 在python中使用open函数对文件进行处理。1.open()python打开文件使用open()函数,返回一个指向文件的指针。该函数常用
- 首先,先介绍两种引入模块的方法。法一:将整个文件引入import 文件名文件名.函数名( ) / 文件名.类名通过这个方法可以运行另外一个文
- 在使用Jupyter notebook时有这么一句代码start_frame = imread(“OwnCollection\vehicle
- 目录问题背景解决方案主要实现原理:可靠性:SpringBoot 集成使用 Redis 分布式锁使用示例参考文档问题背景现在的应用程序架构中,
- 分享一个 * 真网页拾色器(调色板),颜色丰富216色,使用方便。运行截图:<html id="container"