summaryrefslogtreecommitdiffstats
path: root/examples/multimediawidgets/camera
diff options
context:
space:
mode:
authorLars Knoll <lars.knoll@qt.io>2021-06-11 12:49:26 +0200
committerLars Knoll <lars.knoll@qt.io>2021-06-16 10:03:03 +0200
commit9c309ede2feb598908b1476062b79d0d23759bf3 (patch)
tree29e68c3ce8698272206b4fdda78d6b3641da2a8e /examples/multimediawidgets/camera
parentfde5d6f7cce6118cac4ce7b92cd056225737917f (diff)
Get rid of QMediaEncoderSettings
As per API review, fold this class into QMediaRecorder as that's the only place where it is being used. This removes one level of indirection from the API and also makes it possible to use from QML. Change-Id: Id9157df04512382cce28e89b082433ec67d36b28 Reviewed-by: Volker Hilsheimer <volker.hilsheimer@qt.io>
Diffstat (limited to 'examples/multimediawidgets/camera')
-rw-r--r--examples/multimediawidgets/camera/camera.cpp9
-rw-r--r--examples/multimediawidgets/camera/camera.h1
-rw-r--r--examples/multimediawidgets/camera/imagesettings.h1
-rw-r--r--examples/multimediawidgets/camera/videosettings.cpp64
-rw-r--r--examples/multimediawidgets/camera/videosettings.h4
5 files changed, 33 insertions, 46 deletions
diff --git a/examples/multimediawidgets/camera/camera.cpp b/examples/multimediawidgets/camera/camera.cpp
index f45971e9f..552990496 100644
--- a/examples/multimediawidgets/camera/camera.cpp
+++ b/examples/multimediawidgets/camera/camera.cpp
@@ -192,13 +192,8 @@ void Camera::configureVideoSettings()
VideoSettings settingsDialog(m_mediaEncoder.data());
settingsDialog.setWindowFlags(settingsDialog.windowFlags() & ~Qt::WindowContextHelpButtonHint);
- settingsDialog.setEncoderSettings(m_encoderSettings);
-
- if (settingsDialog.exec()) {
- m_encoderSettings = settingsDialog.encoderSettings();
-
- m_mediaEncoder->setEncoderSettings(m_encoderSettings);
- }
+ if (settingsDialog.exec())
+ settingsDialog.applySettings();
}
void Camera::configureImageSettings()
diff --git a/examples/multimediawidgets/camera/camera.h b/examples/multimediawidgets/camera/camera.h
index 6a55f42b3..2b19dae86 100644
--- a/examples/multimediawidgets/camera/camera.h
+++ b/examples/multimediawidgets/camera/camera.h
@@ -138,7 +138,6 @@ private:
QCameraImageCapture *m_imageCapture;
QScopedPointer<QMediaRecorder> m_mediaEncoder;
- QMediaEncoderSettings m_encoderSettings;
bool m_isCapturingImage = false;
bool m_applicationExiting = false;
bool m_doImageCapture = true;
diff --git a/examples/multimediawidgets/camera/imagesettings.h b/examples/multimediawidgets/camera/imagesettings.h
index cb7691045..c155c5531 100644
--- a/examples/multimediawidgets/camera/imagesettings.h
+++ b/examples/multimediawidgets/camera/imagesettings.h
@@ -52,7 +52,6 @@
#define IMAGESETTINGS_H
#include <QDialog>
-#include <QMediaEncoderSettings>
QT_BEGIN_NAMESPACE
class QComboBox;
diff --git a/examples/multimediawidgets/camera/videosettings.cpp b/examples/multimediawidgets/camera/videosettings.cpp
index 9bc0d0ea0..22b82fb60 100644
--- a/examples/multimediawidgets/camera/videosettings.cpp
+++ b/examples/multimediawidgets/camera/videosettings.cpp
@@ -113,7 +113,26 @@ VideoSettings::VideoSettings(QMediaRecorder *mediaRecorder, QWidget *parent)
QVariant::fromValue(format));
}
- ui->qualitySlider->setRange(0, int(QMediaEncoderSettings::VeryHighQuality));
+ ui->qualitySlider->setRange(0, int(QMediaRecorder::VeryHighQuality));
+
+ QMediaFormat format = mediaRecorder->mediaFormat();
+ selectComboBoxItem(ui->containerFormatBox, QVariant::fromValue(format.fileFormat()));
+ selectComboBoxItem(ui->audioCodecBox, QVariant::fromValue(format.audioCodec()));
+ selectComboBoxItem(ui->videoCodecBox, QVariant::fromValue(format.videoCodec()));
+
+ ui->qualitySlider->setValue(mediaRecorder->quality());
+ ui->audioSampleRateBox->setValue(mediaRecorder->audioSampleRate());
+ selectComboBoxItem(ui->videoResolutionBox, QVariant(mediaRecorder->videoResolution()));
+
+ //special case for frame rate
+ for (int i = 0; i < ui->videoFramerateBox->count(); ++i) {
+ qreal itemRate = ui->videoFramerateBox->itemData(i).value<qreal>();
+ if (qFuzzyCompare(itemRate, mediaRecorder->videoFrameRate())) {
+ ui->videoFramerateBox->setCurrentIndex(i);
+ break;
+ }
+ }
+
}
VideoSettings::~VideoSettings()
@@ -133,40 +152,17 @@ void VideoSettings::changeEvent(QEvent *e)
}
}
-QMediaEncoderSettings VideoSettings::encoderSettings() const
-{
- QMediaEncoderSettings settings = mediaRecorder->encoderSettings();
- settings.setQuality(QMediaEncoderSettings::Quality(ui->qualitySlider->value()));
- settings.setFileFormat(boxValue(ui->containerFormatBox).value<QMediaFormat::FileFormat>());
-
- settings.setAudioCodec(boxValue(ui->audioCodecBox).value<QMediaFormat::AudioCodec>());
- settings.setAudioSampleRate(ui->audioSampleRateBox->value());
-
- settings.setVideoCodec(boxValue(ui->videoCodecBox).value<QMediaFormat::VideoCodec>());
- settings.setVideoResolution(boxValue(ui->videoResolutionBox).toSize());
- settings.setVideoFrameRate(boxValue(ui->videoFramerateBox).value<qreal>());
- return settings;
-}
-
-void VideoSettings::setEncoderSettings(const QMediaEncoderSettings &encoderSettings)
+void VideoSettings::applySettings()
{
- selectComboBoxItem(ui->containerFormatBox, QVariant::fromValue(encoderSettings.fileFormat()));
- ui->qualitySlider->setValue(encoderSettings.quality());
-
- selectComboBoxItem(ui->audioCodecBox, QVariant::fromValue(encoderSettings.audioCodec()));
- ui->audioSampleRateBox->setValue(encoderSettings.audioSampleRate());
-
- selectComboBoxItem(ui->videoCodecBox, QVariant::fromValue(encoderSettings.videoCodec()));
- selectComboBoxItem(ui->videoResolutionBox, QVariant(encoderSettings.videoResolution()));
-
- //special case for frame rate
- for (int i = 0; i < ui->videoFramerateBox->count(); ++i) {
- qreal itemRate = ui->videoFramerateBox->itemData(i).value<qreal>();
- if (qFuzzyCompare(itemRate, encoderSettings.videoFrameRate())) {
- ui->videoFramerateBox->setCurrentIndex(i);
- break;
- }
- }
+ QMediaFormat format;
+ format.setFileFormat(boxValue(ui->containerFormatBox).value<QMediaFormat::FileFormat>());
+ format.setAudioCodec(boxValue(ui->audioCodecBox).value<QMediaFormat::AudioCodec>());
+ format.setVideoCodec(boxValue(ui->videoCodecBox).value<QMediaFormat::VideoCodec>());
+
+ mediaRecorder->setQuality(QMediaRecorder::Quality(ui->qualitySlider->value()));
+ mediaRecorder->setAudioSampleRate(ui->audioSampleRateBox->value());
+ mediaRecorder->setVideoResolution(boxValue(ui->videoResolutionBox).toSize());
+ mediaRecorder->setVideoFrameRate(boxValue(ui->videoFramerateBox).value<qreal>());
}
QVariant VideoSettings::boxValue(const QComboBox *box) const
diff --git a/examples/multimediawidgets/camera/videosettings.h b/examples/multimediawidgets/camera/videosettings.h
index 2cb690d27..28f8ce8a7 100644
--- a/examples/multimediawidgets/camera/videosettings.h
+++ b/examples/multimediawidgets/camera/videosettings.h
@@ -52,7 +52,6 @@
#define VIDEOSETTINGS_H
#include <QDialog>
-#include <QMediaEncoderSettings>
QT_BEGIN_NAMESPACE
class QComboBox;
@@ -68,8 +67,7 @@ public:
explicit VideoSettings(QMediaRecorder *mediaRecorder, QWidget *parent = nullptr);
~VideoSettings();
- QMediaEncoderSettings encoderSettings() const;
- void setEncoderSettings(const QMediaEncoderSettings&);
+ void applySettings();
protected:
void changeEvent(QEvent *e) override;