微信小程序制作海报并分享到朋友圈如何实现
惠民小程序小编了解到,微信小程序成为当下热门话题,下面从多个方面来谈谈微信小程序制作海报并分享到朋友圈如何实现。 最新消息, 最新消息,有微信小程序开发者,开发提交的小程序总是审核不过,不知道出了什么问题,而以前同样的内容都能通过审核。 据开发者介绍,他们提交的小程序被打回的原因是:小程序服务提供的内容涉及商业推广,属个人未开放类目。 经网络媒体披露,微信小程序开发时,在查询个 小程序制作海报可以通过一些小程序直接上传图片实现,这里小编为大家介绍如何通过小程序自己制作海报并分享到朋友圈呢? 添加画布 首先,在小程序里进行绘图操作需要用到 这样一来我们就有了一个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,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,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,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将 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) }) } } } (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |