2018-05-11 19:42:23 +02:00
|
|
|
// Copyright 2018 Citra Emulator Project
|
|
|
|
// Licensed under GPLv2 or any later version
|
|
|
|
// Refer to the license.txt file included.
|
|
|
|
|
|
|
|
#include <QFileDialog>
|
|
|
|
#include <QImageReader>
|
|
|
|
#include <QMessageBox>
|
|
|
|
#include "citra_qt/camera/still_image_camera.h"
|
|
|
|
|
|
|
|
namespace Camera {
|
|
|
|
|
2018-05-20 03:07:37 +02:00
|
|
|
StillImageCamera::StillImageCamera(QImage image_, const Service::CAM::Flip& flip)
|
|
|
|
: image(std::move(image_)) {
|
|
|
|
using namespace Service::CAM;
|
|
|
|
flip_horizontal = basic_flip_horizontal = (flip == Flip::Horizontal) || (flip == Flip::Reverse);
|
|
|
|
flip_vertical = basic_flip_vertical = (flip == Flip::Vertical) || (flip == Flip::Reverse);
|
|
|
|
}
|
2018-05-11 19:42:23 +02:00
|
|
|
|
|
|
|
void StillImageCamera::StartCapture() {}
|
|
|
|
|
|
|
|
void StillImageCamera::StopCapture() {}
|
|
|
|
|
|
|
|
void StillImageCamera::SetFormat(Service::CAM::OutputFormat output_format) {
|
|
|
|
output_rgb = output_format == Service::CAM::OutputFormat::RGB565;
|
|
|
|
}
|
|
|
|
|
|
|
|
void StillImageCamera::SetResolution(const Service::CAM::Resolution& resolution) {
|
|
|
|
width = resolution.width;
|
|
|
|
height = resolution.height;
|
|
|
|
}
|
|
|
|
|
|
|
|
void StillImageCamera::SetFlip(Service::CAM::Flip flip) {
|
|
|
|
using namespace Service::CAM;
|
2018-05-20 03:07:37 +02:00
|
|
|
flip_horizontal = basic_flip_horizontal ^ (flip == Flip::Horizontal || flip == Flip::Reverse);
|
|
|
|
flip_vertical = basic_flip_vertical ^ (flip == Flip::Vertical || flip == Flip::Reverse);
|
2018-05-11 19:42:23 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
void StillImageCamera::SetEffect(Service::CAM::Effect effect) {
|
|
|
|
if (effect != Service::CAM::Effect::None) {
|
|
|
|
NGLOG_ERROR(Service_CAM, "Unimplemented effect {}", static_cast<int>(effect));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
std::vector<u16> StillImageCamera::ReceiveFrame() {
|
|
|
|
return CameraUtil::ProcessImage(image, width, height, output_rgb, flip_horizontal,
|
|
|
|
flip_vertical);
|
|
|
|
}
|
|
|
|
|
|
|
|
bool StillImageCamera::IsPreviewAvailable() {
|
|
|
|
return !image.isNull();
|
|
|
|
}
|
|
|
|
|
|
|
|
const std::string StillImageCameraFactory::getFilePath() {
|
|
|
|
QList<QByteArray> types = QImageReader::supportedImageFormats();
|
|
|
|
QList<QString> temp_filters;
|
|
|
|
for (QByteArray type : types) {
|
|
|
|
temp_filters << QString("*." + QString(type));
|
|
|
|
}
|
|
|
|
|
2018-05-19 11:03:06 +02:00
|
|
|
QString filter = QObject::tr("Supported image files (%1)").arg(temp_filters.join(" "));
|
2018-05-11 19:42:23 +02:00
|
|
|
|
|
|
|
return QFileDialog::getOpenFileName(nullptr, QObject::tr("Open File"), ".", filter)
|
|
|
|
.toStdString();
|
|
|
|
}
|
|
|
|
|
2018-05-20 03:07:37 +02:00
|
|
|
std::unique_ptr<CameraInterface> StillImageCameraFactory::Create(
|
|
|
|
const std::string& config, const Service::CAM::Flip& flip) const {
|
2018-05-11 19:42:23 +02:00
|
|
|
std::string real_config = config;
|
|
|
|
if (config.empty()) {
|
|
|
|
real_config = getFilePath();
|
|
|
|
}
|
|
|
|
QImage image(QString::fromStdString(real_config));
|
|
|
|
if (image.isNull()) {
|
|
|
|
NGLOG_ERROR(Service_CAM, "Couldn't load image \"{}\"", real_config.c_str());
|
|
|
|
}
|
2018-05-20 03:07:37 +02:00
|
|
|
return std::make_unique<StillImageCamera>(image, flip);
|
2018-05-11 19:42:23 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
} // namespace Camera
|