Make the FIFO Player a separate window

This way, it can be focused with the render window behind it, instead of having the main window show up and cover the render window.  This is useful for adjusting the object range, among other things.
This commit is contained in:
Pokechu22 2021-02-16 11:24:57 -08:00
parent 05bd15a928
commit 83f7c41e31
3 changed files with 27 additions and 6 deletions

View File

@ -6,9 +6,13 @@
#include <QCheckBox> #include <QCheckBox>
#include <QDialogButtonBox> #include <QDialogButtonBox>
#include <QEvent>
#include <QFileDialog> #include <QFileDialog>
#include <QGroupBox> #include <QGroupBox>
#include <QHBoxLayout> #include <QHBoxLayout>
#include <QIcon>
#include <QKeyEvent>
#include <QKeySequence>
#include <QLabel> #include <QLabel>
#include <QPushButton> #include <QPushButton>
#include <QSpinBox> #include <QSpinBox>
@ -26,12 +30,13 @@
#include "DolphinQt/FIFO/FIFOAnalyzer.h" #include "DolphinQt/FIFO/FIFOAnalyzer.h"
#include "DolphinQt/QtUtils/ModalMessageBox.h" #include "DolphinQt/QtUtils/ModalMessageBox.h"
#include "DolphinQt/QtUtils/QueueOnObject.h" #include "DolphinQt/QtUtils/QueueOnObject.h"
#include "DolphinQt/Resources.h"
#include "DolphinQt/Settings.h" #include "DolphinQt/Settings.h"
FIFOPlayerWindow::FIFOPlayerWindow(QWidget* parent) : QDialog(parent) FIFOPlayerWindow::FIFOPlayerWindow(QWidget* parent) : QWidget(parent)
{ {
setWindowTitle(tr("FIFO Player")); setWindowTitle(tr("FIFO Player"));
setWindowFlags(windowFlags() & ~Qt::WindowContextHelpButtonHint); setWindowIcon(Resources::GetAppIcon());
CreateWidgets(); CreateWidgets();
ConnectWidgets(); ConnectWidgets();
@ -56,6 +61,8 @@ FIFOPlayerWindow::FIFOPlayerWindow(QWidget* parent) : QDialog(parent)
OnEmulationStopped(); OnEmulationStopped();
m_emu_state = state; m_emu_state = state;
}); });
installEventFilter(this);
} }
FIFOPlayerWindow::~FIFOPlayerWindow() FIFOPlayerWindow::~FIFOPlayerWindow()
@ -167,7 +174,7 @@ void FIFOPlayerWindow::ConnectWidgets()
connect(m_save, &QPushButton::clicked, this, &FIFOPlayerWindow::SaveRecording); connect(m_save, &QPushButton::clicked, this, &FIFOPlayerWindow::SaveRecording);
connect(m_record, &QPushButton::clicked, this, &FIFOPlayerWindow::StartRecording); connect(m_record, &QPushButton::clicked, this, &FIFOPlayerWindow::StartRecording);
connect(m_stop, &QPushButton::clicked, this, &FIFOPlayerWindow::StopRecording); connect(m_stop, &QPushButton::clicked, this, &FIFOPlayerWindow::StopRecording);
connect(m_button_box, &QDialogButtonBox::rejected, this, &FIFOPlayerWindow::reject); connect(m_button_box, &QDialogButtonBox::rejected, this, &FIFOPlayerWindow::hide);
connect(m_early_memory_updates, &QCheckBox::toggled, this, connect(m_early_memory_updates, &QCheckBox::toggled, this,
&FIFOPlayerWindow::OnEarlyMemoryUpdatesChanged); &FIFOPlayerWindow::OnEarlyMemoryUpdatesChanged);
connect(m_frame_range_from, qOverload<int>(&QSpinBox::valueChanged), this, connect(m_frame_range_from, qOverload<int>(&QSpinBox::valueChanged), this,
@ -371,3 +378,15 @@ void FIFOPlayerWindow::UpdateControls()
m_save->setEnabled(FifoRecorder::GetInstance().IsRecordingDone()); m_save->setEnabled(FifoRecorder::GetInstance().IsRecordingDone());
} }
bool FIFOPlayerWindow::eventFilter(QObject* object, QEvent* event)
{
// Close when escape is pressed
if (event->type() == QEvent::KeyPress)
{
if (static_cast<QKeyEvent*>(event)->matches(QKeySequence::Cancel))
hide();
}
return false;
}

View File

@ -4,7 +4,7 @@
#pragma once #pragma once
#include <QDialog> #include <QWidget>
#include "Core/Core.h" #include "Core/Core.h"
@ -15,7 +15,7 @@ class QPushButton;
class QSpinBox; class QSpinBox;
class FIFOAnalyzer; class FIFOAnalyzer;
class FIFOPlayerWindow : public QDialog class FIFOPlayerWindow : public QWidget
{ {
Q_OBJECT Q_OBJECT
public: public:
@ -45,6 +45,8 @@ private:
void UpdateInfo(); void UpdateInfo();
void UpdateLimits(); void UpdateLimits();
bool eventFilter(QObject* object, QEvent* event) final override;
QLabel* m_info_label; QLabel* m_info_label;
QPushButton* m_load; QPushButton* m_load;
QPushButton* m_save; QPushButton* m_save;

View File

@ -1214,7 +1214,7 @@ void MainWindow::ShowFIFOPlayer()
{ {
if (!m_fifo_window) if (!m_fifo_window)
{ {
m_fifo_window = new FIFOPlayerWindow(this); m_fifo_window = new FIFOPlayerWindow;
connect(m_fifo_window, &FIFOPlayerWindow::LoadFIFORequested, this, connect(m_fifo_window, &FIFOPlayerWindow::LoadFIFORequested, this,
[this](const QString& path) { StartGame(path, ScanForSecondDisc::No); }); [this](const QString& path) { StartGame(path, ScanForSecondDisc::No); });
} }