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

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创建一个功能完整的Windows风格计算器程序

《使用Python创建一个功能完整的Windows风格计算器程序》:本文主要介绍如何使用Python和Tkinter创建一个功能完整的Windows风格计算器程序,包括基本运算、高级科学计算(如三... 目录python实现Windows系统计算器程序(含高级功能)1. 使用Tkinter实现基础计算器2.

Python实现微信自动锁定工具

《Python实现微信自动锁定工具》在数字化办公时代,微信已成为职场沟通的重要工具,但临时离开时忘记锁屏可能导致敏感信息泄露,下面我们就来看看如何使用Python打造一个微信自动锁定工具吧... 目录引言:当微信隐私遇到自动化守护效果展示核心功能全景图技术亮点深度解析1. 无操作检测引擎2. 微信路径智能获

将Java程序打包成EXE文件的实现方式

《将Java程序打包成EXE文件的实现方式》:本文主要介绍将Java程序打包成EXE文件的实现方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录如何将Java程序编程打包成EXE文件1.准备Java程序2.生成JAR包3.选择并安装打包工具4.配置Launch4

Java程序进程起来了但是不打印日志的原因分析

《Java程序进程起来了但是不打印日志的原因分析》:本文主要介绍Java程序进程起来了但是不打印日志的原因分析,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录Java程序进程起来了但是不打印日志的原因1、日志配置问题2、日志文件权限问题3、日志文件路径问题4、程序

IDEA自动生成注释模板的配置教程

《IDEA自动生成注释模板的配置教程》本文介绍了如何在IntelliJIDEA中配置类和方法的注释模板,包括自动生成项目名称、包名、日期和时间等内容,以及如何定制参数和返回值的注释格式,需要的朋友可以... 目录项目场景配置方法类注释模板定义类开头的注释步骤类注释效果方法注释模板定义方法开头的注释步骤方法注

Python如何自动生成环境依赖包requirements

《Python如何自动生成环境依赖包requirements》:本文主要介绍Python如何自动生成环境依赖包requirements问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑... 目录生成当前 python 环境 安装的所有依赖包1、命令2、常见问题只生成当前 项目 的所有依赖包1、

MySQL中动态生成SQL语句去掉所有字段的空格的操作方法

《MySQL中动态生成SQL语句去掉所有字段的空格的操作方法》在数据库管理过程中,我们常常会遇到需要对表中字段进行清洗和整理的情况,本文将详细介绍如何在MySQL中动态生成SQL语句来去掉所有字段的空... 目录在mysql中动态生成SQL语句去掉所有字段的空格准备工作原理分析动态生成SQL语句在MySQL

SpringBoot实现微信小程序支付功能

《SpringBoot实现微信小程序支付功能》小程序支付功能已成为众多应用的核心需求之一,本文主要介绍了SpringBoot实现微信小程序支付功能,文中通过示例代码介绍的非常详细,对大家的学习或者工作... 目录一、引言二、准备工作(一)微信支付商户平台配置(二)Spring Boot项目搭建(三)配置文件

Java利用docx4j+Freemarker生成word文档

《Java利用docx4j+Freemarker生成word文档》这篇文章主要为大家详细介绍了Java如何利用docx4j+Freemarker生成word文档,文中的示例代码讲解详细,感兴趣的小伙伴... 目录技术方案maven依赖创建模板文件实现代码技术方案Java 1.8 + docx4j + Fr

微信公众号脚本-获取热搜自动新建草稿并发布文章

《微信公众号脚本-获取热搜自动新建草稿并发布文章》本来想写一个自动化发布微信公众号的小绿书的脚本,但是微信公众号官网没有小绿书的接口,那就写一个获取热搜微信普通文章的脚本吧,:本文主要介绍微信公众... 目录介绍思路前期准备环境要求获取接口token获取热搜获取热搜数据下载热搜图片给图片加上标题文字上传图片