Merge pull request #7325 from spycrab/qt_tas_reset
Qt/TAS: Implement recentering feature
This commit is contained in:
commit
6d56b03304
|
@ -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)
|
||||||
|
@ -64,12 +67,20 @@ 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();
|
||||||
int new_y = (event->y() * ir_max_y) / height();
|
int new_y = (event->y() * ir_max_y) / height();
|
||||||
|
|
||||||
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);
|
||||||
|
|
|
@ -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)
|
||||||
|
@ -65,12 +68,20 @@ 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();
|
||||||
int new_y = m_max_y - (event->y() * m_max_y) / height();
|
int new_y = m_max_y - (event->y() * m_max_y) / height();
|
||||||
|
|
||||||
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);
|
||||||
|
|
Loading…
Reference in New Issue