欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

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

程序员文章站 2023-10-29 23:00:22
截止到2017年11月18号,微信小程序官方还尚未开放直接分享到朋友圈的能力,但是劳动人民的智慧是伟大的,现在普遍的做法是,生成一张带有小程序码的图片,保存到用户相册,用户...

截止到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.当用户点击分享到朋友圈时,给用户展示图片,并将图片保存到相册

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

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