直接使用canvas画布合成
1、首先在wxml中输入一个canvas和一个现实最终海报的image
<canvas style="position:fixed;top: 0;left: -100%;" type="2d" id="Canvas"></canvas>2、在onready中通过 wx.createSelectorQuery().select获取canvas画板及上下文context;
<image src="{{imgsrc}}" mode="aspectFit" ></image>
/**3、绘制海报和二维码
* 生命周期函数--监听页面初次渲染完成
*/
onReady() {
const query = wx.createSelectorQuery()
query.select('#Canvas')
.fields({
node: true,
size: true
})
.exec((res) => {
const canvas = res[0].node
const ctx = canvas.getContext('2d')
this.setData({
canvas,
ctx
})
})
},
drawbg() {
if (!this.data.canvas) return
this.data.canvas.width = "300" //海报宽度
this.data.canvas.height = "500" //海报高度
const image = this.data.canvas.createImage();
image.src = "/images/haibaobg.png";//海报背景图片
image.onload = () => {
// 将图片绘制到canvas上
this.data.ctx.drawImage(image, 0, 0, 300, 500)//填充整个canvas画布
this.drawqrcode();
}
},
drawqrcode(){
if (!this.data.canvas) return
const image = this.data.canvas.createImage();
image.src ="/images/qrcode.png";
image.onload = () => {
// 将图片绘制到canvas上
this.data.ctx.drawImage(image, 100, 200, 50, 50)//绘制二维码图片到指定xy位置就好了
wx.canvasToTempFilePath({
canvas: this.data.canvas,
success: (res) => {
that.setData({
imgsrc: res.tempFilePath,
})
//resolve(res.tempFilePath)
},
})
}
}网友回复
如何破解绕开seedance2.0真人照片生成视频 限制?
python有哪些算法可以将视频中的每个帧图片去除指定区域水印合成新的视频?
iphone的激光雷达数据能否实时传输到three三维空间中?
豆包sora等ai视频生成大模型生成的视频水印如何去除?
python如何实现在电脑上拨号打电话给手机?
具身机器人与人形机器人区别?
nodejs如何将一个完整的js代码文件切割成不同的部分混淆后动态加载进入html运行?
为啥windows.onerror捕获js错误是这样的{"message":"Script error.","source":"","lineno":0,"colno":0,"stack":null,
2026年ai将全面接管编程?
WebMCP是干啥的?


