当前位置: 首页 > news >正文

保姆级教学 uniapp绘制二维码海报并保存至相册,真机正常展示图片二维码

一、获取二维码

      uni.request({url: `https://api.weixin.qq.com/wxa/getwxacode?access_token=${getStorage("token")}`,responseType: "arraybuffer",method: "POST",data: {path: "/pages/index/index"},success(res) {// 转换为 Uint8Array 类型的数组const arrayBuffer = new Uint8Array(res.data)// 转换为 Base64 编码的字符串const base64 = uni.arrayBufferToBase64(arrayBuffer)// 缓存至本地state.image = base64},fail(err) {console.log(err, "err")}})

代码仅作示例

以上代码作用就是,拿到后端给的base64格式的图片,用做绘图

二、绘制画布

    const handleCanvas = () => {//初始化画布const ctx = uni.createCanvasContext('myCanvas');ctx.setFillStyle("rgba(96, 216, 254, 1)")ctx.fillRect(0, 0, uni.upx2px(750), uni.upx2px(1120))//外边框const mx = uni.upx2px(55)const my = uni.upx2px(332);const mwidth = uni.upx2px(640);const mheight = uni.upx2px(640);const mradius = uni.upx2px(32);const mColor = "#DFF3FF"_border(ctx, mx, my, mwidth, mheight, mradius, mColor)// 内边框const px = uni.upx2px(105)const py = uni.upx2px(382);const pwidth = uni.upx2px(540);const pheight = uni.upx2px(540);const pradius = uni.upx2px(32);const pColor = "#FFF"_border(ctx, px, py, pwidth, pheight, pradius, pColor)//二维码  _QRCode(ctx, state.image)// 绘制画布ctx.draw()}// 绘制边框   参数分别为  画布对象 画布x轴起点 画布y轴起点 画布宽度 画布高度 圆角边框 背景色const _border = (ctx: CanvasRenderingContext2D, x: number, y: number, width: number, height: number, radius: number, color: string) => {ctx.beginPath();ctx.moveTo(x + radius, y);ctx.lineTo(x + width - radius, y);ctx.arcTo(x + width, y, x + width, y + radius, radius);ctx.lineTo(x + width, y + height - radius);ctx.arcTo(x + width, y + height, x + width - radius, y + height, radius);ctx.lineTo(x + radius, y + height);ctx.arcTo(x, y + height, x, y + height - radius, radius);ctx.lineTo(x, y + radius);ctx.arcTo(x, y, x + radius, y, radius);ctx.closePath();ctx.fillStyle = color;ctx.fill();}const _QRCode = (ctx, data) => {// 获取文件管理器const fsm = wx.getFileSystemManager();//  将 base64 字符串转成 ArrayBuffer对象const buffer = wx.base64ToArrayBuffer(data);// 文件系统中的用户目录路径 (本地路径)const fileName = wx.env.USER_DATA_PATH + '/share_img.png';fsm.writeFileSync(fileName, buffer, 'binary'); // 写入文件, 同步方法// 以上四行代码让其在真机上正常显示,因为canvas无法读取base64格式,需要先保存在文件管理器,拿到临时路径ctx.drawImage(fileName, uni.upx2px(135), uni.upx2px(412), uni.upx2px(480), uni.upx2px(480))}

1.复杂样式尽量使用图片引入 ctx.drawImage("换成你本地图片的相对路径",...)

2.需要其他样式或者图片,自行添加,我这个应该还有个背景图的,在等UI出图

3.画布绘制的顺序需要注意下,后面覆盖的图形会把前面的图形在视觉上覆盖掉,所以二维码方法要写在最后面

三、保存至相册

    const handleSave = () => {uni.showLoading({title: '正在生成海报',mask: true})uni.canvasToTempFilePath({canvasId: 'myCanvas',success: (res) => {uni.saveImageToPhotosAlbum({filePath: res.tempFilePath,success: (res) => {uni.showToast({title: '保存成功',icon: 'none'})}})},complete(result) {uni.hideLoading()},})}

http://www.lryc.cn/news/500162.html

相关文章:

  • 常用Vim操作
  • 【C#】NET 9中LINQ的新特性-CountBy
  • Trimble X9三维激光扫描仪高效应对化工厂复杂管道扫描测绘挑战【沪敖3D】
  • 【数据结构】文件和外部排序
  • 新手学习:网页前端、后端、服务器Tomcat和数据库的基本介绍
  • 机器学习贝叶斯模型原理
  • 【C++】实现100以内素数的求解
  • Python 浏览器自动化新利器:DrissionPage,让网页操作更简单!
  • Rust学习笔记_13——枚举
  • Postgresql 格式转换笔记整理
  • AI开发:卷积神经网络CNN原理初识,简易例程 - 机器学习
  • 详细介绍vue的递归组件(重要)
  • 【单片机基础知识】基础知识(CortexM系列、STM32系统框架、存储器映射、寄存器映射)
  • yolov5导出命令
  • RabbitMQ的常用术语介绍
  • Docker魔法:用docker run -p轻松开通容器服务大门
  • 【后端面试总结】Redis过期删除策略
  • 数字图像处理(15):图像平移
  • 高级java每日一道面试题-2024年12月08日-JVM篇-什么是类加载器?
  • JAVA子类的无参构造器中第一行的super
  • mysql程序介绍,选项介绍(常用选项,指定选项的方式,特性),命令介绍(查看,部分命令),从sql文件执行sql语句的两种方法
  • Unity教程(十九)战斗系统 受击反馈
  • lanqiaoOJ 3744:小蓝的智慧拼图购物 ← pair+优先队列
  • Spring Boot教程之二十一:文件处理
  • 【Linux】Linux的基本常识+指令
  • Rocky Linux 9.3系统搭建Slurm环境【笔记】
  • 原生微信小程序使用原子化tailwindcss
  • 《掌握Nmap:全面解析网络扫描与安全检测的终极指南》
  • k8s-Informer概要解析(2)
  • UE5基本数据类型