微信小程序中生成图片的代码
本篇文章给大家带来的内容是关于微信小程序中生成图片的代码,有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。添加画布首先,在小程序里进行绘图操作需要用到<canvas>组件,步骤大致分为以下3个部分:一张大的背景图,一段动态的文字(‘标题 用户名 及其他信息’),以及一个小程序码图片。那我们就先在我们的wxml代码中放入如下的<canvas>:<!--wxml代码--><view style='width:100%;height:100%;' bindlongpress='saveInviteCard'><canvas canvas-id="shareCanvas" style="width:{{windowWidth}}px;height:{{windowHeight}}px" ></canvas></view> 第三方函数引入const util = require('../../utils/util.js')//util.jsvar Promise = require('../components/bluebird.min.js')module.exports = {promisify: api => {return (options, ...params) => {return new Promise((resolve, reject) => {const extras = {success: resolve,fail: reject}api({ ...options, ...extras }, ...params)})}}}bluebird.min.js大家可自己百度下载,源文件代码太长,我这里就不复制粘贴了。//获取手机宽高 wx.getSystemInfo({success: function (res) {wc.put('phoneInfo', res)}});var windowHeight = phoneInfo.windowHeight, windowWidth = phoneInfo.windowWidthself.setData({windowHeight: windowHeight,windowWidth: windowWidth })//在这段代码中,我们通过使用wx.getImageInfo这个API来下载一个网络图片到本地(并可获取该图片的尺寸等其他信息),然后调用ctx.drawImage方法将图片绘制到画布上,填满画布。const wxGetImageInfo = util.promisify(wx.getImageInfo)//绘制二维码Promise.all([//背景图wxGetImageInfo({src: 'https://timgsa.baidu.com/timg?image&quality=80&size=b9999_10000&sec=1536213812443&di=753a0a49acfd390fba9fd7884daafa5c&imgtype=0&src=http%3A%2F%2Fi5.hexunimg.cn%2F2016-08-10%2F185422031.jpg'}),//二维码wxGetImageInfo({src: 'https://ss0.bdstatic.com/70cFuHSh_Q1YnxGkpoWK1HF6hhy/it/u=1898297765,3486952215&fm=26&gp=0.jpg'})]).then(res => {console.log(res)if (res[0].errMsg == "getImageInfo:ok" && res[1].errMsg == "getImageInfo:ok"){const ctx = wx.createCanvasContext('shareCanvas')// 底图ctx.drawImage(res[0].path, 0, 0, windowWidth, windowHeight)//写入文字ctx.setTextAlign('center')// 文字居中ctx.setFillStyle('#f3a721')// 文字颜色:黑色ctx.setFontSize(22)// 文字字号:22pxctx.fillText("作者:X淵"—Eric", windowWidth / 2, windowHeight / 2)// 小程序码const qrImgSize = 150ctx.drawImage(res[1].path, (windowWidth - qrImgSize) / 2, windowHeight / 1.8, qrImgSize, qrImgSize)ctx.stroke()ctx.draw()}else{wx.showToast({title: '邀请卡绘制失败!',image:'../../asset/images/warning.png'})} })这样,差不多我们的分享图就生成好了。长按图片保存到系统相册要把它保存进用户的系统相册中去,实现这个功能,我们主要靠wx.canvasToTempFilePath和wx.saveImageToPhotosAlbum这两个API。
主要的流程就是先通过wx.canvasToTempFilePath将<canvas>上绘制的图像生成临时文件的形式,然后再通过wx.saveImageToPhotosAlbum进行保存到系统相册的操作。//保存邀请卡saveInviteCard:function(){console.log('保存图片')const wxCanvasToTempFilePath = util.promisify(wx.canvasToTempFilePath)const wxSaveImageToPhotosAlbum = util.promisify(wx.saveImageToPhotosAlbum)wxCanvasToTempFilePath({canvasId: 'shareCanvas'}, this).then(res => {return wxSaveImageToPhotosAlbum({filePath: res.tempFilePath})}).then(res => {wx.showToast({title: '已保存到相册'})})}相关推荐:
微信小程序 二维码canvas绘制实例详解
微信小程序canvas基础详解以上就是微信小程序中生成图片的代码的详细内容,更多请关注小潘博客其它相关文章!