Skip to content

Commit

Permalink
AdvancedWidget: Change codec selection to a choice and add UTVideo.
Browse files Browse the repository at this point in the history
UTVideo was requrested by users based on its compatibility with video editing programs.
  • Loading branch information
TryTwo committed Dec 25, 2024
1 parent f9ce2b9 commit 8c1cd5e
Show file tree
Hide file tree
Showing 2 changed files with 58 additions and 11 deletions.
64 changes: 53 additions & 11 deletions Source/Core/DolphinQt/Config/Graphics/AdvancedWidget.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -37,6 +37,9 @@ AdvancedWidget::AdvancedWidget(GraphicsWindow* parent)
});
connect(m_manual_texture_sampling, &QCheckBox::toggled,
[this, parent] { emit parent->UseFastTextureSamplingChanged(); });
#if defined(HAVE_FFMPEG)
connect(&Settings::Instance(), &Settings::ConfigChanged, this, &AdvancedWidget::EnableBitrate);
#endif

OnBackendChanged();
OnEmulationStateChanged(!Core::IsUninitialized(Core::System::GetInstance()));
Expand All @@ -51,6 +54,10 @@ AdvancedWidget::AdvancedWidget(GameConfigWidget* parent, Config::Layer* layer) :
connect(&Settings::Instance(), &Settings::EmulationStateChanged, this, [this](Core::State state) {
OnEmulationStateChanged(state != Core::State::Uninitialized);
});
#if defined(HAVE_FFMPEG)
connect(&Settings::Instance(), &Settings::ConfigChanged, this, &AdvancedWidget::EnableBitrate);
#endif

OnEmulationStateChanged(Core::GetState(Core::System::GetInstance()) !=
Core::State::Uninitialized);
}
Expand Down Expand Up @@ -185,13 +192,23 @@ void AdvancedWidget::CreateWidgets()
dump_layout->addWidget(m_frame_dumps_resolution_type, 0, 1);

#if defined(HAVE_FFMPEG)
m_dump_use_ffv1 =
new ConfigBool(tr("Use Lossless Codec (FFV1)"), Config::GFX_USE_FFV1, m_game_layer);
// Update EnableBitrate() if options are changed.
const std::vector<std::pair<QString, QString>> options{
{tr("Auto"), QStringLiteral("")},
{QStringLiteral("Xvid"), QStringLiteral("mpeg4")},
{QStringLiteral("Ut Video"), QStringLiteral("utvideo")},
{QStringLiteral("FFV1"), QStringLiteral("ffv1")}};

m_codec_choice = new ConfigStringChoice(options, Config::GFX_DUMP_CODEC, m_game_layer);

dump_layout->addWidget(new QLabel(tr("Codec:")), 1, 0);
dump_layout->addWidget(m_codec_choice, 1, 1);

m_dump_bitrate = new ConfigInteger(0, 1000000, Config::GFX_BITRATE_KBPS, m_game_layer, 1000);
m_dump_bitrate->setEnabled(!m_dump_use_ffv1->isChecked());
dump_layout->addWidget(m_dump_use_ffv1, 1, 0);
dump_layout->addWidget(new QLabel(tr("Bitrate (kbps):")), 2, 0);
dump_layout->addWidget(m_dump_bitrate, 2, 1);

EnableBitrate();
#endif

dump_layout->addWidget(new QLabel(tr("PNG Compression Level:")), 3, 0);
Expand Down Expand Up @@ -261,12 +278,33 @@ void AdvancedWidget::ConnectWidgets()
});
connect(m_enable_graphics_mods, &QCheckBox::toggled, this,
[this](bool checked) { emit Settings::Instance().EnableGfxModsChanged(checked); });
}

