|
|
@ -1880,6 +1880,12 @@ void NdkCamera::onCaptureCompleted(ACameraCaptureSession* session, ACaptureReque
|
|
|
|
|
|
|
|
|
|
|
|
if (m_params.customHdr)
|
|
|
|
if (m_params.customHdr)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
|
|
|
|
int32_t compensation = m_params.compensation;
|
|
|
|
|
|
|
|
if (compensation == 0)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
compensation = 1;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
val = { 0 };
|
|
|
|
val = { 0 };
|
|
|
|
status = ACameraMetadata_getConstEntry(result, ACAMERA_SENSOR_EXPOSURE_TIME, &val);
|
|
|
|
status = ACameraMetadata_getConstEntry(result, ACAMERA_SENSOR_EXPOSURE_TIME, &val);
|
|
|
|
int64_t exTime = (status == ACAMERA_OK) ? val.data.i64[0] : -1;
|
|
|
|
int64_t exTime = (status == ACAMERA_OK) ? val.data.i64[0] : -1;
|
|
|
@ -1897,7 +1903,7 @@ void NdkCamera::onCaptureCompleted(ACameraCaptureSession* session, ACaptureReque
|
|
|
|
for (int idx = 0; idx < burstCaptures; idx++)
|
|
|
|
for (int idx = 0; idx < burstCaptures; idx++)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
ACaptureRequest_setEntry_u8(requests[idx], ACAMERA_CONTROL_AE_MODE, 1, &aeModeOff);
|
|
|
|
ACaptureRequest_setEntry_u8(requests[idx], ACAMERA_CONTROL_AE_MODE, 1, &aeModeOff);
|
|
|
|
int64_t expt = exTime * (idx + 1);
|
|
|
|
int64_t expt = exTime * ((idx == 0) ? 1 : (compensation + idx));
|
|
|
|
ACaptureRequest_setEntry_i64(requests[idx], ACAMERA_SENSOR_EXPOSURE_TIME, 1, &expt);
|
|
|
|
ACaptureRequest_setEntry_i64(requests[idx], ACAMERA_SENSOR_EXPOSURE_TIME, 1, &expt);
|
|
|
|
ACaptureRequest_setEntry_i32(requests[idx], ACAMERA_SENSOR_SENSITIVITY, 1, &sensitivity);
|
|
|
|
ACaptureRequest_setEntry_i32(requests[idx], ACAMERA_SENSOR_SENSITIVITY, 1, &sensitivity);
|
|
|
|
sensitivity = sensitivityRange.min_;
|
|
|
|
sensitivity = sensitivityRange.min_;
|
|
|
|