位置: IT常识 - 正文

uniapp 实现生成海报并分享给微信好友和保存到本地相册(uniapp生成h5)

编辑:rootadmin
uniapp 实现生成海报并分享给微信好友和保存到本地相册 记录uniapp 生成二维码海报并保存到本地或者分享给微信好友

推荐整理分享uniapp 实现生成海报并分享给微信好友和保存到本地相册(uniapp生成h5),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:uniapp怎么创建项目,uniapp实现生成海报背景图切换代码,uniapp生成微信小程序,uniapp生成apk,uniapp代码生成器,uniapp代码生成,uniapp代码生成,uniapp代码生成,内容如对您有帮助,希望把文章链接给更多的朋友!

文章目录记录uniapp 生成二维码海报并保存到本地或者分享给微信好友前言一、引入生成二维码的组件二、点击右侧的分享图标生成海报三:将canvas 图片转化成图片(最关键)四:保存图片或者发送好友最后前言

最近又遇到一个需求:用户需要将小程序生成的二维码海报分享给微信好友或者保存到本地,最后实现的效果如下:

一、引入生成二维码的组件uniapp 实现生成海报并分享给微信好友和保存到本地相册(uniapp生成h5)

这种网上随便找一下就有了,楼主采用的是tki-qrcode 生成二维码组件,具体的链接如下: 链接: https://blog.csdn.net/qq_45829293/article/details/123169952

二、点击右侧的分享图标生成海报

因为考虑到到时候生成的海报要分享,所以考虑用canvas的方式去绘制海报,当然你也可以试着用传统的 写法去生成,这边楼主没有去尝试过,所以这个方法也就不说了,只说canvas 的方式

核心生成代码如下(示例):

//初始化画布async __init() {uni.showLoading({title: '加载中...',mask: true})this.ctx = uni.createCanvasContext('my-canvas', this)this.canvasW = uni.upx2px(500);this.canvasH = uni.upx2px(750);//设置画布背景透明this.ctx.setFillStyle('rgba(255, 255, 255, 0)')//设置画布大小this.ctx.fillRect(0, 0, this.canvasW, this.canvasH)//绘制圆角背景this.drawRoundRect(this.ctx, 0, 0, this.canvasW, this.canvasH, uni.upx2px(18), '#FFFFFF')//小程序码// let qrcodeImg = await this.getImageInfo(this.qrcode)// this.ctx.drawImage(qrcodeImg.path,198,(((this.canvasW-hW) / 2) + hH + 135), 92, 92)//获取二维码的图片let headerImg = await this.getImageInfo(this.src)let hW = uni.upx2px(500);let hW1 = uni.upx2px(300);let hH = uni.upx2px(300);//绘制标题图 this.drawRoundImg(this.ctx, headerImg.path, uni.upx2px(100), hH / 4, hW1, hH, 8)//绘制提示this.ctx.setFontSize(14);this.ctx.textAlign = 'center' //文字居中 设置文字居中但是fillText的第二个参数必须为画布宽度一半this.ctx.setFillStyle('#A4A4A4');let sWidth = this.ctx.measureText(this.subTitle).widththis.ctx.fillText(this.subTitle, this.canvasW / 2, (((this.canvasW - hW) / 2) + hH + 70))this.ctx.setFontSize(12);this.ctx.fillText(this.subTitle1, this.canvasW / 2, (((this.canvasW - hW) / 2) + hH + 90))//绘制虚线this.drawDashLine(this.ctx, 10, (((this.canvasW - hW) / 2) + hH + 120), (this.canvasW - 10), (((this.canvasW - hW) / 2) + hH + 120), 5)//左边实心圆this.drawEmptyRound(this.ctx, 0, (((this.canvasW - hW) / 2) + hH + 120), 10)//右边实心圆this.drawEmptyRound(this.ctx, this.canvasW, (((this.canvasW - hW) / 2) + hH + 120), 10)//提示文案this.ctx.setFontSize(12);this.ctx.setFillStyle('#858585');//底部广告let BottomAdImg = await this.getImageInfo(this.abImg)// 判断一下手机系统的宽高uni.getSystemInfo({success: (res) => {if (res.windowHeight <= 568) {this.ctx.drawImage(BottomAdImg.path, uni.upx2px(20), (((this.canvasW - hW) /2) + hH + 140), uni.upx2px(460), (this.canvasH - hH) / 4)} else {this.ctx.drawImage(BottomAdImg.path, uni.upx2px(20), (((this.canvasW - hW) /2) + hH + 140), uni.upx2px(460), (this.canvasH - hH) / 3)}}});三:将canvas 图片转化成图片(最关键)

