微信小程序生成海报 / 两张图片合并生成一张

一张背景图,一个二维码,生成一张全屏海报,二维码位于右下角(二维码位置可以调整)

方法思路:使用微信小程序的canvas组件

1、获取canvas组件定义一个canvas上下文
2、获取设备信息,将设备宽高设置为canvas画布的大小
3、在图片加载完成后开始绘制,可以调整绘制图片的起始位置坐标以及大小
4、绘制完成后将canvas转成图片
5、下载到图库
javascript 复制代码
<canvas type="2d" id="myCanvas"></canvas>
javascript 复制代码
handleImg() {
    try {
      const query = wx.createSelectorQuery();
      query.select('#myCanvas')
      .fields({
        node: true,
        size: true
      })
      .exec((res) => {
        const canvas = res[0].node;
        const ctx = canvas.getContext('2d');
        const systemInfo = wx.getSystemInfoSync();
        const dpr = systemInfo.pixelRatio;
        const { windowWidth, windowHeight } = systemInfo
        // 根据设备的像素比 把画布设为全屏
        canvas.width = windowWidth * dpr;
        canvas.height = windowHeight * dpr;
        ctx.scale(dpr, dpr)
        let that = this
        const img = canvas.createImage();
        img.src = '第一张图片的url';
        img.onload = () => {
          const qrcodeImg = canvas.createImage();
          qrcodeImg.src = '第二张图片的url'
          qrcodeImg.onload = () => {
          	// 绘制第一张图片
            ctx.drawImage(img, 0, 0, windowWidth, windowHeight);
            // 绘制第二张图片
            ctx.drawImage(qrcodeImg, windowWidth - 100, windowHeight - 100, 60, 60);
            // 延时保存图片
            setTimeout(() => {
              wx.canvasToTempFilePath({
                canvas,
                destWidth: windowWidth * dpr,
                destHeight: windowHeight * dpr,
                success(res) {
                  console.log('生成的图片路径:', res.tempFilePath);
                  that.saveImageToAlbum(res.tempFilePath)
                },
                fail(err) {
                  console.error('canvasToTempFilePath 保存失败:', err);
              });
            }, 500);
          }
        };
      });
    } catch (err) {
      console.log('trycatch失败',err)
    }
  },
  saveImageToAlbum(filePath) {
    wx.saveImageToPhotosAlbum({
      filePath: filePath,
      success(res) {
        wx.showToast({
          title: '保存成功',
          icon: 'success',
          duration: 2000
        });
      },
      fail(err) {
        console.error('保存失败:', err);
      }
    });
  },

注意:

  • 等图片加载完成后开始绘制
  • 绘制完成后稍加延迟再转成图片

把图片链接准备好替换代码中的占位文字即可运行

有问题欢迎留言交流~

相关推荐
内存不泄露31 分钟前
基于协同过滤的旅游景区售票平台及小程序
小程序·旅游
低代码布道师2 小时前
教培管家第03讲:集结号角——接入企微机器人实现新线索通知
低代码·小程序·机器人·企业微信·云开发
数字游民952717 小时前
推荐一个自带流量加成的小程序接口
人工智能·ai·小程序
2501_9159090617 小时前
Charles 抓不到包怎么办?iOS 调试过程中如何判断请求路径
android·ios·小程序·https·uni-app·iphone·webview
2501_9160074717 小时前
iOS和iPadOS文件管理系统全面解析与使用指南
android·ios·小程序·https·uni-app·iphone·webview
2501_915921431 天前
iOS App 开发阶段性能优化,观察 CPU、内存和日志变化
android·ios·性能优化·小程序·uni-app·iphone·webview
qq_12498707531 天前
基于微信小程序的垃圾分类信息系统(源码+论文+部署+安装)
java·前端·spring boot·后端·微信小程序·小程序·计算机毕业设计
qq_12498707531 天前
基于微信小程序的照片社交平台(源码+论文+部署+安装)
java·大数据·微信小程序·小程序·毕业设计·计算机毕业设计
Focussend智能化营销1 天前
【无标题】重构增长链路:如何将企业小程序从“成本中心”,改造为“利润中心”?
人工智能·小程序·重构·自动化·内容运营·数字化营销
游戏开发爱好者81 天前
在 iOS 开发、测试与上架过程中 如何做证书管理
android·ios·小程序·https·uni-app·iphone·webview