第21讲 createCaptureSession详解 - Android Camera2 API

本讲是Android Camera专题系列的第21讲,我们介绍Android Camera2 API专题的createCaptureSession详解。

更多资源:

资源 描述
在线课程 极客笔记在线课程
知识星球 星球名称:深入浅出Android Camera
星球ID: 17296815
Wechat 极客笔记圈

createCaptureSession (SessionConfiguration config)注意事项

创建CameraCaptureSession

  • 创建CameraCaptureSession时,需要包含所有的Output/Input Surfaces

  • 创建好CameraCaptureSession后,提交的CaptureRequest中带的Surfaces只能在这组Surfaces里面选择

创建CameraCaptureSession一般需要几百毫秒,Camera HAL会对一些硬件做上电操作、创建Pipeline动作等等

CameraCaptureSession的切换

  • 直接调用createCaptureSession,前面的CameraCaptureSession会被close掉

  • 最快的切换方式

    • 先调用旧CameraCaptureSession#abortCaptures,再创建新的CameraCaptureSession

根据不同的场景选择Surface

场景 Surface组件 使用方法
Preview SurfaceView surfaceCreated(SurfaceHolder holder)时调用SurfaceHolder.setFixedSize(int, int)设置Size,然后调用SurfaceHolder.getSurface()来获取Surface
OpenGL ES处理(Preview) SurfaceTexture 调用SurfaceTexture.setDefaultBufferSize(int, int)设置Size,然后通过new Surface(SurfaceTexture)来获取Surface
录像 MediaCodec 配置完MediaCodec后,调用MediaCodec.createInputSurface()来获取Surface
录像 MediaRecorder 配置完MediaRecorder后,调用MediaRecorder.getSurface()来获取Surface
YUV处理 Renderscript 配置好Allocation后,调用Allocation.getSurface()来获取Surface
抓图(Raw/YUV/JPEG…) ImageReader 配置好ImageReader后,调用ImageReader.getSurface()来获取Surface
Reprocess CameraCaptureSession CameraCaptureSession创建好后,调用CameraCaptureSession#getinputsurface来获取Surface

流配置表说明

Format

  • PRIV: ImageFormat.PRIVATE,对App透明的

  • YUV: ImageFormat.YUV_420_888

  • JPEG: ImageFormat.JPEG

  • RAW: ImageFormat.RAW_SENSOR

Size

  • PREVIEW:跟屏幕宽高比一致,<=1080P

  • RECORD: CamcorderProfile中定义的最大录像Size

  • MAXIMUM: StreamConfigurationMap#getOutputSizes中的最大值

  • MULTI_RES : MultiResolutionStreamConfigurationMap#getOutputInfo(int)获取到的值

超出流配置表限制

如何理解是否超出表格限制

  • 某一行表示一个Streams Configuration组合,比如这一行支持8MP YUV和2MP PRIV
    • [8 MP YUV, 2 MP PRIV] 或者 [2 MP YUV, 2 MP PRIV]组合配置能成功

    • [8 MP YUV, 4 MP PRIV], 或者 [4 MP YUV, 4 MP PRIV], 或者 [8 MP PRIV, 2 MP YUV]不能确保是否成功

  • 如果App使用超出下面表格限制的Surfaces来创建Session,有三种可能发生

    1. CameraCaptureSession能创建成功,并能正常工作

    2. CameraCaptureSession能创建成功,但帧率无法达到StreamConfigurationMap#getOutputMinFrameDuration的要求

    3. CameraCaptureSession创建失败

  • 也有可能可以成功创建Session,可以通过如下两种方式尝试

    • isSessionConfigurationSupported(SessionConfiguration)

    • 调用createCaptureSession看是否不会发生Exception 或 收到onConfigured回调

Regular流配置表

Regular Capture – LEGACY

Regular Capture - LEGACY

Regular Capture – LIMITED

Regular Capture - LIMITED

Regular Capture – FULL

Regular Capture - FULL

Regular Capture – RAW Capability

Regular Capture – RAW Capability

Regular Capture – BURST Capability

Regular Capture – BURST Capability

Regular Capture – LEVEL_3

Regular Capture – LEVEL_3

Regular Capture – Concurrent stream

Regular Capture – Concurrent stream

Regular Capture – MultiResolutionoutputs Legacy Level

Regular Capture – MultiResolutionoutputs Legacy Level

Regular Capture – MultiResolutionoutputs LIMITED Level

Regular Capture – MultiResolutionoutputs LIMITED Level

Regular Capture – 特殊对待QCIF

  • 前面介绍的一定支持的流配置表时,提到只要小于这个表中的Size也能支持,但有一个例外:QCIF(176×144)

  • 因为通常Camera底层的downscale能力都是有限的(最大能downscale多少倍),如果从>= 1920×1080的分辨率downscale到176×144,有可能不支持

Constrained high-speed recording流配置

支持CONSTRAINED_HIGH_SPEED_VIDEO Capability

帧率>=120FPS

与普通Capture Session比,有如下限制

  • 最多支持2个Output Surfaces

  • 每个Output Surface的Size必须一样,来自StreamConfigurationMap#getHighSpeedVideoSizes

  • 只能通过captureBurst 或 setRepeatingBurst方法向Camera底层送CaptureRequest List,CaptureRequest List来自CameraConstrainedHighSpeedCaptureSession#createHighSpeedRequestList

  • FPS Range必须来自StreamConfigurationMap#getHighSpeedVideoFpsRangesFor

Camera课程

Python教程

Java教程

Web教程

数据库教程

图形图像教程

办公软件教程

Linux教程

计算机教程

大数据教程

开发工具教程

Android Camera2 API