Qt/TAS: Implement recentering feature

This commit is contained in:
spycrab 2018-08-13 14:41:53 +02:00
parent 84c24516b1
commit 1c793503b1
2 changed files with 32 additions and 10 deletions

View File

@ -5,6 +5,7 @@
#include "DolphinQt/TAS/IRWidget.h" #include "DolphinQt/TAS/IRWidget.h"
#include <algorithm> #include <algorithm>
#include <cmath>
#include <QMouseEvent> #include <QMouseEvent>
#include <QPainter> #include <QPainter>
@ -14,6 +15,8 @@
IRWidget::IRWidget(QWidget* parent) : QWidget(parent) IRWidget::IRWidget(QWidget* parent) : QWidget(parent)
{ {
setMouseTracking(false); setMouseTracking(false);
setToolTip(tr("Left click to set the IR value.\n"
"Right click to re-center it."));
} }
void IRWidget::SetX(u16 x) void IRWidget::SetX(u16 x)
@ -63,6 +66,13 @@ void IRWidget::mouseMoveEvent(QMouseEvent* event)
} }
void IRWidget::handleMouseEvent(QMouseEvent* event) void IRWidget::handleMouseEvent(QMouseEvent* event)
{
if (event->button() == Qt::RightButton)
{
m_x = std::round(ir_max_x / 2.);
m_y = std::round(ir_max_y / 2.);
}
else
{ {
// convert from widget space to value space // convert from widget space to value space
int new_x = ir_max_x - (event->x() * ir_max_x) / width(); int new_x = ir_max_x - (event->x() * ir_max_x) / width();
@ -70,6 +80,7 @@ void IRWidget::handleMouseEvent(QMouseEvent* event)
m_x = std::max(0, std::min(static_cast<int>(ir_max_x), new_x)); m_x = std::max(0, std::min(static_cast<int>(ir_max_x), new_x));
m_y = std::max(0, std::min(static_cast<int>(ir_max_y), new_y)); m_y = std::max(0, std::min(static_cast<int>(ir_max_y), new_y));
}
emit ChangedX(m_x); emit ChangedX(m_x);
emit ChangedY(m_y); emit ChangedY(m_y);

View File

@ -5,6 +5,7 @@
#include "DolphinQt/TAS/StickWidget.h" #include "DolphinQt/TAS/StickWidget.h"
#include <algorithm> #include <algorithm>
#include <cmath>
#include <QMouseEvent> #include <QMouseEvent>
#include <QPainter> #include <QPainter>
@ -15,6 +16,8 @@ StickWidget::StickWidget(QWidget* parent, u16 max_x, u16 max_y)
: QWidget(parent), m_max_x(max_x), m_max_y(max_y) : QWidget(parent), m_max_x(max_x), m_max_y(max_y)
{ {
setMouseTracking(false); setMouseTracking(false);
setToolTip(tr("Left click to set the stick value.\n"
"Right click to re-center it."));
} }
void StickWidget::SetX(u16 x) void StickWidget::SetX(u16 x)
@ -64,6 +67,13 @@ void StickWidget::mouseMoveEvent(QMouseEvent* event)
} }
void StickWidget::handleMouseEvent(QMouseEvent* event) void StickWidget::handleMouseEvent(QMouseEvent* event)
{
if (event->button() == Qt::RightButton)
{
m_x = std::round(m_max_x / 2.);
m_y = std::round(m_max_y / 2.);
}
else
{ {
// convert from widget space to value space // convert from widget space to value space
int new_x = (event->x() * m_max_x) / width(); int new_x = (event->x() * m_max_x) / width();
@ -71,6 +81,7 @@ void StickWidget::handleMouseEvent(QMouseEvent* event)
m_x = std::max(0, std::min(static_cast<int>(m_max_x), new_x)); m_x = std::max(0, std::min(static_cast<int>(m_max_x), new_x));
m_y = std::max(0, std::min(static_cast<int>(m_max_y), new_y)); m_y = std::max(0, std::min(static_cast<int>(m_max_y), new_y));
}
emit ChangedX(m_x); emit ChangedX(m_x);
emit ChangedY(m_y); emit ChangedY(m_y);