微信小程序实现分享到朋友圈功能


Posted in Javascript onJuly 19, 2018

截止到2017年11月18号,微信小程序官方还尚未开放直接分享到朋友圈的能力,但是劳动人民的智慧是伟大的,现在普遍的做法是,生成一张带有小程序码的图片,保存到用户相册,用户自行发布图片到朋友圈

我的套路:

  1. 请求后端API生成小程序码(生成小程序码需要access token,后端生成比较方便)
  2. canvas绘制文字和图片到画布
  3. 当用户点击分享到朋友圈时,给用户展示画布,画布转成图片,并将图片保存到相册
onShow: function () {
 var that = this;
 //1. 请求后端API生成小程序码
 that.getQr();

 //2. canvas绘制文字和图片
 const ctx = wx.createCanvasContext('myCanvas');
 var imgPath = '../../../image/intro.png'
 var bgImgPath = '../../../image/bgImgPath.png';
 ctx.drawImage(imgPath, 0, 0, 600, 520);

 ctx.setFillStyle('white')
 ctx.fillRect(0, 520, 600, 280);

 ctx.drawImage(imgPath, 30, 550, 60, 60);
 ctx.drawImage(bgImgPath, 30, 550, 60, 60);
 ctx.drawImage(imgPath, 410, 610, 160, 160);

 ctx.setFontSize(28)
 ctx.setFillStyle('#6F6F6F')
 ctx.fillText('妖妖灵', 110, 590)

 ctx.setFontSize(30)
 ctx.setFillStyle('#111111')
 ctx.fillText('宠友们快来围观萌宠靓照', 30, 660)
 ctx.fillText('我在萌爪幼稚园', 30, 700)

 ctx.setFontSize(24)
 ctx.fillText('长按扫码查看详情', 30, 770)
 ctx.draw()
 },
 // 3. canvas画布转成图片
 wx.canvasToTempFilePath({
 x: 0,
 y: 0,
 width: 600,
 height: 800,
 destWidth: 600,
 destHeight:800,
 canvasId: 'myCanvas',
 success: function(res) {
 console.log(res.tempFilePath);
 that.setData({
  shareImgSrc : res.tempFilePath
 })

 },
 fail:function (res) {
 console.log(res)
 }
 })
 //4. 当用户点击分享到朋友圈时,将图片保存到相册
 wx.saveImageToPhotosAlbum({
 filePath:that.data.shareImgSrc,
 success(res) {
 wx.showModal({
  title: '存图成功',
  content: '图片成功保存到相册了,去发圈噻~',
  showCancel:false,
  confirmText:'好哒',
  confirmColor:'#72B9C3',
  success: function(res) {
  if (res.confirm) {
  console.log('用户点击确定');
  }
  that.hideShareImg()
  }
 })
 }
})

canvas绘制单位为px,举个例子,屏幕宽375,绘制375的画布,保存的图片就是375px,图片像素度不够会糊掉,所以我改进了一下套路:

1.请求后端API生成小程序码(生成小程序码需要access token,后端生成比较方便)

2.canvas绘制文字和图片到画布
绘制2倍屏幕宽度的canvas画布,canvas画布必须是可见状态下,才可以被转成图片,可是他辣么大辣么丑肯定不能给用户看见,那就给他定位定个巨大的数字超出屏幕就好了

3.画布转成图片

4.当用户点击分享到朋友圈时,给用户展示图片,并将图片保存到相册

微信小程序实现分享到朋友圈功能

