/* * Copyright (C) Texas Instruments - http://www.ti.com/ * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ /** * @file CameraProperties.cpp * * This file maps the CameraHardwareInterface to the Camera interfaces on OMAP4 (mainly OMX). * */ #include "CameraProperties.h" #define CAMERA_ROOT "CameraRoot" #define CAMERA_INSTANCE "CameraInstance" namespace android { // lower entries have higher priority static const char* g_camera_adapters[] = { #ifdef OMAP4_SUPPORT_OMX_CAMERA_ADAPTER "libomxcameraadapter.so", #endif #ifdef OMAP4_SUPPORT_USB_CAMERA_ADAPTER "libusbcameraadapter.so" #endif }; /********************************************************* CameraProperties - public function implemetation **********************************************************/ CameraProperties::CameraProperties() : mCamerasSupported(0) { LOG_FUNCTION_NAME; mCamerasSupported = 0; mInitialized = 0; LOG_FUNCTION_NAME_EXIT; } CameraProperties::~CameraProperties() { LOG_FUNCTION_NAME; LOG_FUNCTION_NAME_EXIT; } // Initializes the CameraProperties class status_t CameraProperties::initialize() { LOG_FUNCTION_NAME; status_t ret; Mutex::Autolock lock(mLock); if(mInitialized) return NO_ERROR; ret = loadProperties(); if (ret == NO_ERROR) { mInitialized = 1; } LOG_FUNCTION_NAME_EXIT; return ret; } extern "C" status_t CameraAdapter_Capabilities(CameraProperties::Properties* properties_array, int starting_camera, int max_camera, int & supported_cameras); ///Loads all the Camera related properties status_t CameraProperties::loadProperties() { LOG_FUNCTION_NAME; status_t ret = NO_ERROR; //Must be re-initialized here, since loadProperties() could potentially be called more than once. mCamerasSupported = 0; // adapter updates capabilities and we update camera count const status_t err = CameraAdapter_Capabilities(mCameraProps, mCamerasSupported, MAX_CAMERAS_SUPPORTED, mCamerasSupported); if(err != NO_ERROR) { CAMHAL_LOGE("error while getting capabilities"); ret = UNKNOWN_ERROR; } else if (mCamerasSupported == 0) { CAMHAL_LOGE("camera busy. properties not loaded. num_cameras = %d", mCamerasSupported); ret = UNKNOWN_ERROR; } else if (mCamerasSupported > MAX_CAMERAS_SUPPORTED) { CAMHAL_LOGE("returned too many adapaters"); ret = UNKNOWN_ERROR; } else { CAMHAL_LOGI("num_cameras = %d", mCamerasSupported); for (int i = 0; i < mCamerasSupported; i++) { mCameraProps[i].setSensorIndex(i); mCameraProps[i].dump(); } } CAMHAL_LOGV("mCamerasSupported = %d", mCamerasSupported); LOG_FUNCTION_NAME_EXIT; return ret; } // Returns the number of Cameras found int CameraProperties::camerasSupported() { LOG_FUNCTION_NAME; return mCamerasSupported; } };