关于canvas画布内容阻挡view元素显示的层级问题

由于canvas所绘制出来的内容属于原生窗体,属于最高的层级所以无论把cssz-index属性值调到多大都不会遮挡住canvas所绘制的内容,因此我们需要将canvas转化为图片,将显示的内容由原本的canvas原生窗体转化为图片显示

let canvasPath = "" //绘制的canvas图片
ctx.draw(false, () => {
	setTimeout(() => {
		wx.canvasToTempFilePath({
			canvasId: "myCanvas",
			complete: function (res) 				
				canvasPath = res.tempFilePath,
                //二次转化保证图片能够成功获取
				if (!that.data.canvasPath) {
					setTimeout(() => {
						wx.canvasToTempFilePath({
						    canvasId: "myCanvas",
							complete: function (res) {
								canvasPath= res.tempFilePath,
							},
						})
					}, 300)
				}
			},
		})
	}, 300)
//添加计时器防止获取到的canvas的宽高为0
})

可以在图片未生成之前,先使用canvas暂时显示绘制的内容,图片生成后会自动替代

<view wx:if="{{!canvasPath}}">
    <canvas canvas-id="myCanvas" style="width: 310px; height: 530px;"></canvas>
</view>
<van-image wx:else width="310px" height="530px" src="{{canvasPath}}" />

 使用uniapp开发的小伙伴只需要件wx的对象改为uni就ok了

wx.canvasToTempFilePath => uni.canvasToTempFilePath

当然使用uniapp开发的小伙伴们也可以使用subNVues原生子窗体来达到遮挡canvas原生窗体的效果,后面如果有想要了解的小伙伴比较多的话,我也会出一期subNVues原生子窗体的详细教程

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

夏梦春蝉

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值