From 1a5e0c20841e5f207200de47e7ad7138feddfe40 Mon Sep 17 00:00:00 2001 From: JosJuice Date: Sun, 19 Sep 2021 17:08:10 +0200 Subject: [PATCH] DolphinQt: Reduce latency of TAS input's controller input passthrough Fixes https://bugs.dolphin-emu.org/issues/12676. Needs testing to see if this impacts performance when controller inputs are changing. --- Source/Core/DolphinQt/QtUtils/QueueOnObject.h | 8 ++++++++ Source/Core/DolphinQt/TAS/TASInputWindow.cpp | 12 ++++++++---- 2 files changed, 16 insertions(+), 4 deletions(-) diff --git a/Source/Core/DolphinQt/QtUtils/QueueOnObject.h b/Source/Core/DolphinQt/QtUtils/QueueOnObject.h index 7441444f7a..9a38950332 100644 --- a/Source/Core/DolphinQt/QtUtils/QueueOnObject.h +++ b/Source/Core/DolphinQt/QtUtils/QueueOnObject.h @@ -17,3 +17,11 @@ static void QueueOnObject(T* obj, F&& func) QObject src; QObject::connect(&src, &QObject::destroyed, obj, std::forward(func), Qt::QueuedConnection); } + +template +static void QueueOnObjectBlocking(T* obj, F&& func) +{ + QObject src; + QObject::connect(&src, &QObject::destroyed, obj, std::forward(func), + Qt::BlockingQueuedConnection); +} diff --git a/Source/Core/DolphinQt/TAS/TASInputWindow.cpp b/Source/Core/DolphinQt/TAS/TASInputWindow.cpp index 722c20d10b..fbcdcd4fe8 100644 --- a/Source/Core/DolphinQt/TAS/TASInputWindow.cpp +++ b/Source/Core/DolphinQt/TAS/TASInputWindow.cpp @@ -179,12 +179,12 @@ void TASInputWindow::GetButton(TASCheckBox* checkbox, UX& buttons, UX mask) if (pressed) { m_checkbox_set_by_controller[checkbox] = true; - QueueOnObject(checkbox, [checkbox] { checkbox->setChecked(true); }); + QueueOnObjectBlocking(checkbox, [checkbox] { checkbox->setChecked(true); }); } else if (m_checkbox_set_by_controller.count(checkbox) && m_checkbox_set_by_controller[checkbox]) { m_checkbox_set_by_controller[checkbox] = false; - QueueOnObject(checkbox, [checkbox] { checkbox->setChecked(false); }); + QueueOnObjectBlocking(checkbox, [checkbox] { checkbox->setChecked(false); }); } } @@ -202,7 +202,9 @@ void TASInputWindow::GetSpinBoxU8(QSpinBox* spin, u8& controller_value) { if (!m_spinbox_most_recent_values_u8.count(spin) || m_spinbox_most_recent_values_u8[spin] != controller_value) - QueueOnObject(spin, [spin, controller_value] { spin->setValue(controller_value); }); + { + QueueOnObjectBlocking(spin, [spin, controller_value] { spin->setValue(controller_value); }); + } m_spinbox_most_recent_values_u8[spin] = controller_value; } @@ -220,7 +222,9 @@ void TASInputWindow::GetSpinBoxU16(QSpinBox* spin, u16& controller_value) { if (!m_spinbox_most_recent_values_u16.count(spin) || m_spinbox_most_recent_values_u16[spin] != controller_value) - QueueOnObject(spin, [spin, controller_value] { spin->setValue(controller_value); }); + { + QueueOnObjectBlocking(spin, [spin, controller_value] { spin->setValue(controller_value); }); + } m_spinbox_most_recent_values_u16[spin] = controller_value; }