1# 深度信息(仅对系统应用开放)(ArkTS)
2
3深度信息表示图像中每个像素点与相机之间的距离关系,可以辅助实现更精准的对焦和背景虚化效果等。在相机应用预览、拍照和录像场景中,支持上报深度信息。
4
5## 开发步骤
6
7详细的API说明请参考[Camera API参考](../../reference/apis-camera-kit/js-apis-camera.md)。
8
91. 导入camera接口,接口中提供了相机相关的属性和方法,导入方法如下。
10
11   ```ts
12   import { camera } from '@kit.CameraKit';
13   import { BusinessError } from '@kit.BasicServicesKit';
14   ```
15
162. 通过[CameraOutputCapability](../../reference/apis-camera-kit/js-apis-camera.md#cameraoutputcapability)类中的depthProfiles属性获取当前设备支持的深度能力,返回depthProfilesArray数组。通过[createDepthDataOutput](../../reference/apis-camera-kit/js-apis-camera-sys.md#createdepthdataoutput)方法创建深度流。
17
18   ```ts
19   function getDepthDataOutput(cameraManager: camera.CameraManager, cameraOutputCapability: camera.CameraOutputCapability): camera.DepthDataOutput | undefined {
20     let depthProfilesArray: Array<camera.Profile> = cameraOutputCapability.depthProfiles;
21     let depthDataOutput: camera.DepthDataOutput | undefined = undefined;
22     try {
23       depthDataOutput = cameraManager.createDepthDataOutput(depthProfilesArray[0]);
24     } catch (error) {
25       let err = error as BusinessError;
26       console.error(`Failed to create the DepthDataOutput instance. error: ${JSON.stringify(err)}`);
27     }
28     return depthDataOutput;
29   }
30   ```
31
323. 使能。通过depthDataOutput类的[start](../../reference/apis-camera-kit/js-apis-camera-sys.md#start12)方法输出深度流。接口调用失败会返回相应错误码,错误码类型参见[Camera错误码](../../reference/apis-camera-kit/js-apis-camera.md#cameraerrorcode)。
33
34   ```ts
35   async function startDepthDataOutput(depthDataOutput: camera.DepthDataOutput): Promise<void> {
36     if (!depthDataOutput) {
37       console.error('depthDataOutput Undefined');
38       return;
39     }
40     try {
41       await depthDataOutput.start();
42     } catch (err) {
43       const error = err as BusinessError;
44       console.error(`Failed to start depth data output. error: ${JSON.stringify(err)}`);
45     }
46   }
47   ```
48
49## 状态监听
50
51在相机应用开发过程中,可以随时监听深度流的深度数据回调信息,以及深度流输出错误信息。
52
53- 通过注册固定的depthDataAvailable回调函数获取监听深度流数据。
54
55  ```ts
56  function onDepthDataAvailable(depthDataOutput: camera.DepthDataOutput): void {
57    depthDataOutput.on('depthDataAvailable', (err: BusinessError) => {
58      if (err !== undefined && err.code !== 0) {
59        return;
60      }
61      console.info('Depth data available');
62    });
63  }
64  ```
65
66- 通过注册固定的error回调函数获取监听深度流输出错误结果,callback返回深度输出接口使用错误时对应的错误码,错误码类型参见[Camera错误码](../../reference/apis-camera-kit/js-apis-camera.md#cameraerrorcode)。
67
68  ```ts
69  function onDepthDataOutputError(depthDataOutput: camera.DepthDataOutput): void {
70    depthDataOutput.on('error', (depthDataOutputError: BusinessError) => {
71      console.error(`Depth data output error code: ${depthDataOutputError.code}`);
72    });
73  }
74  ```
75