uniapp 小程序 多张图片生成海报以及下载海报

2024-04-25 13:04

本文主要是介绍uniapp 小程序 多张图片生成海报以及下载海报,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

uniapp 小程序 多张图片生成海报以及下载海报

  1. 上代码
export default {data() {return {unit: 0,imgurl:"", // 海报图片shareimg:"https://eshopfile.zhiyousx.com/2022051811164947691.jpg", //背景图qrcode :"", // 二维码saveTop:80,}},onLoad(option) {let that = thisuni.getSystemInfo({success: (res) => {that.unit = res.screenWidth/750}});},methods:{// 获取二维码getqrcodeImg(){this.$https('GET','xxxx/xxxx/xxxx',).then(res => {if(res.code === 1){// 有现成的可以不用掉接口this.qrcode = res.datathis.genQrFile()}})},genQrFile() {let unit = this.unituni.showLoading()this.saveTop = parseInt(80*unit)var urlQR = this.getNetworkImage(this.qrcode);//二维码。var bg=this.getNetworkImage(this.shareimg);//背景图片转为本地图片let that = this;Promise.all([bg,urlQR]).then(res => {// 创建 canvas 绘图上下文(指定 canvasId)let ctx = uni.createCanvasContext('firstCanvas', this);// 绘制图像到画布  /** * 参数1  所要绘制的图片资源 * 参数2  图像的左上角在目标canvas上 X 轴的位置* 参数3  图像的左上角在目标canvas上 Y 轴的位置* 参数4  在目标画布上绘制图像的宽度,允许对绘制的图像进行缩放* 参数5  在目标画布上绘制图像的高度,允许对绘制的图像进行缩放*/ctx.drawImage(res[0], 0, 0, parseInt(640*unit), parseInt(1140*unit));ctx.beginPath()// 你也可以插入文字// ctx.fillText('textAlign=right', 150, 100)let x = parseInt(117*unit),y= parseInt(483*unit),w=parseInt(220*unit),h=parseInt(225*unit)ctx.arc(w / 2 + x, w / 2 + y, h / 2, 0, Math.PI * 2, false)ctx.clip()// 绘制第二张图片图像到画布ctx.drawImage(res[1], x,y,w, h);ctx.restore()ctx.draw(false, () => {// 把当前画布指定区域的内容导出生成指定大小的图片,并返回文件路径uni.canvasToTempFilePath({x: 0,y: 0,width: 375,height: 840,destWidth: 640,destHeight: 1140,canvasId: 'firstCanvas',success: function(res) {// 保存文件路径that.imgurl = res.tempFilePathuni.hideLoading()},fail(e) {uni.hideLoading()}});});})},// 图片转为本地图片getNetworkImage(url) {return new Promise((resolve, reject) => {uni.downloadFile({url,success: (e) => {const p = e.tempFilePathif (p.indexOf('json') > -1) {reject(p)return false}resolve(p)},fail: (r) => {reject(r)}})})},}
}			     
  1. 下载海报
    我的上一篇博客有后半部分图片保存代码!

  2. 搞定! 日常开发代码记录。

这篇关于uniapp 小程序 多张图片生成海报以及下载海报的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Java实战之利用POI生成Excel图表

《Java实战之利用POI生成Excel图表》ApachePOI是Java生态中处理Office文档的核心工具,这篇文章主要为大家详细介绍了如何在Excel中创建折线图,柱状图,饼图等常见图表,需要的... 目录一、环境配置与依赖管理二、数据源准备与工作表构建三、图表生成核心步骤1. 折线图(Line Ch

Android开发中gradle下载缓慢的问题级解决方法

《Android开发中gradle下载缓慢的问题级解决方法》本文介绍了解决Android开发中Gradle下载缓慢问题的几种方法,本文给大家介绍的非常详细,感兴趣的朋友跟随小编一起看看吧... 目录一、网络环境优化二、Gradle版本与配置优化三、其他优化措施针对android开发中Gradle下载缓慢的问

python 3.8 的anaconda下载方法

《python3.8的anaconda下载方法》本文详细介绍了如何下载和安装带有Python3.8的Anaconda发行版,包括Anaconda简介、下载步骤、安装指南以及验证安装结果,此外,还介... 目录python3.8 版本的 Anaconda 下载与安装指南一、Anaconda 简介二、下载 An

如何使用CSS3实现波浪式图片墙

《如何使用CSS3实现波浪式图片墙》:本文主要介绍了如何使用CSS3的transform属性和动画技巧实现波浪式图片墙,通过设置图片的垂直偏移量,并使用动画使其周期性地改变位置,可以创建出动态且具有波浪效果的图片墙,同时,还强调了响应式设计的重要性,以确保图片墙在不同设备上都能良好显示,详细内容请阅读本文,希望能对你有所帮助...

Python脚本实现图片文件批量命名

《Python脚本实现图片文件批量命名》这篇文章主要为大家详细介绍了一个用python第三方库pillow写的批量处理图片命名的脚本,文中的示例代码讲解详细,感兴趣的小伙伴可以了解下... 目录前言源码批量处理图片尺寸脚本源码GUI界面源码打包成.exe可执行文件前言本文介绍一个用python第三方库pi

Python爬虫selenium验证之中文识别点选+图片验证码案例(最新推荐)

《Python爬虫selenium验证之中文识别点选+图片验证码案例(最新推荐)》本文介绍了如何使用Python和Selenium结合ddddocr库实现图片验证码的识别和点击功能,感兴趣的朋友一起看... 目录1.获取图片2.目标识别3.背景坐标识别3.1 ddddocr3.2 打码平台4.坐标点击5.图

将java程序打包成可执行文件的实现方式

《将java程序打包成可执行文件的实现方式》本文介绍了将Java程序打包成可执行文件的三种方法:手动打包(将编译后的代码及JRE运行环境一起打包),使用第三方打包工具(如Launch4j)和JDK自带... 目录1.问题提出2.如何将Java程序打包成可执行文件2.1将编译后的代码及jre运行环境一起打包2

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

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

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

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

Java下载文件中文文件名乱码的解决方案(文件名包含很多%)

《Java下载文件中文文件名乱码的解决方案(文件名包含很多%)》Java下载文件时,文件名中文乱码问题通常是由于编码不正确导致的,使用`URLEncoder.encode(filepath,UTF-8... 目录Java下载文件中文文件名乱码问题一般情况下,大家都是这样为了解决这个问题最终解决总结Java下