微信小程序3.3.5 实时帧数据绘制到canvas再转png;base64

前言

针对比较新的微信小程序开发库,我用的是3.3.5

代码

js

Page({

  /**
   * 生命周期函数--监听页面加载
   */
  onLoad() {
    // 获取camera上下文
    const context = wx.createCameraContext();
    // 定义监听帧数据回调函数
    const CamFramCall = (frame)=>{
      // 选择画布对象
      const query = wx.createSelectorQuery()
      // 画布ID为“mycanvas”
      query.select('#mycanvas')
        .fields({node:true,size:true})
        .exec((res)=>{
          const canvas=res[0].node
          const ctx=canvas.getContext('2d')
          // 根据实时帧宽高设置canvas宽高
          canvas.width=frame.width
          canvas.height=frame.height
          // 创建用于填充画布的imageData对象
          var imageData=ctx.createImageData(canvas.width,canvas.height)
          // 将原始帧数据格式转Uint8ClampedArray
          var ImgU8Array = new Uint8ClampedArray(frame.data);
          // 把原始帧数据写入imageData对象
          for(var i=0;i<ImgU8Array.length;i+=4){
            imageData.data[0+i]=ImgU8Array[i+0]
            imageData.data[1+i]=ImgU8Array[i+1]
            imageData.data[2+i]=ImgU8Array[i+2]
            imageData.data[3+i]=ImgU8Array[i+3]
          }
          // 把imageData绘制到canvas中
          ctx.putImageData(imageData,0,0,0,0,canvas.width,canvas.height)
          定义base64Data,用于存储实时帧的数据
          var base64Data=canvas.toDataURL()
          // 打印到控制台
          console.log(base64Data)
        })
      // 关闭监听
      listener.stop()
    }
    // 设置监听回调函数
    const listener = context.onCameraFrame(CamFramCall);
    // 开启监听
    listener.start()
  },

})

注意在wxml中加上这行代码

<canvas id="mycanvas" type="2d"></canvas>

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值