mirror of
				https://github.com/dolphin-emu/dolphin.git
				synced 2025-10-25 17:39:09 +00:00 
			
		
		
		
	This lets the TAS input code use a higher-level interface for overriding inputs instead of having to fiddle with raw bits. WiiTASInputWindow in particular was messy with how much controller code it had to re-implement.
		
			
				
	
	
		
			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 + ((m_x * w) / ir_max_x);
 | |
|   u16 y = PADDING + (h - (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 = (event->pos().x() * ir_max_x) / width();
 | |
|     int new_y = ir_max_y - (event->pos().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();
 | |
| }
 |