为大家推荐现在关注度比较高的微信小程序教程一篇:《微信小程序开发教程》小编为大家精心整理的,希望喜欢。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
jQuery建立一个按字母顺序排列的友好页面索引(兼容IE6/7/8)
Feb 26 Javascript
Javascript学习笔记之 对象篇(三) : hasOwnProperty
Jun 24 Javascript
jQuery插件实现控制网页元素动态居中显示
Mar 24 Javascript
js+html5实现canvas绘制圆形图案的方法
Jun 05 Javascript
jQuery实现自动切换播放的经典滑动门效果
Sep 12 Javascript
用JS写的一个Ajax库(实例代码)
Aug 06 Javascript
完美解决jQuery fancybox ie 无法显示关闭按钮的问题
Nov 29 Javascript
微信小程序教程系列之新建页面(4)
Apr 17 Javascript
vue利用better-scroll实现轮播图与页面滚动详解
Oct 20 Javascript
微信小程序实现流程进度的图样式功能
Jan 16 Javascript
vue.js+elementUI实现点击左右箭头切换头像功能(类似轮播图效果)
Sep 05 Javascript
vue实现一个矩形标记区域(rectangle marker)的方法
Oct 28 Javascript
微信小程序实现自定义加载图标功能
Jul 19 #Javascript
Angular5集成eventbus的示例代码
Jul 19 #Javascript
微信小程序实现弹出菜单
Jul 19 #Javascript
微信小程序实现之手势锁功能实例代码
Jul 19 #Javascript
React组件重构之嵌套+继承及高阶组件详解
Jul 19 #Javascript
微信小程序实现折叠展开效果
Jul 19 #Javascript
详解Angularjs 自定义指令中的数据绑定
Jul 19 #Javascript
You might like
浅谈PHP进程管理
2019/03/08 PHP
图片上传判断及预览脚本的效果实例
2013/08/07 Javascript
JavaScript异步编程:异步数据收集的具体方法
2013/08/19 Javascript
jquery form 隐藏的input 选择
2014/04/29 Javascript
[原创]推荐10款最热门jQuery UI框架
2014/08/19 Javascript
node.js [superAgent] 请求使用示例
2015/03/13 Javascript
基于jquery实现复选框全选,反选,全不选等功能
2015/10/16 Javascript
Javascript设计模式理论与编程实战之简单工厂模式
2015/11/03 Javascript
基于JS实现的随机数字抽签实例
2016/12/08 Javascript
微信小程序左右滑动切换页面详解及实例代码
2017/02/28 Javascript
基于Bootstrap的标签页组件及bootstrap-tab使用说明
2017/07/25 Javascript
JavaScript+CSS相册特效实例代码
2017/09/07 Javascript
Vue中computed与methods的区别详解
2018/03/24 Javascript
js代码实现轮播图
2020/05/04 Javascript
python定时器使用示例分享
2014/02/16 Python
Python函数式编程指南(二):从函数开始
2015/06/24 Python
python利用Guetzli批量压缩图片
2017/03/23 Python
对python3 urllib包与http包的使用详解
2018/05/10 Python
Python实现将字符串的首字母变为大写,其余都变为小写的方法
2019/06/11 Python
Python调用百度根据经纬度查询地址的示例代码
2019/07/07 Python
Django框架model模型对象验证实现方法分析
2019/10/02 Python
Django实现文件上传下载功能
2019/10/06 Python
python多继承(钻石继承)问题和解决方法简单示例
2019/10/21 Python
python与mysql数据库交互的实现
2020/01/06 Python
python连接mongodb集群方法详解
2020/02/13 Python
python 串行执行和并行执行实例
2020/04/30 Python
DataFrame 数据合并实现(merge,join,concat)
2020/06/14 Python
Canvas环形饼图与手势控制的实现代码
2019/11/08 HTML / CSS
System.Array.CopyTo()和System.Array.Clone()有什么区别
2016/06/20 面试题
灵泰克Java笔试题
2016/01/09 面试题
2014年小班元旦活动方案
2014/02/16 职场文书
工程学毕业生自荐信
2014/06/14 职场文书
2014年污水处理厂工作总结
2014/12/19 职场文书
2015年班级工作总结范文
2015/04/03 职场文书
车间主任岗位职责范本
2015/04/08 职场文书
python 自动化偷懒的四个实用操作
2021/04/11 Python