微信小程序--經過canvas生成圖片並保存到本地

前言

需求場景:咱們知道,微信小程序能夠分享給好友或者微信羣,不能分享到朋友圈,那分享到朋友圈就須要特殊處理一下,這裏咱們把小程序和canvas結合起來使用,生成自定義圖片並保存到本地。html

代碼

  • wxml文件
<view>
    <button type="default" size="defaultSize" bindtap="exportImg">生成圖片</button>
</view>
<canvas canvas-id="myCanvas"></canvas>
複製代碼複製代碼
  • js文件

經過canvasAPI繪製canvas

const ctx = wx.createCanvasContext('myCanvas');
//繪製背景圖
ctx.drawImage(res.path, 0, 0, screenWidth, 500);
//繪製背景圖上層的頭像
ctx.save();
ctx.arc(100, 100, 30, 0, 2 * Math.PI);
ctx.clip();
ctx.drawImage(avatarUrl, 50, 50, 110, 110);//根據微信getUserInfo接口獲取到用戶頭像
ctx.restore();
//繪製文字
ctx.setTextAlign('center')
ctx.setFillStyle('#fff')
ctx.setFontSize(16)
ctx.fillText(userInfo.nickName, 100, 180)//用戶暱稱
ctx.stroke()
ctx.draw()
複製代碼複製代碼

經過wx.canvasToTempFilePath獲取本地路徑小程序

wx.canvasToTempFilePath({
    x: 0,
    y: 0,
    width: 300,
    height: 500,
    canvasId: 'myCanvas',
    success: function (res) {
        console.log(res.tempFilePath);
    }
})
複製代碼複製代碼

經過wx.saveImageToPhotosAlbum保存圖片到本地微信小程序

wx.saveImageToPhotosAlbum({
    filePath: tempFilePath,//canvasToTempFilePath返回的tempFilePath
    success: (res) => {
        console.log(res)
    },
    fail: (err) => {}
})
複製代碼複製代碼

簡單的效果圖

總結

  1. canvasdrawImage方法只支持本地圖片,不支持網絡圖片,因此頭像和背景圖我都用getImageInfo這個方法轉了一下。
  2. 經過userInfo獲取的頭像是正方形的,不是需求中的圓形,這裏用到了clip()方法,須要配合save()restore(),由於裁剪以後若是不恢復,接下來的繪製都會在那個小區域裏面。
  3. 這次demo沒有使用生成二維碼的api,有興趣的朋友們能夠搞一下。此處是連接

參考文檔

微信小程序之生成圖片分享api

canvas實現圓框圖片bash

微信小程序官方文檔微信

轉自微信小程序--經過canvas生成圖片並保存到本地

相關文章
相關標籤/搜索