From 754fb0225369123ef6e369fd91c48071dcf6057c Mon Sep 17 00:00:00 2001 From: Yin-Chia Yeh Date: Thu, 21 Aug 2014 09:17:35 -0700 Subject: camera: zsl: remove AF check if no focser presents If there is no focuser, don't check AF state while picking ZSL candidate frames. bug 17164077 Change-Id: Ib56e260249dcfb1b3bafea22abeb3abeae4e2c1a --- .../api1/client2/ZslProcessor3.cpp | 39 +++++++++++++--------- .../libcameraservice/api1/client2/ZslProcessor3.h | 2 ++ 2 files changed, 26 insertions(+), 15 deletions(-) (limited to 'services/camera/libcameraservice/api1/client2') diff --git a/services/camera/libcameraservice/api1/client2/ZslProcessor3.cpp b/services/camera/libcameraservice/api1/client2/ZslProcessor3.cpp index 37de610..b388079 100644 --- a/services/camera/libcameraservice/api1/client2/ZslProcessor3.cpp +++ b/services/camera/libcameraservice/api1/client2/ZslProcessor3.cpp @@ -51,7 +51,8 @@ ZslProcessor3::ZslProcessor3( mZslStreamId(NO_STREAM), mFrameListHead(0), mZslQueueHead(0), - mZslQueueTail(0) { + mZslQueueTail(0), + mHasFocuser(false) { // Initialize buffer queue and frame list based on pipeline max depth. size_t pipelineMaxDepth = kDefaultMaxPipelineDepth; if (client != 0) { @@ -67,6 +68,11 @@ ZslProcessor3::ZslProcessor3( " use default pipeline max depth %zu", __FUNCTION__, kDefaultMaxPipelineDepth); } + + entry = device->info().find(ANDROID_LENS_INFO_MINIMUM_FOCUS_DISTANCE); + if (entry.count > 0 && entry.data.f[0] != 0.) { + mHasFocuser = true; + } } } @@ -489,20 +495,23 @@ nsecs_t ZslProcessor3::getCandidateTimestampLocked(size_t* metadataIdx) const { continue; } - // Make sure the candidate frame has good focus. - entry = frame.find(ANDROID_CONTROL_AF_STATE); - if (entry.count == 0) { - ALOGW("%s: ZSL queue frame has no AF state field!", - __FUNCTION__); - continue; - } - uint8_t afState = entry.data.u8[0]; - if (afState != ANDROID_CONTROL_AF_STATE_PASSIVE_FOCUSED && - afState != ANDROID_CONTROL_AF_STATE_FOCUSED_LOCKED && - afState != ANDROID_CONTROL_AF_STATE_NOT_FOCUSED_LOCKED) { - ALOGW("%s: ZSL queue frame AF state is %d is not good for capture, skip it", - __FUNCTION__, afState); - continue; + // Check AF state if device has focuser + if (mHasFocuser) { + // Make sure the candidate frame has good focus. + entry = frame.find(ANDROID_CONTROL_AF_STATE); + if (entry.count == 0) { + ALOGW("%s: ZSL queue frame has no AF state field!", + __FUNCTION__); + continue; + } + uint8_t afState = entry.data.u8[0]; + if (afState != ANDROID_CONTROL_AF_STATE_PASSIVE_FOCUSED && + afState != ANDROID_CONTROL_AF_STATE_FOCUSED_LOCKED && + afState != ANDROID_CONTROL_AF_STATE_NOT_FOCUSED_LOCKED) { + ALOGW("%s: ZSL queue frame AF state is %d is not good for capture, skip it", + __FUNCTION__, afState); + continue; + } } minTimestamp = frameTimestamp; diff --git a/services/camera/libcameraservice/api1/client2/ZslProcessor3.h b/services/camera/libcameraservice/api1/client2/ZslProcessor3.h index dfb1457..daa352b 100644 --- a/services/camera/libcameraservice/api1/client2/ZslProcessor3.h +++ b/services/camera/libcameraservice/api1/client2/ZslProcessor3.h @@ -121,6 +121,8 @@ class ZslProcessor3 : CameraMetadata mLatestCapturedRequest; + bool mHasFocuser; + virtual bool threadLoop(); status_t clearZslQueueLocked(); -- cgit v1.1