首页 >

微信小程序中生成图片的代码

微信小程序|小程序开发微信小程序中生成图片的代码
微信小程序
微信小程序-小程序开发
oa办公软件源码,vscode设置多行修饰,ubuntu vs安装,系统查找tomcat位置,爬虫聚合,php 选择排序,东莞短视频seo优化,校园网站模版,微信的登录注册页面模板lzw
本篇文章给大家带来的内容是关于微信小程序中生成图片的代码,有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。
百度云直链源码,ubuntu 安装url,配tomcat的jdk.,爬虫 有道翻译,php数据库管理系统开发,用百度seo做虚拟产品lzw

添加画布

首先,在小程序里进行绘图操作需要用到组件,步骤大致分为以下3个部分:一张大的背景图,一段动态的文字(‘标题 用户名 及其他信息’),以及一个小程序码图片。那我们就先在我们的wxml代码中放入如下的:

诗词app安卓源码,ubuntu修改开机画面,tomcat的host在哪儿,税务爬虫案例,php和web哪个更好用,seo高分打法lzw
  

第三方函数引入

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)         // 文字字号: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: '邀请卡绘制失败!',          image:'../../asset/images/warning.jpg'        })      } })

这样,差不多我们的分享图就生成好了。

长按图片保存到系统相册

要把它保存进用户的系统相册中去,实现这个功能,我们主要靠wx.canvasToTempFilePathwx.saveImageToPhotosAlbum这两个API。

主要的流程就是先通过wx.canvasToTempFilePath上绘制的图像生成临时文件的形式,然后再通过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基础详解


微信小程序中生成图片的代码
  • 在微信小程序中如何使用progress组件实现显示进度
  • 在微信小程序中如何使用progress组件实现显示进度 | 在微信小程序中如何使用progress组件实现显示进度 ...

    微信小程序中生成图片的代码
  • 微信小程序中列表上拉加载的实现方法(code)
  • 微信小程序中列表上拉加载的实现方法(code) | 微信小程序中列表上拉加载的实现方法(code) ...

    微信小程序中生成图片的代码
  • 关于微信小程序的异步处理
  • 关于微信小程序的异步处理 | 关于微信小程序的异步处理 ...