我们在微信小程序中经常会使用到分享商品海报,或者是重绘微信小程序分享链的图片功能。实现该功能只要跟着如下几个步骤就可以快速实现啦!(本文示例代码使用的是uni-app,原生或者其他框架需要将uni前缀该成对应框架前缀即可;)
步骤描述不清晰或者不想看步骤?那就直接访问完整代码地址吧
完整代码演示:微信小程序 - 分享商品海报
相关文档:
uni-app官方文档
微信小程序官方文档
第一步:提前将需要分享的图片素材先缓存至本地临时图片路径;
initPic(){ this.handleNetImg('网络图片地址').then((res)=>{ this.bgdSrc =res.path;//保存这个临时图片路径 } } //生成临时图片 handleNetImg(imagePath) { return new Promise((resolve, reject) => { uni.getImageInfo({ src: imagePath, success: function (res) { resolve(res); } }); }); },
第二步:加入分享按钮以及Canvas元素;
<button open-type="share">点击分享</button> <button @click="getPhotosAlbumAuth">保存本地</button> <view class="canvas-box"> <canvas canvas-id='mycanvas'></canvas> </view>
第三步:初始Canvas,将内容画到Canvas上,画完后将画布生成临时图片;
createShareGoods(){ uni.showLoading({ title:'正在生成中...' }) var ctx = uni.createCanvasContext('mycanvas', this); ctx.drawImage(this.bgdSrc, 0, 0, 300, 240); //画背景图 ctx.drawImage(this.itemPic, 0, 0, 400, 400, 30, 45, 140, 140);//画商品图片 ctx.drawImage(this.qrcode, 0, 0, 400, 400, 225, 5, 100, 100);//画二维码,这边可以变成小程序码 //现价 ctx.setFillStyle('#E80013'); ctx.setFontSize(18); ctx.fillText('这边可以写一些说明之类的', 180, 100); ctx.setFillStyle('#E80013'); ctx.setFontSize(18); ctx.fillText('这边可以写一些说明之类的', 100, 100); //开始画画完后生成新的临时图片地址 ctx.draw(false, () => { setTimeout(()=>{ uni.canvasToTempFilePath({ canvasId: 'mycanvas', success: (res) => { uni.hideLoading(); this.picTempUrl=res.tempFilePath; } }); }, 300); }) },
第四步:点击分享按钮,完成分享;
/** * 分享页面到微信好友 */ onShareAppMessage(){ return { title: '限时特卖:'+this.name, path: 'pages/index/index"htmlcode">//获取手机相册权限 getPhotosAlbumAuth(){ uni.getSetting({ success:(res)=> { if (!res.authSetting['scope.writePhotosAlbum']) { uni.authorize({ scope: 'scope.writePhotosAlbum', success:()=> { this.saveImage(); } }) } else { this.saveImage(); } } }) }, //保存海报 saveImage(){ uni.saveImageToPhotosAlbum({ filePath: this.picTempUrl, success: (data)=> { uni.showToast({ title: "图片保存成功", icon: "success", mask: true }) }, complete: () => { this.posterStatus=false; } }) },为大家推荐现在关注度比较高的微信小程序教程一篇:《微信小程序开发教程》小编为大家精心整理的,希望喜欢。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
《魔兽世界》大逃杀!60人新游玩模式《强袭风暴》3月21日上线
暴雪近日发布了《魔兽世界》10.2.6 更新内容,新游玩模式《强袭风暴》即将于3月21 日在亚服上线,届时玩家将前往阿拉希高地展开一场 60 人大逃杀对战。
艾泽拉斯的冒险者已经征服了艾泽拉斯的大地及遥远的彼岸。他们在对抗世界上最致命的敌人时展现出过人的手腕,并且成功阻止终结宇宙等级的威胁。当他们在为即将于《魔兽世界》资料片《地心之战》中来袭的萨拉塔斯势力做战斗准备时,他们还需要在熟悉的阿拉希高地面对一个全新的敌人──那就是彼此。在《巨龙崛起》10.2.6 更新的《强袭风暴》中,玩家将会进入一个全新的海盗主题大逃杀式限时活动,其中包含极高的风险和史诗级的奖励。
《强袭风暴》不是普通的战场,作为一个独立于主游戏之外的活动,玩家可以用大逃杀的风格来体验《魔兽世界》,不分职业、不分装备(除了你在赛局中捡到的),光是技巧和战略的强弱之分就能决定出谁才是能坚持到最后的赢家。本次活动将会开放单人和双人模式,玩家在加入海盗主题的预赛大厅区域前,可以从强袭风暴角色画面新增好友。游玩游戏将可以累计名望轨迹,《巨龙崛起》和《魔兽世界:巫妖王之怒 经典版》的玩家都可以获得奖励。
更新日志
- 中国武警男声合唱团《辉煌之声1天路》[DTS-WAV分轨]
- 紫薇《旧曲新韵》[320K/MP3][175.29MB]
- 紫薇《旧曲新韵》[FLAC/分轨][550.18MB]
- 周深《反深代词》[先听版][320K/MP3][72.71MB]
- 李佳薇.2024-会发光的【黑籁音乐】【FLAC分轨】
- 后弦.2012-很有爱【天浩盛世】【WAV+CUE】
- 林俊吉.2012-将你惜命命【美华】【WAV+CUE】
- 晓雅《分享》DTS-WAV
- 黑鸭子2008-飞歌[首版][WAV+CUE]
- 黄乙玲1989-水泼落地难收回[日本天龙版][WAV+CUE]
- 周深《反深代词》[先听版][FLAC/分轨][310.97MB]
- 姜育恒1984《什么时候·串起又散落》台湾复刻版[WAV+CUE][1G]
- 那英《如今》引进版[WAV+CUE][1G]
- 蔡幸娟.1991-真的让我爱你吗【飞碟】【WAV+CUE】
- 群星.2024-好团圆电视剧原声带【TME】【FLAC分轨】