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

前言

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

代码

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()
  },

})

相关推荐

  1. 程序实现图片base64

    2024-04-04 15:52:02       11 阅读
  2. 程序canvas画布自由绘制/画笔功能实现

    2024-04-04 15:52:02       37 阅读
  3. 程序(3.3.5) 对实时数据调速

    2024-04-04 15:52:02       16 阅读
  4. 程序外部程序

    2024-04-04 15:52:02       38 阅读
  5. 程序canvas实现贴纸效果

    2024-04-04 15:52:02       33 阅读
  6. 程序canvas画布图片pdf文件

    2024-04-04 15:52:02       36 阅读
  7. 程序canvas画布绘制文字自动换行

    2024-04-04 15:52:02       44 阅读

最近更新

  1. TCP协议是安全的吗?

    2024-04-04 15:52:02       16 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2024-04-04 15:52:02       16 阅读
  3. 【Python教程】压缩PDF文件大小

    2024-04-04 15:52:02       15 阅读
  4. 通过文章id递归查询所有评论(xml)

    2024-04-04 15:52:02       18 阅读

热门阅读

  1. VMware虚拟机三种网络模式

    2024-04-04 15:52:02       15 阅读
  2. OBS在Linux下安装NDI插件手札

    2024-04-04 15:52:02       15 阅读
  3. Linux下docker运行python

    2024-04-04 15:52:02       17 阅读
  4. MySQL 表锁、行锁

    2024-04-04 15:52:02       14 阅读
  5. 【C++】编程规范之内存规则

    2024-04-04 15:52:02       13 阅读
  6. tomcat配置web项目

    2024-04-04 15:52:02       13 阅读
  7. Tomcat部署及安全加固

    2024-04-04 15:52:02       13 阅读
  8. MT3016 竹鼠通讯

    2024-04-04 15:52:02       13 阅读
  9. LeetCode——蜡烛间的盘子(前缀和+预处理)

    2024-04-04 15:52:02       16 阅读
  10. leetcode热题100.跳跃游戏

    2024-04-04 15:52:02       13 阅读
  11. Qt-打开视频文件和图片文件的判断

    2024-04-04 15:52:02       13 阅读