mirror of
https://github.com/dolphin-emu/dolphin.git
synced 2025-10-24 00:49:18 +00:00
SPDX standardizes how source code conveys its copyright and licensing information. See https://spdx.github.io/spdx-spec/1-rationale/ . SPDX tags are adopted in many large projects, including things like the Linux kernel.
100 lines
2.3 KiB
C++
100 lines
2.3 KiB
C++
// Copyright 2018 Dolphin Emulator Project
|
|
// SPDX-License-Identifier: GPL-2.0-or-later
|
|
|
|
#include "DolphinQt/TAS/IRWidget.h"
|
|
|
|
#include <algorithm>
|
|
#include <cmath>
|
|
|
|
#include <QMouseEvent>
|
|
#include <QPainter>
|
|
|
|
#include "Common/CommonTypes.h"
|
|
|
|
constexpr int PADDING = 1;
|
|
|
|
IRWidget::IRWidget(QWidget* parent) : QWidget(parent)
|
|
{
|
|
setMouseTracking(false);
|
|
setToolTip(tr("Left click to set the IR value.\n"
|
|
"Right click to re-center it."));
|
|
|
|
// If the widget gets too small, it will get deformed.
|
|
setMinimumSize(QSize(64, 48));
|
|
}
|
|
|
|
void IRWidget::SetX(u16 x)
|
|
{
|
|
m_x = std::min(ir_max_x, x);
|
|
|
|
update();
|
|
}
|
|
|
|
void IRWidget::SetY(u16 y)
|
|
{
|
|
m_y = std::min(ir_max_y, y);
|
|
|
|
update();
|
|
}
|
|
|
|
void IRWidget::paintEvent(QPaintEvent* event)
|
|
{
|
|
QPainter painter(this);
|
|
|
|
painter.setRenderHint(QPainter::Antialiasing, true);
|
|
painter.setRenderHint(QPainter::SmoothPixmapTransform, true);
|
|
|
|
const int w = width() - PADDING * 2;
|
|
const int h = height() - PADDING * 2;
|
|
|
|
painter.setBrush(Qt::white);
|
|
painter.drawRect(PADDING, PADDING, w, h);
|
|
|
|
painter.drawLine(PADDING, PADDING + h / 2, PADDING + w, PADDING + h / 2);
|
|
painter.drawLine(PADDING + w / 2, PADDING, PADDING + w / 2, PADDING + h);
|
|
|
|
// convert from value space to widget space
|
|
u16 x = PADDING + (w - (m_x * w) / ir_max_x);
|
|
u16 y = PADDING + ((m_y * h) / ir_max_y);
|
|
|
|
painter.drawLine(PADDING + w / 2, PADDING + h / 2, x, y);
|
|
|
|
painter.setBrush(Qt::blue);
|
|
int wh_avg = (w + h) / 2;
|
|
int radius = wh_avg / 30;
|
|
painter.drawEllipse(x - radius, y - radius, radius * 2, radius * 2);
|
|
}
|
|
|
|
void IRWidget::mousePressEvent(QMouseEvent* event)
|
|
{
|
|
handleMouseEvent(event);
|
|
m_ignore_movement = event->button() == Qt::RightButton;
|
|
}
|
|
|
|
void IRWidget::mouseMoveEvent(QMouseEvent* event)
|
|
{
|
|
if (!m_ignore_movement)
|
|
handleMouseEvent(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
|
|
int new_x = ir_max_x - (event->x() * ir_max_x) / width();
|
|
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_y = std::max(0, std::min(static_cast<int>(ir_max_y), new_y));
|
|
}
|
|
|
|
emit ChangedX(m_x);
|
|
emit ChangedY(m_y);
|
|
update();
|
|
}
|