#if defined(HAVE_FFMPEG)
connect(m_dump_use_ffv1, &QCheckBox::toggled, this,
[this](bool checked) { m_dump_bitrate->setEnabled(!checked); });
#endif
void AdvancedWidget::EnableBitrate()
{
if (m_codec_choice->currentIndex() == -1)
m_codec_choice->setCurrentIndex(Config::Get(Config::GFX_USE_FFV1) ? 3 : 0);

const QString& choice = m_codec_choice->currentText();
const bool enable = choice != QStringLiteral("Ut Video") && choice != QStringLiteral("FFV1");

if (m_game_layer)
{
m_dump_bitrate->setEnabled(enable);
return;
}

// Toggle off depreciated "Use FFV1" option, so it doesn't collide.
if (Config::Get(Config::GFX_USE_FFV1))
{
auto layer = Config::GetActiveLayerForConfig(Config::GFX_USE_FFV1);
Config::Set(layer, Config::GFX_USE_FFV1, false);
}

m_dump_bitrate->setEnabled(enable);
}
#endif

void AdvancedWidget::OnBackendChanged()
{
Expand Down Expand Up @@ -391,9 +429,13 @@ void AdvancedWidget::AddDescriptions()
"possible input for external editing software.<br><br><dolphin_emphasis>If unsure, leave "
"this at \"Aspect Ratio Corrected Internal Resolution\".</dolphin_emphasis>");
#if defined(HAVE_FFMPEG)
static const char TR_USE_FFV1_DESCRIPTION[] =
QT_TR_NOOP("Encodes frame dumps using the FFV1 codec.<br><br><dolphin_emphasis>If "
"unsure, leave this unchecked.</dolphin_emphasis>");
static const char TR_CODEC_CHOICE_DESCRIPTION[] =
QT_TR_NOOP("Selects codec for encoding frame dumps."
"<br><br><b>Xvid</b>: Lossy. High Compression. Can set bitrate."
"<br><b>Ut Video</b>: Lossless. Fast. Low compression (large file size). Good "
"compatibility with editing programs."
"<br><b>FFV1</b>: Lossless. Slow. High compression. Poor compatibility."
"<br><br><dolphin_emphasis>If unsure, choose Xvid.</dolphin_emphasis>");
#endif
static const char TR_PNG_COMPRESSION_LEVEL_DESCRIPTION[] =
QT_TR_NOOP("Specifies the zlib compression level to use when saving PNG images (both for "
Expand Down Expand Up @@ -483,7 +525,7 @@ void AdvancedWidget::AddDescriptions()
m_enable_graphics_mods->SetDescription(tr(TR_LOAD_GRAPHICS_MODS_DESCRIPTION));
m_frame_dumps_resolution_type->SetDescription(tr(TR_FRAME_DUMPS_RESOLUTION_TYPE_DESCRIPTION));
#ifdef HAVE_FFMPEG
m_dump_use_ffv1->SetDescription(tr(TR_USE_FFV1_DESCRIPTION));
m_codec_choice->SetDescription(tr(TR_CODEC_CHOICE_DESCRIPTION));
#endif
m_png_compression_level->SetDescription(tr(TR_PNG_COMPRESSION_LEVEL_DESCRIPTION));
m_enable_cropping->SetDescription(tr(TR_CROPPING_DESCRIPTION));
Expand Down
5 changes: 5 additions & 0 deletions Source/Core/DolphinQt/Config/Graphics/AdvancedWidget.h
Original file line number Diff line number Diff line change
Expand Up @@ -8,6 +8,7 @@
class ConfigBool;
class ConfigChoice;
class ConfigInteger;
class ConfigStringChoice;
class GameConfigWidget;
class GraphicsWindow;

Expand All @@ -27,6 +28,9 @@ class AdvancedWidget final : public QWidget
void CreateWidgets();
void ConnectWidgets();
void AddDescriptions();
#if defined(HAVE_FFMPEG)
void EnableBitrate();
#endif
void OnBackendChanged();
void OnEmulationStateChanged(bool running);

Expand Down Expand Up @@ -62,6 +66,7 @@ class AdvancedWidget final : public QWidget
// Frame dumping
ConfigBool* m_dump_use_ffv1;
ConfigChoice* m_frame_dumps_resolution_type;
ConfigStringChoice* m_codec_choice;
ConfigInteger* m_dump_bitrate;
ConfigInteger* m_png_compression_level;

Expand Down

0 comments on commit 8c1cd5e

Please sign in to comment.