mirror of
https://github.com/yuzu-emu/yuzu-mainline.git
synced 2024-12-12 18:34:21 +01:00
yuzu: Force camera output to be saved on a buffer (#8805)
This commit is contained in:
parent
5503d572ab
commit
db2335e2f8
@ -815,6 +815,12 @@ void GRenderWindow::InitializeCamera() {
|
|||||||
if (Settings::values.ir_sensor_device.GetValue() == cameraInfo.deviceName().toStdString() ||
|
if (Settings::values.ir_sensor_device.GetValue() == cameraInfo.deviceName().toStdString() ||
|
||||||
Settings::values.ir_sensor_device.GetValue() == "Auto") {
|
Settings::values.ir_sensor_device.GetValue() == "Auto") {
|
||||||
camera = std::make_unique<QCamera>(cameraInfo);
|
camera = std::make_unique<QCamera>(cameraInfo);
|
||||||
|
if (!camera->isCaptureModeSupported(QCamera::CaptureMode::CaptureViewfinder) &&
|
||||||
|
!camera->isCaptureModeSupported(QCamera::CaptureMode::CaptureStillImage)) {
|
||||||
|
LOG_ERROR(Frontend,
|
||||||
|
"Camera doesn't support CaptureViewfinder or CaptureStillImage");
|
||||||
|
continue;
|
||||||
|
}
|
||||||
camera_found = true;
|
camera_found = true;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
@ -825,10 +831,22 @@ void GRenderWindow::InitializeCamera() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
camera_capture = std::make_unique<QCameraImageCapture>(camera.get());
|
camera_capture = std::make_unique<QCameraImageCapture>(camera.get());
|
||||||
|
|
||||||
|
if (!camera_capture->isCaptureDestinationSupported(
|
||||||
|
QCameraImageCapture::CaptureDestination::CaptureToBuffer)) {
|
||||||
|
LOG_ERROR(Frontend, "Camera doesn't support saving to buffer");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
camera_capture->setCaptureDestination(QCameraImageCapture::CaptureDestination::CaptureToBuffer);
|
||||||
connect(camera_capture.get(), &QCameraImageCapture::imageCaptured, this,
|
connect(camera_capture.get(), &QCameraImageCapture::imageCaptured, this,
|
||||||
&GRenderWindow::OnCameraCapture);
|
&GRenderWindow::OnCameraCapture);
|
||||||
camera->unload();
|
camera->unload();
|
||||||
camera->setCaptureMode(QCamera::CaptureViewfinder);
|
if (camera->isCaptureModeSupported(QCamera::CaptureMode::CaptureViewfinder)) {
|
||||||
|
camera->setCaptureMode(QCamera::CaptureViewfinder);
|
||||||
|
} else if (camera->isCaptureModeSupported(QCamera::CaptureMode::CaptureStillImage)) {
|
||||||
|
camera->setCaptureMode(QCamera::CaptureStillImage);
|
||||||
|
}
|
||||||
camera->load();
|
camera->load();
|
||||||
camera->start();
|
camera->start();
|
||||||
|
|
||||||
|
@ -42,6 +42,12 @@ void ConfigureCamera::PreviewCamera() {
|
|||||||
LOG_INFO(Frontend, "Selected Camera {} {}", cameraInfo.description().toStdString(),
|
LOG_INFO(Frontend, "Selected Camera {} {}", cameraInfo.description().toStdString(),
|
||||||
cameraInfo.deviceName().toStdString());
|
cameraInfo.deviceName().toStdString());
|
||||||
camera = std::make_unique<QCamera>(cameraInfo);
|
camera = std::make_unique<QCamera>(cameraInfo);
|
||||||
|
if (!camera->isCaptureModeSupported(QCamera::CaptureMode::CaptureViewfinder) &&
|
||||||
|
!camera->isCaptureModeSupported(QCamera::CaptureMode::CaptureStillImage)) {
|
||||||
|
LOG_ERROR(Frontend,
|
||||||
|
"Camera doesn't support CaptureViewfinder or CaptureStillImage");
|
||||||
|
continue;
|
||||||
|
}
|
||||||
camera_found = true;
|
camera_found = true;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
@ -57,10 +63,22 @@ void ConfigureCamera::PreviewCamera() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
camera_capture = std::make_unique<QCameraImageCapture>(camera.get());
|
camera_capture = std::make_unique<QCameraImageCapture>(camera.get());
|
||||||
|
|
||||||
|
if (!camera_capture->isCaptureDestinationSupported(
|
||||||
|
QCameraImageCapture::CaptureDestination::CaptureToBuffer)) {
|
||||||
|
LOG_ERROR(Frontend, "Camera doesn't support saving to buffer");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
camera_capture->setCaptureDestination(QCameraImageCapture::CaptureDestination::CaptureToBuffer);
|
||||||
connect(camera_capture.get(), &QCameraImageCapture::imageCaptured, this,
|
connect(camera_capture.get(), &QCameraImageCapture::imageCaptured, this,
|
||||||
&ConfigureCamera::DisplayCapturedFrame);
|
&ConfigureCamera::DisplayCapturedFrame);
|
||||||
camera->unload();
|
camera->unload();
|
||||||
camera->setCaptureMode(QCamera::CaptureViewfinder);
|
if (camera->isCaptureModeSupported(QCamera::CaptureMode::CaptureViewfinder)) {
|
||||||
|
camera->setCaptureMode(QCamera::CaptureViewfinder);
|
||||||
|
} else if (camera->isCaptureModeSupported(QCamera::CaptureMode::CaptureStillImage)) {
|
||||||
|
camera->setCaptureMode(QCamera::CaptureStillImage);
|
||||||
|
}
|
||||||
camera->load();
|
camera->load();
|
||||||
camera->start();
|
camera->start();
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user