直接使用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)
},
})
}
}
网友回复
python如何实现torrent的服务端进行文件分发p2p下载?
如何在浏览器中录制摄像头和麦克风数据为mp4视频保存下载本地?
go如何编写一个类似docker的linux的虚拟容器?
python如何写一个bittorrent的种子下载客户端?
ai能通过看一个网页的交互过程视频自主模仿复制网页编写代码吗?
ai先写功能代码通过chrome mcp来进行测试功能最后ai美化页面这个流程能行吗?
vue在手机端上下拖拽元素的时候如何禁止父元素及body的滚动导致无法拖拽完成?
使用tailwindcss如何去掉响应式自适应?
有没有直接在浏览器中运行的离线linux系统?
nginx如何保留post或get数据进行url重定向?