VIVO相机启动流程拆解

和你一起终身学 习,这里是程序员Android

经典好文推荐,通过阅读本文,您将收获以下知识点:

一、启动阶段拆解概览

1. 启动阶段拆解表格


Camera 启动阶段拆机表格

S0 :System

deliverInputEvent ===> activityStart 开始

S1 :Camera APP + Camera FWK

activityStart 开始 ===>CameraHal::openSession 开始

S2 :Camera HAL

CameraHal::openSession

S3 :Camera APP + Camera FWK

CameraHal::openSession 结束 ===>CameraHal::configureStreams 开始

S4 :Camera HAL

CameraHal::configureStreams

S5 :Camera APP + Camera FWK

CameraHal::configureStreams 结束===>submitRequestList 开始|

S6 :Camera HAL

submitRequestList 开始===>first full buffer

S7 :Camera APP

first full buffer ===>APP surfaceview

S8 :SurfaceFlinger

APP surfaceview===>SF HWC 屏显第一帧

二、 阶段拆解

S0 点击事件处理到Camera app 启动


点击事件处理

S1 Camera app 启动到 下发openCamera


Camera activitystart

S2 Camera HAL 开始 opencamera


camera 下发open camera

S3 open Camera 结束,到配流开始


获取Camera 数,配流

S4 Camera HAL 配流并初始化usecase


Camera 配流并初始化usecase

S5 配流结束到提交预览请求


提交预览请求

S6 提交预览请求到返回第一帧


第一帧callback

S7 APP 处理第一帧并送给SurfaceFlinger


APP 处理第一帧送给SurfaceFlinger

S8 vsync-SF 信息到来,SF 处理并送显示


vsync-SF 信息到来,SF 处理并送显示

三、Trace 中的其他信息

1. 帧率


Camera HAL 出图帧率 以及 屏幕显示帧率

2. CPU 负载 ,CPU频率


CPU 负载

CPU 频率 1.9GHZ 2.4G HZ

VIEngine-Main 预览帧处理


VivoCamera 预览引擎

预览帧处理

预览请求帧 与预览callback 帧处理


Camera 第0帧 预览请求流程

Camera 第 0帧 Callback流程

preivew 帧callback

perflock 提频相关


perflock 提频相关

四、log分析

配流信息:

go 复制代码
行  163983: 08-22 16:14:46.219  1047  1537  7386 I CameraService: CameraService::connect call (PID 30560 "com.android.camera", camera ID 0) and Camera API version 2
    行  164229: 08-22 16:14:46.420  1047  1537  7386 I Camera3-Device: Camera 0: Creating new stream 0: 1440 x 1080, format 34, dataspace 0 rotation 0 consumer usage 0, isShared 0, physicalCameraId , isMultiResolution 0 dynamicRangeProfile 0x1, streamUseCase 0, timestampBase 0, mirrorMode 0, colorSpace -1, useReadoutTimestamp 0
    行  164237: 08-22 16:14:46.432  1047  1537  7386 I Camera3-Device: Camera 0: Creating new stream 1: 1440 x 1080, format 35, dataspace 146931712 rotation 0 consumer usage 0, isShared 0, physicalCameraId , isMultiResolution 0 dynamicRangeProfile 0x1, streamUseCase 0, timestampBase 0, mirrorMode 0, colorSpace -1, useReadoutTimestamp 0
    行  164246: 08-22 16:14:46.444  1047  1537  7386 I Camera3-Device: Camera 0: Creating new stream 2: 4080 x 3060, format 35, dataspace 146931712 rotation 0 consumer usage 0, isShared 0, physicalCameraId , isMultiResolution 0 dynamicRangeProfile 0x1, streamUseCase 0, timestampBase 0, mirrorMode 0, colorSpace -1, useReadoutTimestamp 0

参考文献:

【腾讯文档】Camera学习知识库

https://docs.qq.com/doc/DSWZ6dUlNemtUWndv

至此,本篇已结束。转载网络的文章,小编觉得很优秀,欢迎点击阅读原文,支持原创作者,如有侵权,恳请联系小编删除,欢迎您的建议与指正。同时期待您的关注,感谢您的阅读,谢谢!

点个在看,为大佬点赞!

相关推荐
gaosushexiangji19 小时前
一项基于高灵敏度sCMOS相机的光镊成像实验
数码相机
王哈哈^_^2 天前
YOLOv11视觉检测实战:安全距离测算全解析
人工智能·数码相机·算法·yolo·计算机视觉·目标跟踪·视觉检测
不一样的故事1262 天前
iPhone 17 Pro Max 的评测和用户反馈
数码相机·智能手机·iphone
一只在学习的瓶子2 天前
Camera性能
数码相机
第二层皮-合肥2 天前
图像处理中的暗场校正
图像处理·数码相机·计算机视觉
格林威3 天前
AOI在风电行业制造领域中的应用
人工智能·数码相机·计算机视觉·视觉检测·制造·机器视觉·aoi
kyle~3 天前
机器视觉---UVC相机驱动
数码相机
代码改善世界6 天前
仓颉语言相机拍照功能实现深度解析
数码相机
杨朝为-蓝松抠图SDK6 天前
绿幕直播:绿幕怎么选择?灯光怎么布置?相机怎么设置?抠图软件怎么操作?
数码相机·无人直播·obs直播·绿幕抠图·绿幕直播·蓝松抠图·发丝级抠图
TMT星球6 天前
沙利文报告:连续8年全球第一,影石全景相机市占率升至85%
数码相机