网站维护多少钱一个月/百度竞价推广托管

   日期:2024-12-27     作者:br0qf       评论:0    移动:http://oml01z.riyuangf.com/mobile/news/8208.html
核心提示:时至今日,android已经8.0+,而研究camera1的意义在于对一般的Binder机制,老的camera架构有深入的理解。

网站维护多少钱一个月/百度竞价推广托管

时至今日,android已经8.0+,而研究camera1的意义在于对一般的Binder机制,老的camera架构有深入的理解。目前国内,比如我的工作,至今仍然是android5.1为主, 6.0,7.0为辅,甚至还有开历史倒车的4.4的工作。更加不提近日Vivo新机升降摄像头成为了检测流氓软件的标杆了。这是因为,某app使用了camera api1,获取某些摄像头属性他必须先Camera.open()以后才能。而我推测该机器是绑定了camera.open的动作,硬件上就会升起摄像头。并解释说camera2对AR VR支持不好等等。

言归正传,对于这样的大app至今都在使用Camera1。我们还是继续研究下。

android camera架构十分的复杂,今天开始分析它,这里以android2.3.7源码为研究对象,后续可以对比下android5.1下的对于Camera1的变化。比如frameworks/av的路径是有差异。至于架构似乎差异不大。到时候再说。

(永不过时的API1

首先建立在学习了Binder,学习了AshMemory(MemoryHeapBase

我已经写了2篇,第一篇以java android上层开发工程师的角度;第二篇,融汇贯通C++/Java Binder.

入门学习:Binder Java入门

注意学习:Binder C++ Java

1. Anonymous Shared Memory

AShMem包含IMemory和IMemoryHeap2族,都是Binder机制的应用实例

:提供接口,访问匿名共享内存

​ {heapFD; mBase; size;flags;device;offset}

: 在client端的业务逻辑

​ 里面包含一个static sp (内部有键值对Vectormap),保存了一个Client进程中所有的BpMemoryHeap.

:BnMemoryHeap sever端真实的业务逻辑.

引用原文:匿名共享内存的C++访问方式

1)服务端构造MemoryHeapBase对象时,创建匿名共享内存,并映射到服务进程的地址空间中,同时提供获取该匿名共享内存的接口函数

2)客户端通过BpMemoryHeap对象请求服务端返回创建的匿名共享内存信息,并且将服务端创建的匿名共享内存映射到客户进程的地址空间中,在客户端也提供对应的接口函数来获取匿名共享内存的信息

:其实是承载IMemoryHeap的一个封装对象。

​ 主要包含getMemory()返回IMemoryHeap mHeap

​ 所以与直接使用MemoryHeap相比,这里更关注的是共享内存块的起始位置offset,和大小size。

MemoryHeapBase:一般用于在进程间共享一个完整的匿名共享内存块

常用构造函数

MemoryBase: 一般用于在进程间共享一个匿名共享内存块的其中一部分。

常用构造函数

2. Camera类图

此图需要反复翻上去看,先保存对比看。

3. 建立连接流程

open()-> new Camera(id) -> native_setup(this, id)

3. 主动类型:startPreview为代表的上层往下的流程

java->startPreview->JNI

流程很清晰,进程也已经清楚,略掉流程图的绘制。

