mirror of https://github.com/mgba-emu/mgba.git
Qt: Add refresh button to controller editing
This commit is contained in:
parent
1d021a72c7
commit
66345e9b7e
1
CHANGES
1
CHANGES
|
@ -45,6 +45,7 @@ Misc:
|
||||||
- ARM7: Flush prefetch cache when loading CPSR via MSR
|
- ARM7: Flush prefetch cache when loading CPSR via MSR
|
||||||
- Qt: Canonicalize file paths when loading games
|
- Qt: Canonicalize file paths when loading games
|
||||||
- OpenGL: Add texSize uniform
|
- OpenGL: Add texSize uniform
|
||||||
|
- Qt: Add refresh button to controller editing
|
||||||
|
|
||||||
0.4.0: (2016-02-02)
|
0.4.0: (2016-02-02)
|
||||||
Features:
|
Features:
|
||||||
|
|
|
@ -57,20 +57,11 @@ GBAKeyEditor::GBAKeyEditor(InputController* controller, int type, const QString&
|
||||||
|
|
||||||
#ifdef BUILD_SDL
|
#ifdef BUILD_SDL
|
||||||
if (type == SDL_BINDING_BUTTON) {
|
if (type == SDL_BINDING_BUTTON) {
|
||||||
controller->updateJoysticks();
|
|
||||||
controller->recalibrateAxes();
|
|
||||||
lookupAxes(map);
|
|
||||||
|
|
||||||
m_profileSelect = new QComboBox(this);
|
m_profileSelect = new QComboBox(this);
|
||||||
m_profileSelect->addItems(controller->connectedGamepads(type));
|
|
||||||
int activeGamepad = controller->gamepad(type);
|
|
||||||
selectGamepad(activeGamepad);
|
|
||||||
if (activeGamepad > 0) {
|
|
||||||
m_profileSelect->setCurrentIndex(activeGamepad);
|
|
||||||
}
|
|
||||||
|
|
||||||
connect(m_profileSelect, SIGNAL(currentIndexChanged(int)), this, SLOT(selectGamepad(int)));
|
connect(m_profileSelect, SIGNAL(currentIndexChanged(int)), this, SLOT(selectGamepad(int)));
|
||||||
|
|
||||||
|
updateJoysticks();
|
||||||
|
|
||||||
m_clear = new QWidget(this);
|
m_clear = new QWidget(this);
|
||||||
QHBoxLayout* layout = new QHBoxLayout;
|
QHBoxLayout* layout = new QHBoxLayout;
|
||||||
m_clear->setLayout(layout);
|
m_clear->setLayout(layout);
|
||||||
|
@ -97,6 +88,10 @@ GBAKeyEditor::GBAKeyEditor(InputController* controller, int type, const QString&
|
||||||
(*m_currentKey)->clearAxis();
|
(*m_currentKey)->clearAxis();
|
||||||
(*m_currentKey)->blockSignals(signalsBlocked);
|
(*m_currentKey)->blockSignals(signalsBlocked);
|
||||||
});
|
});
|
||||||
|
|
||||||
|
QPushButton* updateJoysticksButton = new QPushButton(tr("Refresh"));
|
||||||
|
layout->addWidget(updateJoysticksButton);
|
||||||
|
connect(updateJoysticksButton, SIGNAL(pressed()), this, SLOT(updateJoysticks()));
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
@ -355,3 +350,19 @@ void GBAKeyEditor::setLocation(QWidget* widget, qreal x, qreal y) {
|
||||||
widget->setGeometry(s.width() * x - hint.width() / 2.0, s.height() * y - hint.height() / 2.0, hint.width(),
|
widget->setGeometry(s.width() * x - hint.width() / 2.0, s.height() * y - hint.height() / 2.0, hint.width(),
|
||||||
hint.height());
|
hint.height());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#ifdef BUILD_SDL
|
||||||
|
void GBAKeyEditor::updateJoysticks() {
|
||||||
|
m_controller->updateJoysticks();
|
||||||
|
m_controller->recalibrateAxes();
|
||||||
|
|
||||||
|
m_profileSelect->clear();
|
||||||
|
m_profileSelect->addItems(m_controller->connectedGamepads(m_type));
|
||||||
|
int activeGamepad = m_controller->gamepad(m_type);
|
||||||
|
selectGamepad(activeGamepad);
|
||||||
|
if (activeGamepad > 0) {
|
||||||
|
m_profileSelect->setCurrentIndex(activeGamepad);
|
||||||
|
}
|
||||||
|
lookupAxes(m_controller->map());
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
|
@ -47,6 +47,7 @@ private slots:
|
||||||
#ifdef BUILD_SDL
|
#ifdef BUILD_SDL
|
||||||
void setAxisValue(int axis, int32_t value);
|
void setAxisValue(int axis, int32_t value);
|
||||||
void selectGamepad(int index);
|
void selectGamepad(int index);
|
||||||
|
void updateJoysticks();
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
|
Loading…
Reference in New Issue