微信小程序生成二维码带参海报

2023-12-17 10:48

本文主要是介绍微信小程序生成二维码带参海报,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

微信小程序生成二维码带参海报

没错,就是用 canvas 来实现


文章目录

  • 微信小程序生成二维码带参海报
    • 获取屏幕分辨率比
    • 生成二维码
    • 获取网络图片并转为本地临时文件
    • 绘制背景图片以及二维码
    • 代码片段
    • 参考链接


首先声明,微信小程序的官方文档我是看了的,但是我真没看懂???,所以退而求其次,以下代码可能存在很多冗余,请不吝赐教,拜谢。

获取屏幕分辨率比

讲到生成海报,就不得不提分辨率比,因为canvas里设置的值是基于设计稿的,但是这个二维码图片的尺寸及位置是设置不了微信小程序里的自适应单位 rpx 的,所以我们需要先获取屏幕分辨率比。

	/** 获取屏幕比例 */_getScreenRatio() {/** 设计稿里的屏幕宽度 */const ORI_WIDTH = 375;return new Promise(resolve => {wx.getSystemInfo({success: res => {this.setData({ratio: ORI_WIDTH / res.windowWidth || 1});resolve(null);}// 因为设置了ratio的默认初始值为1,所以这里不做false回调处理});});},

生成二维码

这里我用到了 weapp-qrcode包 ,因为使用npm包构建有些小问题,原谅偷懒的我直接复制了 文件weapp.qrcode.esm.js。

	import drawQrcode from './weapp.qrcode.esm';Page({/** 根据链接生成动态二维码 */_getGenerateQR() {const QRCodeWidth = 115 / this.data.ratio; // 是canvasQRCode的长宽除以2,即真实二维码图片的长宽除以2const QRCodeHeight = 115 / this.data.ratio;const CanvasId = 'canvasQRCode'; // 页面二维码canvas容器的ID,必须在页面添加canvas,且设置好长宽return new Promise(resolve => {drawQrcode({width: QRCodeWidth,height: QRCodeHeight,canvasId: CanvasId,text: '要生成二维码的链接,可以在其他地方设置,用this.data.xxx获取',callback: e => {// HACK: 安卓机上不准确,生成的二维码无法扫描,加延时解决setTimeout(() => {console.log('_getGenerageQR()', 'qrcode: ', e);// 将canvas保存至临时文件wx.canvasToTempFilePath({canvasId: CanvasId,success: res => {resolve(res.tempFilePath);}});}, 500);}});});}
});

获取网络图片并转为本地临时文件

注意这里的网络图片域名必须是【微信公众平台】里面设置了的。

设置download域名

let backgroundImgSrc = 'https://xxx/yyy.png';wx.getImageInfo({src: backgroundImgSrc,success: res => {this._drawImage(res.path, qrcodeSrc);  // 绘制合成图片},fail: err => {console.error('_drawImage/wx.getImageInfo()', '获取网络图片失败', err);}});

绘制背景图片以及二维码

	/*** 绘制带二维码的背景图片* @param {number} index 背景图片及canvas编号* @param {String} backgroundImgPath 背景图片本地地址* @param {String} qrcodeSrc 二维码图片本地临时地址*/_drawImage(backgroundImgPath, qrcodeSrc) {// 图片尺寸常量const backImgWidth = 353.5 / this.data.ratio;const backImgHeight = 525 / this.data.ratio;const qrcodeX = 117 / this.data.ratio;const qrcodeY = 280.5 / this.data.ratio;const qrcodeWidth = 115 / this.data.ratio;const qrcodeHeight = 115 / this.data.ratio;// 准备画布,设置长宽let ctx = wx.createCanvasContext('canvasBackground');  // 这个canvas必须是在页面里存在的ctx.drawImage(backgroundImgPath, 0, 0, backImgWidth, backImgHeight); // 设置背景图片ctx.drawImage(qrcodeSrc, qrcodeX, qrcodeY, qrcodeWidth, qrcodeHeight); // X坐标,Y坐标,二维码长,二维码宽ctx.draw(true, () => {// 为了防止canvas资源转换失败,所以将资源转换放在draw的成功回调内执行wx.canvasToTempFilePath({canvasId: 'canvasBackground',success: res => {this.setData({imgSrc: res.tempFilePath});                    wx.hideLoading();  // 隐藏onload内的加载中},fail: err => {console.error('_drawImage/wx.canvasToTempFilePath()','获取canvas临时图片地址失败',err);}});});}

代码片段

微信小程序代码片段

参考链接

感谢
[1] 微信小程序官方文档 扫普通链接二维码打开小程序
[2] yingye weapp-qrcode

这篇关于微信小程序生成二维码带参海报的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/504098

相关文章

在不同系统间迁移Python程序的方法与教程

《在不同系统间迁移Python程序的方法与教程》本文介绍了几种将Windows上编写的Python程序迁移到Linux服务器上的方法,包括使用虚拟环境和依赖冻结、容器化技术(如Docker)、使用An... 目录使用虚拟环境和依赖冻结1. 创建虚拟环境2. 冻结依赖使用容器化技术(如 docker)1. 创

浅析如何使用Swagger生成带权限控制的API文档

《浅析如何使用Swagger生成带权限控制的API文档》当涉及到权限控制时,如何生成既安全又详细的API文档就成了一个关键问题,所以这篇文章小编就来和大家好好聊聊如何用Swagger来生成带有... 目录准备工作配置 Swagger权限控制给 API 加上权限注解查看文档注意事项在咱们的开发工作里,API

Java使用POI-TL和JFreeChart动态生成Word报告

《Java使用POI-TL和JFreeChart动态生成Word报告》本文介绍了使用POI-TL和JFreeChart生成包含动态数据和图表的Word报告的方法,并分享了实际开发中的踩坑经验,通过代码... 目录前言一、需求背景二、方案分析三、 POI-TL + JFreeChart 实现3.1 Maven

MybatisGenerator文件生成不出对应文件的问题

《MybatisGenerator文件生成不出对应文件的问题》本文介绍了使用MybatisGenerator生成文件时遇到的问题及解决方法,主要步骤包括检查目标表是否存在、是否能连接到数据库、配置生成... 目录MyBATisGenerator 文件生成不出对应文件先在项目结构里引入“targetProje

Python使用qrcode库实现生成二维码的操作指南

《Python使用qrcode库实现生成二维码的操作指南》二维码是一种广泛使用的二维条码,因其高效的数据存储能力和易于扫描的特点,广泛应用于支付、身份验证、营销推广等领域,Pythonqrcode库是... 目录一、安装 python qrcode 库二、基本使用方法1. 生成简单二维码2. 生成带 Log

Python使用Pandas库将Excel数据叠加生成新DataFrame的操作指南

《Python使用Pandas库将Excel数据叠加生成新DataFrame的操作指南》在日常数据处理工作中,我们经常需要将不同Excel文档中的数据整合到一个新的DataFrame中,以便进行进一步... 目录一、准备工作二、读取Excel文件三、数据叠加四、处理重复数据(可选)五、保存新DataFram

SpringBoot生成和操作PDF的代码详解

《SpringBoot生成和操作PDF的代码详解》本文主要介绍了在SpringBoot项目下,通过代码和操作步骤,详细的介绍了如何操作PDF,希望可以帮助到准备通过JAVA操作PDF的你,项目框架用的... 目录本文简介PDF文件简介代码实现PDF操作基于PDF模板生成,并下载完全基于代码生成,并保存合并P

详解Java中如何使用JFreeChart生成甘特图

《详解Java中如何使用JFreeChart生成甘特图》甘特图是一种流行的项目管理工具,用于显示项目的进度和任务分配,在Java开发中,JFreeChart是一个强大的开源图表库,能够生成各种类型的图... 目录引言一、JFreeChart简介二、准备工作三、创建甘特图1. 定义数据集2. 创建甘特图3.

W外链微信推广短连接怎么做?

制作微信推广链接的难点分析 一、内容创作难度 制作微信推广链接时,首先需要创作有吸引力的内容。这不仅要求内容本身有趣、有价值,还要能够激起人们的分享欲望。对于许多企业和个人来说,尤其是那些缺乏创意和写作能力的人来说,这是制作微信推广链接的一大难点。 二、精准定位难度 微信用户群体庞大,不同用户的需求和兴趣各异。因此,制作推广链接时需要精准定位目标受众,以便更有效地吸引他们点击并分享链接

AI一键生成 PPT

AI一键生成 PPT 操作步骤 作为一名打工人,是不是经常需要制作各种PPT来分享我的生活和想法。但是,你们知道,有时候灵感来了,时间却不够用了!😩直到我发现了Kimi AI——一个能够自动生成PPT的神奇助手!🌟 什么是Kimi? 一款月之暗面科技有限公司开发的AI办公工具,帮助用户快速生成高质量的演示文稿。 无论你是职场人士、学生还是教师,Kimi都能够为你的办公文