这一步搞清楚的是(阅读时,要反复翻阅类图理解,JAVA JNI 的JNICameraContext, 持有本地sp

4. 回调类型:以postData(int msgType, const sp< IMemory>& dataPtr)为代表的回调机制

4.1 第1步,看设置监听的流程

这里纯粹是在一个进程,2个对象中最普通的监听注册而已。

首先我们要明确dataCallback等3个方法,它的对象是Camera,已经传递给CameraService了。

所以在阅读代码要搞清楚,Camera.cpp Camera::dataCallback(int32_t msgType, const sp& dataPtr)其实是BnCameraClient; CameraService就会使用存下来的BpCameraClient:ICameraClient调用对应方法即可。

4.2 第2步,找发送端

查看CameraService的时候,就是类图中很多的CameraService::Client::handleXXX,比如

而所有的handleXXX都是从static方法而来

而它们是在new CameraService:Client()的时候,给hardware对象设置的回调。

HAL底下,暂时不分析。MTK的源码中可以查阅部分实现。这里略过。

这一步的分析过来,可以倒过来看。这就是一个基于Binder的远程回调方式。原理与[binder/AIDL回调机制]

20180702备注
从上面逻辑可以看出,hardware有buff以后,首先通过静态func注册进去的3个方法回调到cameraservice,然后binder机制调用到BnCameraClient,即Camera.cpp中的mListener会被接受。
然而,由于Camera不仅仅是preview,还涉及到mediaRecorder,则会出现mListener在录制的时候,被设置到CameraSource里面去了。
因此,此处的回调也就不能去到JNIContext了。

这个会在后续展开讲解。android2.3 camera架构相对简单(虽然已经很庞大了,android5以上的camera更加复杂,更多的模型嵌套。逻辑上也有所变化。

5. takePicture 内存共享研究

整体拍照流程,虚线左边是app进程,右边是CameraService进程。基本上都是Binder流程,不再赘述。

按照第一章节的理解,我们必须找到在哪里申明MemoryHeapBase或者MemoryBase的地方。

在CameraHardwareStub.h定义

上流程图中,因为每个平台实现不同,简要描述,内部代码(略)可以自行分析,是从hardware去takePicture并给出了共享的一个。如果没有拷贝需求则直接给出去。如果有拷贝的需求,则通过CameraService内部的运作一番。之后就开始走回调流程。

最后共享回调到,JNI 在这里

而fields.post_event = env->GetStaticMethodID(clazz, “postEventFromNative”,
“(Ljava/lang/Object;IIILjava/lang/Object;)V”);

因此,可以看到AShMem在takePicture流程上的使用,在日后其他类似流程的共享机制上会更加轻松地阅读和使用。

总结

  • 研究的android2.3.7的源码。后续再补充5.1下的camera1的差异。也多亏老代码的目录分明,代码更加简洁。

  • 共享内存机制,掌握2个类,他们的应用场景的差异。

    MemoryHeapBase:一般用于在进程间共享一个完整的匿名共享内存块

    MemoryBase: 一般用于在进程间共享一个匿名共享内存块的其中一部分。

    他们都是作为binder对象共享出去的;不过在使用中一般是以MemoryHeapBase在定义共享端申明,而用MemoryBase共享具体某一部分。

  • 对JNI和cameraService持有的对象,他们的关系,Bp,Bn,接口如何流转目前已经十分清晰

  • 而对binder callback的研究,则加深了对上一篇文章源码阅读心得的理解。

    1. 看到某个func() 内部有mRemote/remote()就是客户端拿到BinderProxy/BpBinder
    2. func() 都需要将descriptor写入Parcel JNI。如果是获取Ibinder则需要额外写入Binder token, 然后mRemote.transact()/remote->transact()就是调用binder驱动;
    3. 看到onTransact()就代表已经在server端,onTransact() switch case会从binder驱动的返回结果中parcel解析出一般数据,如果是获取IBinder就是BinderProxy/BpBinder对象;这中间就会调用真实的func(),最后写回去
    4. 一般某个文件中会同时有func()2个同名的,要注意区分他的类作用域,一个是Stub/BnXX实体操作;一个是Proxy/BpXX代理操作。

    之前的理解是没有错误的,但是本文理解binder callback后,需要做出解释。
    因为原本的服务端持有了客户端给过来的Callback(IBinder)对象以后,在使用callback的时候,此刻就作为客户端了,反过来,接受的时候,客户端就作为server了。

引用

https://www.cnblogs.com/suncoolcat/p/3329082.html

一篇android匿名内存共享机制原理解析文章

我之前的2-3篇Binder、AIDL文章。

附录

title camera open流程图

App进程->App进程: java open(id)
App进程->App进程: JNI Camera:connect(id)
App进程–>service: cs.connect(c, id)
service–>App进程: c->mCamera = BpCamera
App进程->App进程: sp (Camera:ICameraClient)

 
特别提示:本信息由相关用户自行提供,真实性未证实,仅供参考。请谨慎采用,风险自负。

举报收藏 0打赏 0评论 0
 
更多>同类最新资讯
0相关评论

相关文章
最新文章
推荐文章
推荐图文
最新资讯
点击排行
{
网站首页  |  关于我们  |  联系方式  |  使用协议  |  隐私政策  |  版权隐私  |  网站地图  |  排名推广  |  广告服务  |  积分换礼  |  网站留言  |  RSS订阅  |  违规举报  |  鄂ICP备2020018471号