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

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

相关文章

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获取热搜获取热搜数据下载热搜图片给图片加上标题文字上传图片

Java编译生成多个.class文件的原理和作用

《Java编译生成多个.class文件的原理和作用》作为一名经验丰富的开发者,在Java项目中执行编译后,可能会发现一个.java源文件有时会产生多个.class文件,从技术实现层面详细剖析这一现象... 目录一、内部类机制与.class文件生成成员内部类(常规内部类)局部内部类(方法内部类)匿名内部类二、

使用Jackson进行JSON生成与解析的新手指南

《使用Jackson进行JSON生成与解析的新手指南》这篇文章主要为大家详细介绍了如何使用Jackson进行JSON生成与解析处理,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1. 核心依赖2. 基础用法2.1 对象转 jsON(序列化)2.2 JSON 转对象(反序列化)3.

java中使用POI生成Excel并导出过程

《java中使用POI生成Excel并导出过程》:本文主要介绍java中使用POI生成Excel并导出过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录需求说明及实现方式需求完成通用代码版本1版本2结果展示type参数为atype参数为b总结注:本文章中代码均为

在java中如何将inputStream对象转换为File对象(不生成本地文件)

《在java中如何将inputStream对象转换为File对象(不生成本地文件)》:本文主要介绍在java中如何将inputStream对象转换为File对象(不生成本地文件),具有很好的参考价... 目录需求说明问题解决总结需求说明在后端中通过POI生成Excel文件流,将输出流(outputStre

C/C++随机数生成的五种方法

《C/C++随机数生成的五种方法》C++作为一种古老的编程语言,其随机数生成的方法已经经历了多次的变革,早期的C++版本使用的是rand()函数和RAND_MAX常量,这种方法虽然简单,但并不总是提供... 目录C/C++ 随机数生成方法1. 使用 rand() 和 srand()2. 使用 <random

Flask 验证码自动生成的实现示例

《Flask验证码自动生成的实现示例》本文主要介绍了Flask验证码自动生成的实现示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习... 目录生成图片以及结果处理验证码蓝图html页面展示想必验证码大家都有所了解,但是可以自己定义图片验证码