CAMERA预览数据流程分析(一)-------数据的获取

预览数据流分析(一)  数据的获取

 

mCameraDevice.startPreview();

 

/*

上篇文章已经有知道这个mCameraDevice就是对应的CameraClient的客户端,所以这个的startPreview就是CameraClient::startPreview()

*/

Step 1:

\frameworks\av\services\camera\libcameraservice\api1\CameraClient.cpp

// start preview mode

status_t CameraClient::startPreview() {

   LOG1("startPreview (pid %d)", getCallingPid());

   return startCameraMode(CAMERA_PREVIEW_MODE);

}

 

Step 2:

\frameworks\av\services\camera\libcameraservice\api1\CameraClient.cpp

 

// start preview or recording

status_tCameraClient::startCameraMode(camera_mode mode) {

   LOG1("startCameraMode(%d)", mode);

   Mutex::Autolock lock(mLock);

   status_t result = checkPidAndHardware();

   if (result != NO_ERROR) return result;

 

   switch(mode) {

       case CAMERA_PREVIEW_MODE:

           if (mSurface == 0 && mPreviewWindow == 0) {

                LOG1("mSurface is not setyet.");

               // still able to startpreview in this case.

           }

           return startPreviewMode();

       case CAMERA_RECORDING_MODE:

           if (mSurface == 0 && mPreviewWindow == 0) {

                ALOGE("mSurface ormPreviewWindow must be set before startRecordingMode.");

                return INVALID_OPERATION;

           }

           return startRecordingMode();

       default:

           return UNKNOWN_ERROR;

    }

}

 

Step 3:

\frameworks\av\services\camera\libcameraservice\api1\CameraClient.cpp

 

status_t CameraClient::startPreviewMode() {

   LOG1("startPreviewMode");

   status_t result = NO_ERROR;

 

   // if preview has been enabled, nothing needs to be done

   if (mHardware->previewEnabled()) {

       return NO_ERROR;

    }

 

   if (mPreviewWindow != 0) {

       native_window_set_scaling_mode(mPreviewWindow.get(),

               NATIVE_WINDOW_SCALING_MODE_SCALE_TO_WINDOW);

       native_window_set_buffers_transform(mPreviewWindow.get(),

                mOrientation);

    }

    mHardware->setPreviewWindow(mPreviewWindow);

   result = mHardware->startPreview();

 

   return result;

}

 

/*

主要分析这两个接口:

1,  mHardware->setPreviewWindow

2,  mHardware->startPreview();

mHardware前面已经有说明说,对应的就是Cam1Device类,而其具体的实现则是在其父类Cam1DeviceBase中实现的。所以mHardware->setPreviewWindow

对应就是Cam1DeviceBase::

setPreviewWindow(preview_stream_ops*window)

mHardware->startPreview();对应的是status_t

Cam1DeviceBase::

startPreview()

*/

 

Step 4.1.1:

\vendor\mediatek\proprietary\hardware\mtkcam\legacy\v1\device\Cam1DeviceBase.cpp

status_t

Cam1DeviceBase::

setPreviewWindow(preview_stream_ops* window)

{

   CAM_TRACE_CALL();

   MY_LOGI("+ window(%p)", window);

/*

这里主要是初始化了一个DisplayClient的类。具体这个DisplayClient的功能。后面再分析。

DisplayClient创建的时候,生成了一个createDisplayThread的线程,用来处理displayclient发送过来的消息,

createImgBufQueue 则用于存储数据,具体如何运作的待分析。

bool

DisplayClient::

init()

{

    bool ret =false;

    //

   MY_LOGD("+");

    //

    ret =   createDisplayThread()

       &&  createImgBufQueue()

            ;

    //

    MY_LOGD("-ret(%d)", ret);

    return  ret;

}

*/

   status_t status = initDisplayClient(window);

   if  ( OK == status &&previewEnabled() && mpDisplayClient != 0 )

    {

       status = enableDisplayClient();

       if(mbWindowReady)

       {

           waitStartPreviewDone();

       }

    }

   //

   return  status;

}

 

Step 4.1.2:

 

status_t

Cam1DeviceBase::

initDisplayClient(preview_stream_ops*window)

{

   CAM_TRACE_CALL();

#if '1'!=MTKCAM_HAVE_DISPLAY_CLIENT

   #warning "Not Build Display Client"

   MY_LOGD("Not Build Display Client");

   return  OK;

#else

   status_t status = OK;

   Size previewSize;

   //

   MY_LOGD("+ window(%p)", window);

   //

   //

   //  [1] Check to see whether thepassed window is NULL or not.

   if  ( ! window )

    {

       MY_LOGW("NULL window is passed into...");

       mbWindowReady = false;

       //

       if  ( mpDisplayClient != 0 )

       {

           MY_LOGW("destroy the current display client(%p)...",mpDisplayClient.get());

           mpDisplayClient->un

相机API2是Android系统中用于控制相机硬件的标准接口,它提供了更灵活、更高效的相机控制功能。而app-fw-hal是Android系统中的相机HAL模块,它是应用程序和相机驱动程序之间的接口。在使用相机API2拍摄RAW照片时,其流程如下: 1. 打开相机:应用程序使用相机管理器(CameraManager)打开相机设备。 2. 创建相机会话:应用程序使用相机设备的创建会话方法(createCaptureSession)创建一个用于拍摄的会话。在创建会话时,需要指定输出目标,例如预览或拍照。 3. 配置相机:应用程序使用相机设备的创建请求方法(createCaptureRequest)创建一个请求对象,并通过该对象配置相机的参数。例如,设置相机的曝光时间、ISO等参数。 4. 配置输出目标:应用程序通过请求对象的addTarget方法将输出目标与请求对象关联起来。对于RAW照片,需要将输出目标设置为ImageReader。 5. 开始预览:应用程序通过会话对象的setRepeatingRequest方法开始预览。 6. 拍照:应用程序通过请求对象的capture方法拍摄照片。 7. 获取RAW数据:当拍摄完成后,ImageReader会回调onImageAvailable方法,应用程序可以在该方法中获取RAW数据。 8. 处理RAW数据:应用程序可以将RAW数据转换为JPEG格式并保存到文件系统中,或者进行其他的处理操作。 9. 关闭会话:应用程序使用会话对象的close方法关闭会话。 10. 关闭相机:应用程序使用相机设备的close方法关闭相机。 以上就是使用相机API2拍摄RAW照片的流程,其中app-fw-hal作为相机HAL模块提供了应用程序和相机驱动程序之间的接口。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值