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


本篇内容介绍了“微信小程序制作海报并分享到朋友圈怎么实现”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!
添加画布
首先,在小程序里进行绘图操作需要用到组件,那我们就先在我们的wxml代码中放入如下的

这样一来我们就有了一个600×900的绘图区域。然后,我们要开始写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将上绘制的图像生成临时文件的形式,然后再通过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)
})
}
}“微信小程序制作海报并分享到朋友圈怎么实现”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注百云主机网站,小编将为大家输免费云主机域名出更多高质量的实用文章!

相关推荐: C++的数据共享与保护实例分析

这篇文章主要讲解了“C++的数据共享与保护实例分析”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“C++的数据共享与保护实例分析”吧!作用域是一个标识符在程序正文中有效的区域作用域关系从大到小为:命名空间作用域 …

免责声明:本站发布的图片视频文字,以转载和分享为主,文章观点不代表本站立场,本站不承担相关法律责任;如果涉及侵权请联系邮箱:360163164@qq.com举报,并提供相关证据,经查实将立刻删除涉嫌侵权内容。

Like (0)
Donate 微信扫一扫 微信扫一扫
Previous 01/23 15:49
Next 01/23 15:50

相关推荐