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.
This commit is contained in:
parent
ca064b55fe
commit
1a5e0c2084
|
@ -17,3 +17,11 @@ static void QueueOnObject(T* obj, F&& func)
|
|||
QObject src;
|
||||
QObject::connect(&src, &QObject::destroyed, obj, std::forward<F>(func), Qt::QueuedConnection);
|
||||
}
|
||||
|
||||
template <typename T, typename F>
|
||||
static void QueueOnObjectBlocking(T* obj, F&& func)
|
||||
{
|
||||
QObject src;
|
||||
QObject::connect(&src, &QObject::destroyed, obj, std::forward<F>(func),
|
||||
Qt::BlockingQueuedConnection);
|
||||
}
|
||||
|
|
|
@ -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;
|
||||
}
|
||||
|
|
Loading…
Reference in New Issue