mirror of
				https://github.com/dolphin-emu/dolphin.git
				synced 2025-10-25 09:29:43 +00:00 
			
		
		
		
	This is a feature which existed in DolphinWX. Seems like it got implemented in DolphinQt for IRWidget/StickWidget but not sliders.
		
			
				
	
	
		
			124 lines
		
	
	
	
		
			4.4 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			124 lines
		
	
	
	
		
			4.4 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| // Copyright 2018 Dolphin Emulator Project
 | |
| // Licensed under GPLv2+
 | |
| // Refer to the license.txt file included.
 | |
| 
 | |
| #include "DolphinQt/TAS/GCTASInputWindow.h"
 | |
| 
 | |
| #include <QCheckBox>
 | |
| #include <QGridLayout>
 | |
| #include <QGroupBox>
 | |
| #include <QHBoxLayout>
 | |
| #include <QSpacerItem>
 | |
| #include <QSpinBox>
 | |
| #include <QVBoxLayout>
 | |
| 
 | |
| #include "Common/CommonTypes.h"
 | |
| 
 | |
| #include "DolphinQt/TAS/TASCheckBox.h"
 | |
| 
 | |
| #include "InputCommon/GCPadStatus.h"
 | |
| 
 | |
| GCTASInputWindow::GCTASInputWindow(QWidget* parent, int num) : TASInputWindow(parent)
 | |
| {
 | |
|   setWindowTitle(tr("GameCube TAS Input %1").arg(num + 1));
 | |
| 
 | |
|   m_main_stick_box = CreateStickInputs(tr("Main Stick"), m_x_main_stick_value, m_y_main_stick_value,
 | |
|                                        255, 255, Qt::Key_F, Qt::Key_G);
 | |
|   m_c_stick_box = CreateStickInputs(tr("C Stick"), m_x_c_stick_value, m_y_c_stick_value, 255, 255,
 | |
|                                     Qt::Key_H, Qt::Key_J);
 | |
| 
 | |
|   auto* top_layout = new QHBoxLayout;
 | |
|   top_layout->addWidget(m_main_stick_box);
 | |
|   top_layout->addWidget(m_c_stick_box);
 | |
| 
 | |
|   m_triggers_box = new QGroupBox(tr("Triggers"));
 | |
| 
 | |
|   auto* l_trigger_layout =
 | |
|       CreateSliderValuePairLayout(tr("Left"), m_l_trigger_value, 0, 255, Qt::Key_N, m_triggers_box);
 | |
|   auto* r_trigger_layout = CreateSliderValuePairLayout(tr("Right"), m_r_trigger_value, 0, 255,
 | |
|                                                        Qt::Key_M, m_triggers_box);
 | |
| 
 | |
|   auto* triggers_layout = new QVBoxLayout;
 | |
|   triggers_layout->addLayout(l_trigger_layout);
 | |
|   triggers_layout->addLayout(r_trigger_layout);
 | |
|   m_triggers_box->setLayout(triggers_layout);
 | |
| 
 | |
|   m_a_button = CreateButton(QStringLiteral("&A"));
 | |
|   m_b_button = CreateButton(QStringLiteral("&B"));
 | |
|   m_x_button = CreateButton(QStringLiteral("&X"));
 | |
|   m_y_button = CreateButton(QStringLiteral("&Y"));
 | |
|   m_z_button = CreateButton(QStringLiteral("&Z"));
 | |
|   m_l_button = CreateButton(QStringLiteral("&L"));
 | |
|   m_r_button = CreateButton(QStringLiteral("&R"));
 | |
|   m_start_button = CreateButton(QStringLiteral("&START"));
 | |
|   m_left_button = CreateButton(QStringLiteral("L&eft"));
 | |
|   m_up_button = CreateButton(QStringLiteral("&Up"));
 | |
|   m_down_button = CreateButton(QStringLiteral("&Down"));
 | |
|   m_right_button = CreateButton(QStringLiteral("R&ight"));
 | |
| 
 | |
|   auto* buttons_layout = new QGridLayout;
 | |
|   buttons_layout->addWidget(m_a_button, 0, 0);
 | |
|   buttons_layout->addWidget(m_b_button, 0, 1);
 | |
|   buttons_layout->addWidget(m_x_button, 0, 2);
 | |
|   buttons_layout->addWidget(m_y_button, 0, 3);
 | |
|   buttons_layout->addWidget(m_z_button, 0, 4);
 | |
|   buttons_layout->addWidget(m_l_button, 0, 5);
 | |
|   buttons_layout->addWidget(m_r_button, 0, 6);
 | |
| 
 | |
|   buttons_layout->addWidget(m_start_button, 1, 0);
 | |
|   buttons_layout->addWidget(m_left_button, 1, 1);
 | |
|   buttons_layout->addWidget(m_up_button, 1, 2);
 | |
|   buttons_layout->addWidget(m_down_button, 1, 3);
 | |
|   buttons_layout->addWidget(m_right_button, 1, 4);
 | |
| 
 | |
|   buttons_layout->addItem(new QSpacerItem(1, 1, QSizePolicy::Expanding), 0, 7);
 | |
| 
 | |
|   m_buttons_box = new QGroupBox(tr("Buttons"));
 | |
|   m_buttons_box->setLayout(buttons_layout);
 | |
| 
 | |
|   auto* layout = new QVBoxLayout;
 | |
|   layout->addLayout(top_layout);
 | |
|   layout->addWidget(m_triggers_box);
 | |
|   layout->addWidget(m_buttons_box);
 | |
|   layout->addWidget(m_settings_box);
 | |
| 
 | |
|   setLayout(layout);
 | |
| }
 | |
