HostInterface: Add a ConfirmMessage() method

This commit is contained in:
Connor McLaughlin 2020-02-26 19:25:57 +10:00
parent 8ffdcf1b7e
commit e9dea6e0f7
8 changed files with 62 additions and 3 deletions

View File

@ -160,6 +160,12 @@ void HostInterface::ReportMessage(const char* message)
Log_InfoPrintf(message); Log_InfoPrintf(message);
} }
bool HostInterface::ConfirmMessage(const char* message)
{
Log_WarningPrintf("ConfirmMessage(\"%s\") -> Yes");
return true;
}
void HostInterface::ReportFormattedError(const char* format, ...) void HostInterface::ReportFormattedError(const char* format, ...)
{ {
std::va_list ap; std::va_list ap;
@ -180,6 +186,16 @@ void HostInterface::ReportFormattedMessage(const char* format, ...)
ReportMessage(message.c_str()); ReportMessage(message.c_str());
} }
bool HostInterface::ConfirmFormattedMessage(const char* format, ...)
{
std::va_list ap;
va_start(ap, format);
std::string message = StringUtil::StdStringFromFormatV(format, ap);
va_end(ap);
return ConfirmMessage(message.c_str());
}
void HostInterface::DrawFPSWindow() void HostInterface::DrawFPSWindow()
{ {
const bool show_fps = true; const bool show_fps = true;

View File

@ -68,9 +68,11 @@ public:
virtual void ReportError(const char* message); virtual void ReportError(const char* message);
virtual void ReportMessage(const char* message); virtual void ReportMessage(const char* message);
virtual bool ConfirmMessage(const char* message);
void ReportFormattedError(const char* format, ...); void ReportFormattedError(const char* format, ...);
void ReportFormattedMessage(const char* format, ...); void ReportFormattedMessage(const char* format, ...);
bool ConfirmFormattedMessage(const char* format, ...);
/// Adds OSD messages, duration is in seconds. /// Adds OSD messages, duration is in seconds.
void AddOSDMessage(const char* message, float duration = 2.0f); void AddOSDMessage(const char* message, float duration = 2.0f);

View File

@ -35,7 +35,7 @@ MainWindow::~MainWindow()
void MainWindow::reportError(const QString& message) void MainWindow::reportError(const QString& message)
{ {
QMessageBox::critical(nullptr, tr("DuckStation Error"), message, QMessageBox::Ok); QMessageBox::critical(this, tr("DuckStation"), message, QMessageBox::Ok);
} }
void MainWindow::reportMessage(const QString& message) void MainWindow::reportMessage(const QString& message)
@ -43,6 +43,11 @@ void MainWindow::reportMessage(const QString& message)
m_ui.statusBar->showMessage(message, 2000); m_ui.statusBar->showMessage(message, 2000);
} }
bool MainWindow::confirmMessage(const QString& message)
{
return (QMessageBox::question(this, tr("DuckStation"), message) == QMessageBox::Yes);
}
void MainWindow::createDisplayWindow(QThread* worker_thread, bool use_debug_device) void MainWindow::createDisplayWindow(QThread* worker_thread, bool use_debug_device)
{ {
DebugAssert(!m_display_widget); DebugAssert(!m_display_widget);
@ -336,12 +341,14 @@ void MainWindow::connectSignals()
connect(m_host_interface, &QtHostInterface::errorReported, this, &MainWindow::reportError, connect(m_host_interface, &QtHostInterface::errorReported, this, &MainWindow::reportError,
Qt::BlockingQueuedConnection); Qt::BlockingQueuedConnection);
connect(m_host_interface, &QtHostInterface::messageReported, this, &MainWindow::reportMessage);
connect(m_host_interface, &QtHostInterface::messageConfirmed, this, &MainWindow::confirmMessage,
Qt::BlockingQueuedConnection);
connect(m_host_interface, &QtHostInterface::createDisplayWindowRequested, this, &MainWindow::createDisplayWindow, connect(m_host_interface, &QtHostInterface::createDisplayWindowRequested, this, &MainWindow::createDisplayWindow,
Qt::BlockingQueuedConnection); Qt::BlockingQueuedConnection);
connect(m_host_interface, &QtHostInterface::destroyDisplayWindowRequested, this, &MainWindow::destroyDisplayWindow); connect(m_host_interface, &QtHostInterface::destroyDisplayWindowRequested, this, &MainWindow::destroyDisplayWindow);
connect(m_host_interface, &QtHostInterface::setFullscreenRequested, this, &MainWindow::setFullscreen); connect(m_host_interface, &QtHostInterface::setFullscreenRequested, this, &MainWindow::setFullscreen);
connect(m_host_interface, &QtHostInterface::toggleFullscreenRequested, this, &MainWindow::toggleFullscreen); connect(m_host_interface, &QtHostInterface::toggleFullscreenRequested, this, &MainWindow::toggleFullscreen);
connect(m_host_interface, &QtHostInterface::messageReported, this, &MainWindow::reportMessage);
connect(m_host_interface, &QtHostInterface::emulationStarted, this, &MainWindow::onEmulationStarted); connect(m_host_interface, &QtHostInterface::emulationStarted, this, &MainWindow::onEmulationStarted);
connect(m_host_interface, &QtHostInterface::emulationStopped, this, &MainWindow::onEmulationStopped); connect(m_host_interface, &QtHostInterface::emulationStopped, this, &MainWindow::onEmulationStopped);
connect(m_host_interface, &QtHostInterface::emulationPaused, this, &MainWindow::onEmulationPaused); connect(m_host_interface, &QtHostInterface::emulationPaused, this, &MainWindow::onEmulationPaused);

View File

@ -24,6 +24,7 @@ public:
private Q_SLOTS: private Q_SLOTS:
void reportError(const QString& message); void reportError(const QString& message);
void reportMessage(const QString& message); void reportMessage(const QString& message);
bool confirmMessage(const QString& message);
void createDisplayWindow(QThread* worker_thread, bool use_debug_device); void createDisplayWindow(QThread* worker_thread, bool use_debug_device);
void destroyDisplayWindow(); void destroyDisplayWindow();
void setFullscreen(bool fullscreen); void setFullscreen(bool fullscreen);

View File

@ -54,6 +54,11 @@ void QtHostInterface::ReportMessage(const char* message)
emit messageReported(QString::fromLocal8Bit(message)); emit messageReported(QString::fromLocal8Bit(message));
} }
bool QtHostInterface::ConfirmMessage(const char* message)
{
return messageConfirmed(QString::fromLocal8Bit(message));
}
void QtHostInterface::setDefaultSettings() void QtHostInterface::setDefaultSettings()
{ {
HostInterface::UpdateSettings([this]() { HostInterface::SetDefaultSettings(); }); HostInterface::UpdateSettings([this]() { HostInterface::SetDefaultSettings(); });

View File

@ -32,6 +32,7 @@ public:
void ReportError(const char* message) override; void ReportError(const char* message) override;
void ReportMessage(const char* message) override; void ReportMessage(const char* message) override;
bool ConfirmMessage(const char* message) override;
void setDefaultSettings(); void setDefaultSettings();
@ -64,6 +65,7 @@ public:
Q_SIGNALS: Q_SIGNALS:
void errorReported(const QString& message); void errorReported(const QString& message);
void messageReported(const QString& message); void messageReported(const QString& message);
bool messageConfirmed(const QString& message);
void emulationStarted(); void emulationStarted();
void emulationStopped(); void emulationStopped();
void emulationPaused(bool paused); void emulationPaused(bool paused);

View File

@ -259,7 +259,7 @@ std::unique_ptr<SDLHostInterface> SDLHostInterface::Create()
void SDLHostInterface::ReportError(const char* message) void SDLHostInterface::ReportError(const char* message)
{ {
SDL_ShowSimpleMessageBox(SDL_MESSAGEBOX_ERROR, "DuckStation Error", message, m_window); SDL_ShowSimpleMessageBox(SDL_MESSAGEBOX_ERROR, "DuckStation", message, m_window);
} }
void SDLHostInterface::ReportMessage(const char* message) void SDLHostInterface::ReportMessage(const char* message)
@ -267,6 +267,31 @@ void SDLHostInterface::ReportMessage(const char* message)
AddOSDMessage(message, 2.0f); AddOSDMessage(message, 2.0f);
} }
bool SDLHostInterface::ConfirmMessage(const char* message)
{
SDL_MessageBoxData mbd = {};
mbd.flags = SDL_MESSAGEBOX_INFORMATION;
mbd.window = m_window;
mbd.title = "DuckStation";
mbd.message = message;
mbd.numbuttons = 2;
// Why the heck these are reversed I have no idea...
SDL_MessageBoxButtonData buttons[2] = {};
buttons[1].flags = SDL_MESSAGEBOX_BUTTON_ESCAPEKEY_DEFAULT;
buttons[1].buttonid = 0;
buttons[1].text = "Yes";
buttons[0].flags = SDL_MESSAGEBOX_BUTTON_RETURNKEY_DEFAULT;
buttons[0].buttonid = 1;
buttons[0].text = "No";
mbd.buttons = buttons;
mbd.numbuttons = countof(buttons);
int button_id = 0;
SDL_ShowMessageBox(&mbd, &button_id);
return (button_id == 0);
}
void SDLHostInterface::HandleSDLEvent(const SDL_Event* event) void SDLHostInterface::HandleSDLEvent(const SDL_Event* event)
{ {
ImGui_ImplSDL2_ProcessEvent(event); ImGui_ImplSDL2_ProcessEvent(event);

View File

@ -26,6 +26,7 @@ public:
void ReportError(const char* message) override; void ReportError(const char* message) override;
void ReportMessage(const char* message) override; void ReportMessage(const char* message) override;
bool ConfirmMessage(const char* message) override;
void Run(); void Run();