开发
API
自2022年9月6日起,本文档站不再更新内容,相关文档已迁移至全新“抖音开放平台”前往

CameraContext.setZoom

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

设置 Camera 缩放级别。

语法

CameraContext.setZoom(options)

参数说明

options 为 object 类型,属性如下:

属性名类型默认值必填说明最低支持版本
zoomnumber缩放级别,范围[1, maxZoom]。zoom 可取小数,精确到小数后一位。maxZoom 可在 bindinitdone 返回值中获取1.78.0
successfunction接口调用成功的回调函数1.78.0
failfunction接口调用失败的回调函数1.78.0
completefunction接口调用结束的回调函数(调用成功、失败都会执行)1.78.0

zoom 参数与表现

传参表现
合法且在范围内正常
不传 或 非 number 类型报错 "invalid zoom"
> maxzoom默认 maxzoom

回调成功

object 类型,属性如下:

属性名类型说明最低支持版本
zoomnumber实际设置的缩放级别。由于系统限制,某些机型可能无法设置成指定值,会改用最接近的可设值。1.78.0
errMsgstring"setCameraZoom:ok"1.78.0

回调失败

object 类型,属性如下:

属性名类型说明最低支持版本
errMsgstring"setCameraZoom:fail" + errDetail1.78.0
errCodenumber错误码1.78.0

错误说明

errNoerrMsg说明最低支持版本
108invalid zoom无效的缩放级别1.78.0

代码示例

开发者工具中预览

<!-- index.ttml -->
<camera
  class="camera"
  device-position="back"
  flash="off"
  bindinitdone="initdone"
  bindstop="onStop"
  binderror="onError"
></camera>
<button type="primary" bindtap="setZoom">设置缩放级别</button>
// index.js
Page({
  data: {
    counter: 0,
  },
  onLoad: function (options) {
    tt.getSetting({
      success: (res) => {
        let cameraAllowed = res.authSetting["scope.camera"];
        if (!cameraAllowed) {
          tt.showToast({
            title: "请授权相机后重新进入", // 内容
            success: (res) => {
              this.auth();
            },
          });
        }
      },
      fail: (err) => {
        tt.showModal({
          title: "获取授权失败",
          content: JSON.stringify(err),
        });
      },
    });
  },

  auth() {
    tt.authorize({
      scope: "scope.camera",
      success: () => {
        tt.showToast({
          title: "授权成功",
        });
        tt.reLaunch({
          url: "/pages/camera/setzoom", // 指定页面的url
        });
      },
      fail: (err) => {
        tt.showModal({
          title: "授权失败",
          content: JSON.stringify(err),
        });
      },
    });
  },
  setZoom() {
    this.ctx = tt.createCameraContext();
    this.ctx.setZoom({
      zoom: 5,
      success(res) {
        tt.showToast({
          title: "设置 zoom 为" + res.zoom, // 内容
        });
      },
      fail(err) {
        tt.showModal({
          content: "设置缩放失败:" + JSON.stringify(err),
        });
      },
    });
  },
  onError(err) {
    tt.showModal({
      title: "相机出错了",
      content: JSON.stringify(err),
    });
  },
});

Bug & Tip

  • Tip:开发者工具暂不支持此能力,请用真机扫码调试。
点击纠错
该文档是否对你的开发有所帮助?
有帮助
没帮助
该文档是否对你的开发有所帮助?
有帮助
没帮助