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

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

相关文章

golang程序打包成脚本部署到Linux系统方式

《golang程序打包成脚本部署到Linux系统方式》Golang程序通过本地编译(设置GOOS为linux生成无后缀二进制文件),上传至Linux服务器后赋权执行,使用nohup命令实现后台运行,完... 目录本地编译golang程序上传Golang二进制文件到linux服务器总结本地编译Golang程序

使用Docker构建Python Flask程序的详细教程

《使用Docker构建PythonFlask程序的详细教程》在当今的软件开发领域,容器化技术正变得越来越流行,而Docker无疑是其中的佼佼者,本文我们就来聊聊如何使用Docker构建一个简单的Py... 目录引言一、准备工作二、创建 Flask 应用程序三、创建 dockerfile四、构建 Docker

java向微信服务号发送消息的完整步骤实例

《java向微信服务号发送消息的完整步骤实例》:本文主要介绍java向微信服务号发送消息的相关资料,包括申请测试号获取appID/appsecret、关注公众号获取openID、配置消息模板及代码... 目录步骤1. 申请测试系统2. 公众号账号信息3. 关注测试号二维码4. 消息模板接口5. Java测试

Python基于微信OCR引擎实现高效图片文字识别

《Python基于微信OCR引擎实现高效图片文字识别》这篇文章主要为大家详细介绍了一款基于微信OCR引擎的图片文字识别桌面应用开发全过程,可以实现从图片拖拽识别到文字提取,感兴趣的小伙伴可以跟随小编一... 目录一、项目概述1.1 开发背景1.2 技术选型1.3 核心优势二、功能详解2.1 核心功能模块2.

python编写朋克风格的天气查询程序

《python编写朋克风格的天气查询程序》这篇文章主要为大家详细介绍了一个基于Python的桌面应用程序,使用了tkinter库来创建图形用户界面并通过requests库调用Open-MeteoAPI... 目录工具介绍工具使用说明python脚本内容如何运行脚本工具介绍这个天气查询工具是一个基于 Pyt

Ubuntu设置程序开机自启动的操作步骤

《Ubuntu设置程序开机自启动的操作步骤》在部署程序到边缘端时,我们总希望可以通电即启动我们写好的程序,本篇博客用以记录如何在ubuntu开机执行某条命令或者某个可执行程序,需要的朋友可以参考下... 目录1、概述2、图形界面设置3、设置为Systemd服务1、概述测试环境:Ubuntu22.04 带图

Python实现自动化Word文档样式复制与内容生成

《Python实现自动化Word文档样式复制与内容生成》在办公自动化领域,高效处理Word文档的样式和内容复制是一个常见需求,本文将展示如何利用Python的python-docx库实现... 目录一、为什么需要自动化 Word 文档处理二、核心功能实现:样式与表格的深度复制1. 表格复制(含样式与内容)2

Python程序打包exe,单文件和多文件方式

《Python程序打包exe,单文件和多文件方式》:本文主要介绍Python程序打包exe,单文件和多文件方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录python 脚本打成exe文件安装Pyinstaller准备一个ico图标打包方式一(适用于文件较少的程

python如何生成指定文件大小

《python如何生成指定文件大小》:本文主要介绍python如何生成指定文件大小的实现方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录python生成指定文件大小方法一(速度最快)方法二(中等速度)方法三(生成可读文本文件–较慢)方法四(使用内存映射高效生成

Maven项目中集成数据库文档生成工具的操作步骤

《Maven项目中集成数据库文档生成工具的操作步骤》在Maven项目中,可以通过集成数据库文档生成工具来自动生成数据库文档,本文为大家整理了使用screw-maven-plugin(推荐)的完... 目录1. 添加插件配置到 pom.XML2. 配置数据库信息3. 执行生成命令4. 高级配置选项5. 注意事