OutputConfiguration类方法及使用

OutputConfiguration 类是 Android 硬件 camera2 API 中用于配置和管理相机捕获会话输出目标的关键类。

主要方法

  1. 构造方法
    • OutputConfiguration(Surface surface):使用指定的 Surface 初始化一个 OutputConfiguration 对象。
    • OutputConfiguration(Size size, Class<T> klass):使用指定的大小和 Surface 类型创建一个延迟配置的 OutputConfiguration 对象。
  2. 表面管理
    • void addSurface(Surface surface):向 OutputConfiguration 添加一个新的 Surface,可用于添加初始 Surface 之外的附加 Surface。
    • void removeSurface(Surface surface):从 OutputConfiguration 中移除一个 Surface。如果该 Surface 不是此配置的一部分或者是主要 Surface,则会抛出 IllegalArgumentException 异常。
  3. 配置检索
    • List<Surface> getSurfaces():返回与此 OutputConfiguration 关联的 Surface 的不可变列表。
    • Surface getSurface():返回与此 OutputConfiguration 关联的主要 Surface。
    • int getRotation():获取此 OutputConfiguration 的旋转配置。
    • int getSurfaceGroupId():检索此配置的 Surface 组 ID,默认值为 -1。
    • String getPhysicalCameraId():获取为此 OutputConfiguration 设置的物理相机 ID。
  4. 表面共享
    • void enableSurfaceSharing():允许多个 Surface 共享相同的 OutputConfiguration
    • boolean isSurfaceSharingEnabled():检查是否启用了 Surface 共享。
  5. 延迟配置
    • boolean isDeferredConfiguration():检查 OutputConfiguration 是否是延迟配置。
    • boolean isDeferredConfigurationEnabled():返回是否支持延迟配置。
  6. 其他
    • int getMaxSharedSurfaceCount():返回可以添加到此 OutputConfiguration 的最大 Surface 数量。
    • void writeToParcel(Parcel dest, int flags):用于将此对象打包到 Parcel 中。

使用示例

基本使用

// 创建一个包含主要 Surface 的 OutputConfiguration
Surface previewSurface = ...; // 初始化你的 Surface
OutputConfiguration config = new OutputConfiguration(previewSurface);

// 使用该配置创建捕获会话
List<OutputConfiguration> outputConfigs = Arrays.asList(config);
CameraCaptureSession.StateCallback stateCallback = ...; // 你的状态回调
cameraDevice.createCaptureSessionByOutputConfigurations(outputConfigs, stateCallback, null);

添加多个 Surface

// 创建一个包含主要 Surface 的 OutputConfiguration
OutputConfiguration config = new OutputConfiguration(previewSurface);

// 添加附加的 Surface
Surface recordingSurface = ...; // 初始化另一个 Surface
config.addSurface(recordingSurface);

// 如果需要,启用 Surface 共享
config.enableSurfaceSharing();

处理延迟配置

// 创建一个延迟配置的 OutputConfiguration
Size surfaceSize = new Size(1920, 1080);
OutputConfiguration deferredConfig = new OutputConfiguration(surfaceSize, SurfaceTexture.class);

// 稍后,当准备好时设置实际的 Surface
Surface deferredSurface = ...; // 初始化延迟的 Surface
deferredConfig.addSurface(deferredSurface);

这些示例展示了如何使用 OutputConfiguration 类设置和管理相机捕获会话的输出。此类允许灵活处理相机输出,包括延迟配置和 Surface 共享功能。有关更多详细信息,请参阅官方 Android 文档。

  • 9
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Android 中,Camera HAL3 与 CameraService 之间通信使用了 `ICameraDeviceUser` 和 `ICameraDeviceCallbacks` 两个 Binder 接口。 1. `ICameraDeviceUser` 接口 该接口的方法如下: - `disconnect()`: 断开相机设备连接 - `submitRequest(CaptureRequest request, boolean streaming, int* surfaceId):` 向相机设备提交捕获请求 - `submitRequestList(ACaptureRequest[] requestList, boolean streaming, int* surfaceId):` 向相机设备提交捕获请求列表 - `cancelRequest(int requestId):` 取消指定的捕获请求 - `beginConfigure():` 开始相机设备的配置 - `endConfigure(int operatingMode, ACameraMetadata* outMetadata):` 结束相机设备的配置,并返回相机设备的元数据 - `createStream(OutputConfiguration outputConfiguration, int* surfaceId):` 创建一个相机数据流 - `createInputStream(int width, int height, int format, int *inputId):` 创建一个相机输入流 - `getInputSurface():` 获取输入流的 Surface - `setInFlightRequestCount(int count):` 设置正在执行的捕获请求的数量 - `getCaptureRequestMetadataQueue():` 获取捕获请求的元数据队列 2. `ICameraDeviceCallbacks` 接口 该接口的方法如下: - `onDeviceError(int errorCode, CaptureResultExtras resultExtras):` 相机设备出错时的回调方法 - `onDeviceIdle():` 相机设备空闲时的回调方法 - `onCaptureStarted(CaptureResultExtras resultExtras, long timestamp):` 捕获开始时的回调方法 - `onResultReceived(CameraMetadataNative result):` 捕获结果接收时的回调方法 - `onPrepared(int streamId):` 数据流准备好时的回调方法 - `onRequestQueueEmpty():` 请求队列为空时的回调方法 上述两个接口的方法主要用于控制相机设备的连接、捕获请求和数据流的处理。其中,`ICameraDeviceUser` 接口提供了相机设备的基本操作,`ICameraDeviceCallbacks` 接口则用于接收相机设备的回调信息。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值