| 
 | |
| void GCTASInputWindow::GetValues(GCPadStatus* pad)
 | |
| {
 | |
|   if (!isVisible())
 | |
|     return;
 | |
| 
 | |
|   GetButton<u16>(m_a_button, pad->button, PAD_BUTTON_A);
 | |
|   GetButton<u16>(m_b_button, pad->button, PAD_BUTTON_B);
 | |
|   GetButton<u16>(m_x_button, pad->button, PAD_BUTTON_X);
 | |
|   GetButton<u16>(m_y_button, pad->button, PAD_BUTTON_Y);
 | |
|   GetButton<u16>(m_z_button, pad->button, PAD_TRIGGER_Z);
 | |
|   GetButton<u16>(m_l_button, pad->button, PAD_TRIGGER_L);
 | |
|   GetButton<u16>(m_r_button, pad->button, PAD_TRIGGER_R);
 | |
|   GetButton<u16>(m_left_button, pad->button, PAD_BUTTON_LEFT);
 | |
|   GetButton<u16>(m_up_button, pad->button, PAD_BUTTON_UP);
 | |
|   GetButton<u16>(m_down_button, pad->button, PAD_BUTTON_DOWN);
 | |
|   GetButton<u16>(m_right_button, pad->button, PAD_BUTTON_RIGHT);
 | |
|   GetButton<u16>(m_start_button, pad->button, PAD_BUTTON_START);
 | |
| 
 | |
|   if (m_a_button->isChecked())
 | |
|     pad->analogA = 0xFF;
 | |
|   else
 | |
|     pad->analogA = 0x00;
 | |
| 
 | |
|   if (m_b_button->isChecked())
 | |
|     pad->analogB = 0xFF;
 | |
|   else
 | |
|     pad->analogB = 0x00;
 | |
| 
 | |
|   GetSpinBoxU8(m_l_trigger_value, pad->triggerLeft);
 | |
|   GetSpinBoxU8(m_r_trigger_value, pad->triggerRight);
 | |
| 
 | |
|   GetSpinBoxU8(m_x_main_stick_value, pad->stickX);
 | |
|   GetSpinBoxU8(m_y_main_stick_value, pad->stickY);
 | |
| 
 | |
|   GetSpinBoxU8(m_x_c_stick_value, pad->substickX);
 | |
|   GetSpinBoxU8(m_y_c_stick_value, pad->substickY);
 | |
| }
 |