mirror of
https://git.libcamera.org/libcamera/libcamera.git
synced 2025-07-13 15:29:45 +03:00
android: camera_device: Break-out request template
Currently the request template returned from CameraDevice::constructDefaultRequestSettings() is the same for all the supported template types. To prepare to adjust the template depending on the use case, break out the template generation to a dedicated function that supports the PREVIEW use case. All the other template types use the requestTemplatePreview() function and just update the capture intent property. Reviewed-by: Laurent Pinchart <laurent.pinchart@ideasonboard.com> Signed-off-by: Jacopo Mondi <jacopo@jmondi.org>
This commit is contained in:
parent
29b59a9146
commit
8a02d4451c
2 changed files with 47 additions and 36 deletions
|
@ -870,48 +870,14 @@ const camera_metadata_t *CameraDevice::getStaticMetadata()
|
|||
return staticMetadata_->get();
|
||||
}
|
||||
|
||||
/*
|
||||
* Produce a metadata pack to be used as template for a capture request.
|
||||
*/
|
||||
const camera_metadata_t *CameraDevice::constructDefaultRequestSettings(int type)
|
||||
CameraMetadata *CameraDevice::requestTemplatePreview()
|
||||
{
|
||||
auto it = requestTemplates_.find(type);
|
||||
if (it != requestTemplates_.end())
|
||||
return it->second->get();
|
||||
|
||||
/* Use the capture intent matching the requested template type. */
|
||||
uint8_t captureIntent;
|
||||
switch (type) {
|
||||
case CAMERA3_TEMPLATE_PREVIEW:
|
||||
captureIntent = ANDROID_CONTROL_CAPTURE_INTENT_PREVIEW;
|
||||
break;
|
||||
case CAMERA3_TEMPLATE_STILL_CAPTURE:
|
||||
captureIntent = ANDROID_CONTROL_CAPTURE_INTENT_STILL_CAPTURE;
|
||||
break;
|
||||
case CAMERA3_TEMPLATE_VIDEO_RECORD:
|
||||
captureIntent = ANDROID_CONTROL_CAPTURE_INTENT_VIDEO_RECORD;
|
||||
break;
|
||||
case CAMERA3_TEMPLATE_VIDEO_SNAPSHOT:
|
||||
captureIntent = ANDROID_CONTROL_CAPTURE_INTENT_VIDEO_SNAPSHOT;
|
||||
break;
|
||||
case CAMERA3_TEMPLATE_ZERO_SHUTTER_LAG:
|
||||
captureIntent = ANDROID_CONTROL_CAPTURE_INTENT_ZERO_SHUTTER_LAG;
|
||||
break;
|
||||
case CAMERA3_TEMPLATE_MANUAL:
|
||||
captureIntent = ANDROID_CONTROL_CAPTURE_INTENT_MANUAL;
|
||||
break;
|
||||
default:
|
||||
LOG(HAL, Error) << "Invalid template request type: " << type;
|
||||
return nullptr;
|
||||
}
|
||||
|
||||
/*
|
||||
* \todo Keep this in sync with the actual number of entries.
|
||||
* Currently: 12 entries, 15 bytes
|
||||
*/
|
||||
CameraMetadata *requestTemplate = new CameraMetadata(15, 20);
|
||||
if (!requestTemplate->isValid()) {
|
||||
LOG(HAL, Error) << "Failed to allocate template metadata";
|
||||
delete requestTemplate;
|
||||
return nullptr;
|
||||
}
|
||||
|
@ -960,15 +926,59 @@ const camera_metadata_t *CameraDevice::constructDefaultRequestSettings(int type)
|
|||
requestTemplate->addEntry(ANDROID_COLOR_CORRECTION_ABERRATION_MODE,
|
||||
&aberrationMode, 1);
|
||||
|
||||
uint8_t captureIntent = ANDROID_CONTROL_CAPTURE_INTENT_PREVIEW;
|
||||
requestTemplate->addEntry(ANDROID_CONTROL_CAPTURE_INTENT,
|
||||
&captureIntent, 1);
|
||||
|
||||
if (!requestTemplate->isValid()) {
|
||||
return requestTemplate;
|
||||
}
|
||||
|
||||
/*
|
||||
* Produce a metadata pack to be used as template for a capture request.
|
||||
*/
|
||||
const camera_metadata_t *CameraDevice::constructDefaultRequestSettings(int type)
|
||||
{
|
||||
auto it = requestTemplates_.find(type);
|
||||
if (it != requestTemplates_.end())
|
||||
return it->second->get();
|
||||
|
||||
/* Use the capture intent matching the requested template type. */
|
||||
CameraMetadata *requestTemplate;
|
||||
uint8_t captureIntent;
|
||||
switch (type) {
|
||||
case CAMERA3_TEMPLATE_PREVIEW:
|
||||
captureIntent = ANDROID_CONTROL_CAPTURE_INTENT_PREVIEW;
|
||||
break;
|
||||
case CAMERA3_TEMPLATE_STILL_CAPTURE:
|
||||
captureIntent = ANDROID_CONTROL_CAPTURE_INTENT_STILL_CAPTURE;
|
||||
break;
|
||||
case CAMERA3_TEMPLATE_VIDEO_RECORD:
|
||||
captureIntent = ANDROID_CONTROL_CAPTURE_INTENT_VIDEO_RECORD;
|
||||
break;
|
||||
case CAMERA3_TEMPLATE_VIDEO_SNAPSHOT:
|
||||
captureIntent = ANDROID_CONTROL_CAPTURE_INTENT_VIDEO_SNAPSHOT;
|
||||
break;
|
||||
case CAMERA3_TEMPLATE_ZERO_SHUTTER_LAG:
|
||||
captureIntent = ANDROID_CONTROL_CAPTURE_INTENT_ZERO_SHUTTER_LAG;
|
||||
break;
|
||||
case CAMERA3_TEMPLATE_MANUAL:
|
||||
captureIntent = ANDROID_CONTROL_CAPTURE_INTENT_MANUAL;
|
||||
break;
|
||||
default:
|
||||
LOG(HAL, Error) << "Invalid template request type: " << type;
|
||||
return nullptr;
|
||||
}
|
||||
|
||||
requestTemplate = requestTemplatePreview();
|
||||
if (!requestTemplate || !requestTemplate->isValid()) {
|
||||
LOG(HAL, Error) << "Failed to construct request template";
|
||||
delete requestTemplate;
|
||||
return nullptr;
|
||||
}
|
||||
|
||||
requestTemplate->updateEntry(ANDROID_CONTROL_CAPTURE_INTENT,
|
||||
&captureIntent, 1);
|
||||
|
||||
requestTemplates_[type] = requestTemplate;
|
||||
return requestTemplate->get();
|
||||
}
|
||||
|
|
|
@ -83,6 +83,7 @@ private:
|
|||
libcamera::FrameBuffer *createFrameBuffer(const buffer_handle_t camera3buffer);
|
||||
void notifyShutter(uint32_t frameNumber, uint64_t timestamp);
|
||||
void notifyError(uint32_t frameNumber, camera3_stream_t *stream);
|
||||
CameraMetadata *requestTemplatePreview();
|
||||
libcamera::PixelFormat toPixelFormat(int format);
|
||||
std::unique_ptr<CameraMetadata> getResultMetadata(int frame_number,
|
||||
int64_t timestamp);
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue