直接使用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)
},
})
}
}
网友回复
DLNA与UPnP的区别和不同?
苏超自建抢票app,通过先预约再抽签化解高并发抢票?
python如何让给电脑在局域网中伪装成电视接收手机的投屏图片视频播放?
如何结合python+js如何自己的视频编码与加密播放直播?
python如何在电脑上通过局域网将本地视频或m3u8视频投屏电视播放?
腾讯视频爱奇艺优酷vip电影电视剧视频如何通过python绕过vip收费直接观看?
有没有可免费观看全球电视台直播m3u8地址url的合集?
有没有实现观影自由的免vip影视苹果 CMS V10 API的可用url?
python如何实时检测电脑usb插入检测报警?
如何判断真人操作的鼠标移动直线轨迹与机器操作的轨迹?