这一步是最关键的,只有这一步完成了,才能够实现分享给用户或者保存下来

代码如下:

this.ctx.draw(true, () => {// 将canvas 变成图片方便发送给好友或者保存var that = thisuni.canvasToTempFilePath({canvasId: 'my-canvas',fileType: 'jpg',x: 0,y: 0,complete: (res) => {this.canvasImg = res.tempFilePath}}, this);})四:保存图片或者发送好友

这里采用了微信原生的方式,在img 标签上加上 show-menu-by-longpress=true 就可以了。

最后如需项目demo,请联系我:1015095073@qq.com
本文链接地址:https://www.jiuchutong.com/zhishi/284090.html 转载请保留说明!

上一篇:ehSched.exe是什么进程 ehSched进程查询(ecap.exe是什么意思)

下一篇:【vue2可视化开发】新手会遇到的问题——大屏自适应(vue可视化面板怎么打开)

  • 增值税销项税额公式
  • 出口退税新政策报关费发票要怎么开
  • 法定免税项目包括
  • 如何查询继续教育证书
  • 自产用于捐赠的会计处理
  • 固定资产造成的损失可以税前扣除吗
  • 小规模纳税人如何开电子发票
  • 罚款收入需要开票吗
  • 主营业务收入借增贷减
  • 多计提的费用如何做分录
  • 个人取得的咨询费是什么
  • 出口免税什么意思
  • 个税返还奖励财务人员申报个税
  • 营改增后房地产企业增值税税率
  • 查验发票真伪新旧有哪些网站?
  • 回迁房怎么交税
  • 白酒消费税税率多少钱一吨
  • 旅游业要怎么进行差额征税处理
  • 个人证券交易结算资金
  • 进料加工分配率是什么意思
  • 电脑维修中常用的软件
  • 不开票收入申报是含税收入吗
  • 汽车过户费包括
  • 惠普2600打印机故障排除
  • 计提下个月工资怎么做
  • ppap是什么意思中文
  • 命令行基础
  • 免税的农业企业可以抵扣专票吗
  • php数组排序方法
  • vue环境搭建及配置简书
  • tsconfig baseurl
  • 用php编写一个简单的计算器程序
  • python输入三个数输出最小的
  • 支付兼职工资账务处理
  • 民间非盈利组织会计要素组成
  • 法人和自然人有什么区别通俗一点
  • 本月确认收入 发票下月开
  • 赠品怎么做
  • 企业赠送客户礼品涉税
  • 投资公司投资收益要交增值税吗
  • ubuntu20.04vim
  • mysql命令列界面
  • mysql的my.ini配置
  • 存货周转率是指企业某一会计
  • 申请名称预先核准在哪个网站
  • 汇算清缴时资产折旧怎么填
  • 固定资产变动方式名称
  • 工程项目劳务分包招投标要多久
  • 报表的应付账款怎么算
  • 试生产期间的收入如何做账
  • 借资本公积贷递延所得税负债是什么意思
  • 货运代理服务开票
  • 清算后剩余财产股东拒收怎么办
  • 未分配利润如何计算
  • 商业企业可将商品分为哪三类
  • 违反会计规定承担责任
  • sqlserver 优化配置
  • win7 组织
  • 如何做电脑系统备份
  • 惠普hp笔记本电脑
  • 安装macos10.15.7
  • y400加装固态硬盘教程
  • linux批量清空文件内容
  • linux管理员权限命令
  • win10 directx9
  • windows1020h2更新失败
  • win10激活过期有什么影响吗
  • opengl画矩形函数
  • js对象属性值
  • 安卓骰子游戏
  • 浏览器firefox
  • 文章标题作用答题模板
  • js生成随机数函数
  • python数据清洗的方法有哪些
  • Developing for Android, IV: The Rules: Networking
  • 西安市国家税务局稽查局
  • 江西省税务局官网查询系统
  • 个税申报网上操作步骤
  • 财务报表怎么填写
  • 税收与税收管理的关系
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设