抖音开放平台Logo
开发者文档
“/”唤起搜索
控制台
  • JS API 列表
  • 基础
  • TTML
  • 网络
  • 媒体
  • 图片
  • 录音
  • 音频
  • 视频
  • 相机
  • tt.createCameraContext
  • CameraContext
  • CameraFrameListener
  • CameraFrameListener
  • CameraFrameListener.start
  • CameraFrameListener.stop
  • 特效相机
  • Canvas 录制
  • rtc-room 实时通信
  • 地图
  • 文件
  • 数据缓存
  • 地理位置
  • 设备
  • 画布
  • 界面
  • 页面导航
  • 开放接口
  • 行业开放
  • 第三方平台
  • 其它
  • 生活服务(即将废弃)
  • CameraFrameListener.start
    收藏
    我的收藏

    基础库 1.78.0 开始支持本方法,这是一个同步方法。

    开始监听帧数据。开始监听后,CameraContext.onCameraFrame 回调中开始接收帧数据。

    前提条件
    业务背景
    使用限制
    注意事项
    • Tip: 如需使用帧回调,建议 frame-size 和 resolution 统一级别,否则图片可能会有拉伸;
    • Tip:开发者工具暂不支持此能力,请用真机扫码调试。
    支持沙盒
    相关教程

    语法

    CameraFrameListener.start()

    参数说明

    返回值

    扫码体验

    请使用字节宿主APP扫码

    代码示例

    开发者工具中预览

    <!-- index.ttml --> <camera class="camera" frame-size="medium" device-position="back" binderror="onError"></camera> <view class="page-body"> <button type="primary" bindtap="auth">相机授权</button> <button type="primary" bindtap="startOnFrame">开始接收帧数据</button> <view>第 {{counter}} 帧</view> <view hidden="{{counter === 0}}">frameWidth{{frameWidth}}; frameHeight:{{frameHeight}}</view> </view>
    // index.js var listener; Page({ data: { counter: 0, frameWidth: 0, frameHeight: 0, }, onLoad: function (options) { this.openCamera(); }, openCamera() { tt.getSetting({ success: (res) => { let cameraAllowed = res.authSetting["scope.camera"]; if (cameraAllowed) { this.ctx = tt.createCameraContext(); } else { tt.showToast({ title: "请授权相机后重新进入" }); } }, fail: (err) => { tt.showModal({ title: "获取授权失败", content: JSON.stringify(err), }); }, }); }, startOnFrame(e) { listener = this.ctx.onCameraFrame((frame) => { let { width, height, data } = frame; this.setData({ counter: this.data.counter + 1, frameWidth: width, frameHeight: height, }); }); listener.start({ success: (res) => { tt.showToast({ title: "开始接收帧数据" }); }, fail: (err) => { tt.showModal({ title: "接收失败", content: JSON.stringify(err), }); }, }); }, onError(err) { tt.showModal({ title: "相机出错了", content: JSON.stringify(err), }); }, });