> 위챗 애플릿 > 미니 프로그램 개발 > WeChat 미니 프로그램에서 이미지를 생성하는 코드

WeChat 미니 프로그램에서 이미지를 생성하는 코드

不言
풀어 주다: 2018-09-08 17:32:32
원래의
5257명이 탐색했습니다.

이 글의 내용은 WeChat 애플릿에서 이미지를 생성하는 코드에 관한 것입니다. 이는 특정 참고 가치가 있으므로 도움이 필요한 친구에게 도움이 되기를 바랍니다.

캔버스 추가

먼저 미니 프로그램에서 그리기 작업을 수행하려면 <canvas> 구성 요소를 사용해야 합니다. 단계는 대략 다음 세 부분으로 나뉩니다: 큰 배경 이미지, 동적 텍스트('제목 사용자 이름 및 기타 정보') 및 작은 프로그램 코드 그림. 그런 다음 먼저 wxml 코드에 다음 <canvas>을 넣습니다.

<!--wxml代码-->
<view style=&#39;width:100%;height:100%;&#39; bindlongpress=&#39;saveInviteCard&#39;>
  <canvas canvas-id="shareCanvas" style="width:{{windowWidth}}px;height:{{windowHeight}}px" ></canvas>
</view>
로그인 후 복사

타사 기능 소개

const util = require(&#39;../../utils/util.js&#39;)
로그인 후 복사
//util.js
var Promise = require(&#39;../components/bluebird.min.js&#39;)

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(&#39;phoneInfo&#39;, res)
    }
  });

var windowHeight = phoneInfo.windowHeight, windowWidth = phoneInfo.windowWidth
self.setData({
   windowHeight: windowHeight,
   windowWidth: windowWidth
 })

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

const wxGetImageInfo = util.promisify(wx.getImageInfo)
//绘制二维码
Promise.all([
      //背景图
      wxGetImageInfo({
        src: &#39;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&#39;
      }),
      //二维码
      wxGetImageInfo({
        src: &#39;https://ss0.bdstatic.com/70cFuHSh_Q1YnxGkpoWK1HF6hhy/it/u=1898297765,3486952215&fm=26&gp=0.jpg&#39;
      })
    ]).then(res => {
      console.log(res)
      if (res[0].errMsg == "getImageInfo:ok" && res[1].errMsg == "getImageInfo:ok"){
        const ctx = wx.createCanvasContext(&#39;shareCanvas&#39;)

        // 底图
        ctx.drawImage(res[0].path, 0, 0, windowWidth, windowHeight)

        //写入文字
        ctx.setTextAlign(&#39;center&#39;)    // 文字居中
        ctx.setFillStyle(&#39;#f3a721&#39;)  // 文字颜色:黑色
        ctx.setFontSize(22)         // 文字字号:22px
        ctx.fillText("作者:墜夢—Eric", windowWidth / 2, windowHeight / 2)

        // 小程序码
        const qrImgSize = 150
        ctx.drawImage(res[1].path, (windowWidth - qrImgSize) / 2, windowHeight / 1.8, qrImgSize, qrImgSize)

        ctx.stroke()
        ctx.draw()
      }else{
        wx.showToast({
          title: &#39;邀请卡绘制失败!&#39;,
          image:&#39;../../asset/images/warning.png&#39;
        })
      }
 })
로그인 후 복사

이렇게 해서 우리의 공유 사진이 거의 만들어졌습니다.

사진을 길게 눌러 시스템 앨범에 저장하세요

사용자의 시스템 앨범에 저장하고 이 기능을 구현하려면 주로 wx.canvasToTempFilePathwx.saveImageToPhotosAlbum을 사용합니다. </code >이 두 가지 API입니다. <code>wx.canvasToTempFilePathwx.saveImageToPhotosAlbum这两个API。

主要的流程就是先通过wx.canvasToTempFilePath<canvas>上绘制的图像生成临时文件的形式,然后再通过wx.saveImageToPhotosAlbum

주요 프로세스는 먼저 wx.canvasToTempFilePath를 통해 <canvas>에 그려진 이미지에서 임시 파일을 생성한 다음 wx.saveImageToPhotosAlbum<을 사용하는 것입니다. /code>시스템 앨범에 저장하는 작업을 수행합니다.

  //保存邀请卡
  saveInviteCard:function(){
    console.log(&#39;保存图片&#39;)
    const wxCanvasToTempFilePath = util.promisify(wx.canvasToTempFilePath)
    const wxSaveImageToPhotosAlbum = util.promisify(wx.saveImageToPhotosAlbum)

    wxCanvasToTempFilePath({
      canvasId: &#39;shareCanvas&#39;
    }, this).then(res => {
      return wxSaveImageToPhotosAlbum({
        filePath: res.tempFilePath
      })
    }).then(res => {
      wx.showToast({
        title: &#39;已保存到相册&#39;
      })
    })
  }
로그인 후 복사
관련 추천:

WeChat Mini 프로그램 QR 코드 캔버스 그리기 예시에 대한 자세한 설명

WeChat Mini 프로그램 캔버스 기본에 대한 자세한 설명

🎜

위 내용은 WeChat 미니 프로그램에서 이미지를 생성하는 코드의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

관련 라벨:
원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
최신 이슈
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