注册登录

微信小程序制作海报并分享到朋友圈如何实现

2018-05-15|HiShop|阅读量:
导读:小程序制作海报可以通过一些小程序直接上传图片实现,这里小编为大家介绍如何通过小程序自己制作海报并分享到朋友圈呢?...

小程序制作海报可以通过一些小程序直接上传图片实现,这里小编为大家介绍如何通过小程序自己制作海报并分享到朋友圈呢?

微信小程序制作海报并分享到朋友圈如何实现


添加画布

首先,在小程序里进行绘图操作需要用到<canvas>组件,那我们就先在我们的wxml代码中放入如下的<canvas>:

<canvas canvas-id="shareCanvas" style="width:600px;height:900px"></canvas>

这样一来我们就有了一个600x900的绘图区域。然后,我们要开始写JS代码在这张画布上进行绘图操作。

步骤1:绘制背景图

通过观察《长城你造不造》合成的那张分享图,我们可以分析得出它的组成主要有以下3个部分:一张大的背景图,一段动态的文字(xxxx 喊你“一起来为修长城献砖”),以及一个小程序码图片。

那么我们就先找一张图片来当做背景图,将它画到画布上去,代码大致如下:

const wxGetImageInfo = promisify(wx.getImageInfo)

wxGetImageInfo({

    src: 'https://some-domain/bg.png'

}).then(res => {

    const ctx = wx.createCanvasContext('shareCanvas')

    ctx.drawImage(res.path, 0, 0, 600, 900)

    ctx.draw()

})

在这段代码中,我们通过使用wx.getImageInfo这个API来下载一个网络图片到本地(并可获取该图片的尺寸等其他信息),然后调用ctx.drawImage方法将图片绘制到画布上,填满画布。

步骤2:绘制文字

接着,让我们来在画布上继续绘制一段文字,一般这种宣传用的分享图,少不了文字描述,而且可能是根据场景内容不同而产生的动态信息,比如可能是一篇文章的作者、文章的标题和内容。

我们尝试下在画布上添加一段居中显示的文字:“作者:一斤代码”,还是基于前面的那段代码接着写:

const wxGetImageInfo = promisify(wx.getImageInfo)

wxGetImageInfo({

    src: 'https://some-domain/bg.png'

}).then(res => {

    const ctx = wx.createCanvasContext('shareCanvas')

    

    // 底图

    ctx.drawImage(res.path, 0, 0, 600, 900)

    // 作者名称

    ctx.setTextAlign('center')    // 文字居中

    ctx.setFillStyle('#000000')  // 文字颜色:黑色

    ctx.setFontSize(22)         // 文字字号:22px

    ctx.fillText(“作者:一斤代码”, 600 / 2, 500)

    

    ctx.stroke()

    ctx.draw()

})

由于在canvas上绘制文字不会自动折行,如果要画一段比较长的文本,可以考虑限制一行的字数,将长文本拆分成几行来画。

步骤3:绘制小程序码

最后,我们在画布最后添加一个小程序码,可以是静态的小程序码,也可以是比如为每一篇文章动态生成的小程序码(参考《微信小程序之生成自定义参数小程序二维码》这篇文章),反正这个小程序码也就是一张图片,所以绘制方法跟绘制底图差不多。最后的代码类似如此:

const wxGetImageInfo = promisify(wx.getImageInfo)

Promise.all([

    wxGetImageInfo({

        src: 'https://some-domain.com/background.png'

    }),

    wxGetImageInfo({

        src: 'https://some-domain.com/api/generate/qrcode'

    })

]).then(res => {

    const ctx = wx.createCanvasContext('shareCanvas')

    

    // 底图

    ctx.drawImage(res[0].path, 0, 0, 600, 900)

    // 作者名称

    ctx.setTextAlign('center')    // 文字居中

    ctx.setFillStyle('#000000')  // 文字颜色:黑色

    ctx.setFontSize(22)         // 文字字号:22px

    ctx.fillText(“作者:一斤代码”, 600 / 2, 500)

    // 小程序码

    const qrImgSize = 180

    ctx.drawImage(res[1].path, (600 - qrImgSize) / 2, 530, qrImgSize, qrImgSize)

    ctx.stroke()

    ctx.draw()

})

这样,差不多我们的分享图就生成好了。

保存到系统相册

接着,我们要把它保存进用户的系统相册中去,实现这个功能,我们主要靠wx.canvasToTempFilePath和wx.saveImageToPhotosAlbum这两个API。

主要的流程就是先通过wx.canvasToTempFilePath将<canvas>上绘制的图像生成临时文件的形式,然后再通过wx.saveImageToPhotosAlbum进行保存到系统相册的操作。

const wxCanvasToTempFilePath = promisify(wx.canvasToTempFilePath)

const wxSaveImageToPhotosAlbum = promisify(wx.saveImageToPhotosAlbum)

wxCanvasToTempFilePath({

    canvasId: 'shareCanvas'

}, this).then(res => {

    return wxSaveImageToPhotosAlbum({

        filePath: res.tempFilePath

    })

}).then(res => {

    wx.showToast({

        title: '已保存到相册'

    })

})

其中promise.util.js如下:

[javascript] view plain copy

/** 

 * 将wx的callback形式的API转换成支持Promise的形式 

 */  

module.exports = {  

  

  promisify: api => {  

    return (options, ...params) => {  

      return new Promise((resolve, reject) => {  

        const extras = {  

          success: resolve,  

          fail: reject  

        }  

        api({ ...options, ...extras }, ...params)  

      })  

    }  

  }  

  

文章来源:https://www.hishop.com.cn/xiaocx/show_53866.html

<海商(www.hishop.com.cn)是国内知名商城系统及商城网站建设提供商,其中销客多小程序系统为商家提供小程序商城开发、小程序分销系统、微分销系统、商城系统、电商网站建设、微信分销系统、小程序商城等多端商城及电子商务行业解决方案>

申明:本网站部分文章和图片来源网络编辑,如有侵权及时沟通删除。海商hishop网站原创文章,转载请注明来源。

微信小程序开发文档更多
[field:title/]

[field:body function="html2text(cn_substr(@me,450))"/]....

{/dede:arclist}
小程序产品推荐
  • 移动云商城小程序
    一款会赚钱的网上商城系统——移动云商城,让零售企业转型电商更简单!独创6合一全网营销模式、裂变式推广分佣快速吸粉引流,不论微信、APP、手机触屏还是PC端网上购物商城,只要1个后台即可掌控全网最火爆的6大商城!详情