mirror of
https://git.libcamera.org/libcamera/libcamera.git
synced 2025-07-13 23:39:44 +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();
|
return staticMetadata_->get();
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
CameraMetadata *CameraDevice::requestTemplatePreview()
|
||||||
* 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. */
|
|
||||||
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.
|
* \todo Keep this in sync with the actual number of entries.
|
||||||
* Currently: 12 entries, 15 bytes
|
* Currently: 12 entries, 15 bytes
|
||||||
*/
|
*/
|
||||||
CameraMetadata *requestTemplate = new CameraMetadata(15, 20);
|
CameraMetadata *requestTemplate = new CameraMetadata(15, 20);
|
||||||
if (!requestTemplate->isValid()) {
|
if (!requestTemplate->isValid()) {
|
||||||
LOG(HAL, Error) << "Failed to allocate template metadata";
|
|
||||||
delete requestTemplate;
|
delete requestTemplate;
|
||||||
return nullptr;
|
return nullptr;
|
||||||
}
|
}
|
||||||
|
@ -960,15 +926,59 @@ const camera_metadata_t *CameraDevice::constructDefaultRequestSettings(int type)
|
||||||
requestTemplate->addEntry(ANDROID_COLOR_CORRECTION_ABERRATION_MODE,
|
requestTemplate->addEntry(ANDROID_COLOR_CORRECTION_ABERRATION_MODE,
|
||||||
&aberrationMode, 1);
|
&aberrationMode, 1);
|
||||||
|
|
||||||
|
uint8_t captureIntent = ANDROID_CONTROL_CAPTURE_INTENT_PREVIEW;
|
||||||
requestTemplate->addEntry(ANDROID_CONTROL_CAPTURE_INTENT,
|
requestTemplate->addEntry(ANDROID_CONTROL_CAPTURE_INTENT,
|
||||||
&captureIntent, 1);
|
&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";
|
LOG(HAL, Error) << "Failed to construct request template";
|
||||||
delete requestTemplate;
|
delete requestTemplate;
|
||||||
return nullptr;
|
return nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
requestTemplate->updateEntry(ANDROID_CONTROL_CAPTURE_INTENT,
|
||||||
|
&captureIntent, 1);
|
||||||
|
|
||||||
requestTemplates_[type] = requestTemplate;
|
requestTemplates_[type] = requestTemplate;
|
||||||
return requestTemplate->get();
|
return requestTemplate->get();
|
||||||
}
|
}
|
||||||
|
|
|
@ -83,6 +83,7 @@ private:
|
||||||
libcamera::FrameBuffer *createFrameBuffer(const buffer_handle_t camera3buffer);
|
libcamera::FrameBuffer *createFrameBuffer(const buffer_handle_t camera3buffer);
|
||||||
void notifyShutter(uint32_t frameNumber, uint64_t timestamp);
|
void notifyShutter(uint32_t frameNumber, uint64_t timestamp);
|
||||||
void notifyError(uint32_t frameNumber, camera3_stream_t *stream);
|
void notifyError(uint32_t frameNumber, camera3_stream_t *stream);
|
||||||
|
CameraMetadata *requestTemplatePreview();
|
||||||
libcamera::PixelFormat toPixelFormat(int format);
|
libcamera::PixelFormat toPixelFormat(int format);
|
||||||
std::unique_ptr<CameraMetadata> getResultMetadata(int frame_number,
|
std::unique_ptr<CameraMetadata> getResultMetadata(int frame_number,
|
||||||
int64_t timestamp);
|
int64_t timestamp);
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue