小程序----使用图表显示数据--canvas

需求:在小程序上实现数据可视化

思路:本来想用的是echarts或者相关的可视化插件,但因为用的是vue3,大多数插件不支持,所以用了echarts,但最后打包的时候说包太大超过2M无法上传,百度了一下,说包太大可以进行分包,但是分包的时候还有很多条件,例如tabbar必须在主包,而且最重要的是主包还不能使用分包的资源,那这样的话,如果把echarts这个页面封装的页面放到分包里面,那我主包就没法引用这个图表页面显示了,所以分包是不现实的(然而这一点是在我分完包之后才知道的,所以这告诉我们,无论使用什么新东西都要认真阅读文档,读明白所有使用条件,再决定是否可以使用),分包实现不了,最后只能放弃echarts,转向用canvas绘图,其实最开始也是考虑过使用canvas的,但是因为canvas刚自己看了文档不久,不太熟练,而且也没太想好,所以才用echarts的,但最后还是回到了canvas上。

效果图:

实现过程:其实就是利用canvas 2d来画圆,具体属性大家可以到这个网站查看HTML5 Canvas | 菜鸟教程

但是有一点要注意的是,canvas原生属性画图优先级是最高的,且不受z-index等优先级属性控制,所以可能会有一些优先级问题,所以最后我把canvas绘出来的图形转成了图片显示在页面上,这样就没有了优先级的问题。

实现代码:

复制代码
 <canvas v-if="!imgsrc" id="canvas" canvas-id="canvas" style="width: 384px; height: 150px;" ></canvas>
  <image v-if="imgsrc" :src="imgsrc" ></image>

	let that =this
			var ctx = uni.createCanvasContext('canvas', this);
			let end = (this.data.done / this.data.total ) * 2 * Math.PI; //设置弧度
			ctx.setLineWidth(12); // 设置圆环的宽度
			ctx.arc(100, 80, 60, 0, 2 * Math.PI)
			ctx.setStrokeStyle('#ececec');
			ctx.stroke(); //对当前路径进行描边
			// ctx.setLineCap('square'); // 设置圆环端点的形状  无圆角
			ctx.beginPath(); //开始一个新的路径
			ctx.setStrokeStyle('#6db500'); // 设置圆环的颜色
			ctx.setLineCap('round'); // 设置圆环端点的形状  圆角
			ctx.arc(100, 80, 60, 0, end, false);
			ctx.stroke(); //对当前路径进行描边
			//设置一个原点(110,110),半径为100的圆的路径到当前路径
			ctx.stroke(); //对当前路径进行描边
			ctx.draw(false,()=>{
				// 生成图片
				wx.canvasToTempFilePath({
				  height: 150,
				  canvasId: 'canvas',
				  success: (res) => {
					  that.imgsrc = res.tempFilePath
				  },
				  fail: (res) => {
				    console.log(res);
				  }
				},that);
			});
相关推荐
weixin_lynhgworld11 小时前
从闲置到珍宝:旧物回收小程序系统重塑物品价值
小程序·旧物回收
2501_9160074715 小时前
iOS App 上架实战 从内测到应用商店发布的全周期流程解析
android·ios·小程序·https·uni-app·iphone·webview
小小怪下士_---_21 小时前
uniapp开发微信小程序自定义导航栏
前端·vue.js·微信小程序·小程序·uni-app
fakaifa2 天前
点大餐饮独立版系统源码v1.0.3+uniapp前端+搭建教程
小程序·uni-app·php·源码下载·点大餐饮·扫码点单
说私域2 天前
基于开源 AI 大模型 AI 智能名片 S2B2C 商城小程序视角下的企业组织能力建设与破圈升级
人工智能·小程序
fakaifa2 天前
【最新版】CRMEB Pro版v3.4系统源码全开源+PC端+uniapp前端+搭建教程
人工智能·小程序·uni-app·php·crmeb·源码下载·crmebpro
2501_915918412 天前
iOS 应用上架全流程实践,从开发内测到正式发布的多工具组合方案
android·ios·小程序·https·uni-app·iphone·webview
上海云盾第一敬业销售3 天前
小程序被爬虫攻击,使用waf能防护吗?
爬虫·小程序
suncentwl3 天前
做一个答题pk小程序多少钱?
小程序·答题小程序·知识竞赛·答题pk软件
说私域3 天前
基于开源链动2+1模式AI智能名片S2B2C商城小程序的流量转化策略研究
人工智能·小程序