GTK :
Moved default joypad selection to the joypad config dialog.
This commit is contained in:
parent
3d34d0d9eb
commit
e8b08761c9
|
@ -45,6 +45,7 @@ JoypadConfigDialog::JoypadConfigDialog() :
|
||||||
Gtk::Dialog("Joypad config", true, true),
|
Gtk::Dialog("Joypad config", true, true),
|
||||||
m_oTitleHBox(false, 5),
|
m_oTitleHBox(false, 5),
|
||||||
m_oTitleLabel("Joypad :", Gtk::ALIGN_RIGHT),
|
m_oTitleLabel("Joypad :", Gtk::ALIGN_RIGHT),
|
||||||
|
m_oDefaultJoypad("Default joypad"),
|
||||||
m_oTable(G_N_ELEMENTS(m_astKeys), 2, false),
|
m_oTable(G_N_ELEMENTS(m_astKeys), 2, false),
|
||||||
m_ePad(PAD_MAIN)
|
m_ePad(PAD_MAIN)
|
||||||
{
|
{
|
||||||
|
@ -78,14 +79,17 @@ JoypadConfigDialog::JoypadConfigDialog() :
|
||||||
m_oTitleHBox.set_border_width(5);
|
m_oTitleHBox.set_border_width(5);
|
||||||
m_oTable.set_border_width(5);
|
m_oTable.set_border_width(5);
|
||||||
m_oTable.set_spacings(5);
|
m_oTable.set_spacings(5);
|
||||||
|
get_vbox()->set_spacing(5);
|
||||||
get_vbox()->pack_start(m_oTitleHBox);
|
get_vbox()->pack_start(m_oTitleHBox);
|
||||||
get_vbox()->pack_start(m_oSeparator);
|
get_vbox()->pack_start(m_oSeparator);
|
||||||
|
get_vbox()->pack_start(m_oDefaultJoypad);
|
||||||
get_vbox()->pack_start(m_oTable);
|
get_vbox()->pack_start(m_oTable);
|
||||||
|
|
||||||
// Signals and default values
|
// Signals and default values
|
||||||
m_oConfigSig = Glib::signal_idle().connect(sigc::mem_fun(*this, &JoypadConfigDialog::bOnConfigIdle),
|
m_oConfigSig = Glib::signal_idle().connect(sigc::mem_fun(*this, &JoypadConfigDialog::bOnConfigIdle),
|
||||||
Glib::PRIORITY_DEFAULT_IDLE);
|
Glib::PRIORITY_DEFAULT_IDLE);
|
||||||
|
m_oDefaultJoypad.signal_toggled().connect(sigc::mem_fun(*this,
|
||||||
|
&JoypadConfigDialog::vOnDefaultJoypadSelect) );
|
||||||
m_oTitleCombo.signal_changed().connect(sigc::mem_fun(*this,
|
m_oTitleCombo.signal_changed().connect(sigc::mem_fun(*this,
|
||||||
&JoypadConfigDialog::vOnJoypadSelect) );
|
&JoypadConfigDialog::vOnJoypadSelect) );
|
||||||
m_oTitleCombo.set_active_text("1");
|
m_oTitleCombo.set_active_text("1");
|
||||||
|
@ -100,9 +104,11 @@ JoypadConfigDialog::~JoypadConfigDialog()
|
||||||
|
|
||||||
void JoypadConfigDialog::vUpdateEntries()
|
void JoypadConfigDialog::vUpdateEntries()
|
||||||
{
|
{
|
||||||
|
m_oDefaultJoypad.set_active(inputGetDefaultJoypad() == m_ePad);
|
||||||
|
|
||||||
for (guint i = 0; i < m_oEntries.size(); i++)
|
for (guint i = 0; i < m_oEntries.size(); i++)
|
||||||
{
|
{
|
||||||
const char * csName = 0;
|
const char * csName = 0;
|
||||||
|
|
||||||
guint uiKeyval = inputGetKeymap(m_ePad, m_astKeys[i].m_eKeyFlag);
|
guint uiKeyval = inputGetKeymap(m_ePad, m_astKeys[i].m_eKeyFlag);
|
||||||
int dev = uiKeyval >> 16;
|
int dev = uiKeyval >> 16;
|
||||||
|
@ -267,4 +273,16 @@ void JoypadConfigDialog::vOnJoypadSelect()
|
||||||
vUpdateEntries();
|
vUpdateEntries();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void JoypadConfigDialog::vOnDefaultJoypadSelect()
|
||||||
|
{
|
||||||
|
if (m_oDefaultJoypad.get_active())
|
||||||
|
{
|
||||||
|
inputSetDefaultJoypad(m_ePad);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
inputSetDefaultJoypad(PAD_MAIN);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
} // namespace VBA
|
} // namespace VBA
|
||||||
|
|
|
@ -28,6 +28,7 @@
|
||||||
#include <gtkmm/entry.h>
|
#include <gtkmm/entry.h>
|
||||||
#include <gtkmm/comboboxtext.h>
|
#include <gtkmm/comboboxtext.h>
|
||||||
#include <gtkmm/separator.h>
|
#include <gtkmm/separator.h>
|
||||||
|
#include <gtkmm/checkbutton.h>
|
||||||
|
|
||||||
#include "../sdl/inputSDL.h"
|
#include "../sdl/inputSDL.h"
|
||||||
|
|
||||||
|
@ -58,6 +59,7 @@ private:
|
||||||
Gtk::Label m_oTitleLabel;
|
Gtk::Label m_oTitleLabel;
|
||||||
Gtk::ComboBoxText m_oTitleCombo;
|
Gtk::ComboBoxText m_oTitleCombo;
|
||||||
Gtk::HSeparator m_oSeparator;
|
Gtk::HSeparator m_oSeparator;
|
||||||
|
Gtk::CheckButton m_oDefaultJoypad;
|
||||||
Gtk::Table m_oTable;
|
Gtk::Table m_oTable;
|
||||||
Gtk::Button * m_poOkButton;
|
Gtk::Button * m_poOkButton;
|
||||||
std::vector<Gtk::Entry *> m_oEntries;
|
std::vector<Gtk::Entry *> m_oEntries;
|
||||||
|
@ -69,6 +71,7 @@ private:
|
||||||
|
|
||||||
bool bOnConfigIdle();
|
bool bOnConfigIdle();
|
||||||
void vOnJoypadSelect();
|
void vOnJoypadSelect();
|
||||||
|
void vOnDefaultJoypadSelect();
|
||||||
void vUpdateEntries();
|
void vUpdateEntries();
|
||||||
void vEmptyEventQueue();
|
void vEmptyEventQueue();
|
||||||
};
|
};
|
||||||
|
|
|
@ -1044,48 +1044,6 @@
|
||||||
<property name="use_underline">True</property>
|
<property name="use_underline">True</property>
|
||||||
</widget>
|
</widget>
|
||||||
</child>
|
</child>
|
||||||
<child>
|
|
||||||
<widget class="GtkSeparatorMenuItem" id="separator18">
|
|
||||||
<property name="visible">True</property>
|
|
||||||
</widget>
|
|
||||||
</child>
|
|
||||||
<child>
|
|
||||||
<widget class="GtkRadioMenuItem" id="Joypad1">
|
|
||||||
<property name="visible">True</property>
|
|
||||||
<property name="label" translatable="yes">_1</property>
|
|
||||||
<property name="use_underline">True</property>
|
|
||||||
<property name="active">True</property>
|
|
||||||
</widget>
|
|
||||||
</child>
|
|
||||||
<child>
|
|
||||||
<widget class="GtkRadioMenuItem" id="Joypad2">
|
|
||||||
<property name="visible">True</property>
|
|
||||||
<property name="label" translatable="yes">_2</property>
|
|
||||||
<property name="use_underline">True</property>
|
|
||||||
<property name="group">Joypad1</property>
|
|
||||||
</widget>
|
|
||||||
</child>
|
|
||||||
<child>
|
|
||||||
<widget class="GtkRadioMenuItem" id="Joypad3">
|
|
||||||
<property name="visible">True</property>
|
|
||||||
<property name="label" translatable="yes">_3</property>
|
|
||||||
<property name="use_underline">True</property>
|
|
||||||
<property name="group">Joypad1</property>
|
|
||||||
</widget>
|
|
||||||
</child>
|
|
||||||
<child>
|
|
||||||
<widget class="GtkRadioMenuItem" id="Joypad4">
|
|
||||||
<property name="visible">True</property>
|
|
||||||
<property name="label" translatable="yes">_4</property>
|
|
||||||
<property name="use_underline">True</property>
|
|
||||||
<property name="group">Joypad1</property>
|
|
||||||
</widget>
|
|
||||||
</child>
|
|
||||||
<child>
|
|
||||||
<widget class="GtkSeparatorMenuItem" id="separator24">
|
|
||||||
<property name="visible">True</property>
|
|
||||||
</widget>
|
|
||||||
</child>
|
|
||||||
<child>
|
<child>
|
||||||
<widget class="GtkMenuItem" id="AutofireMenu">
|
<widget class="GtkMenuItem" id="AutofireMenu">
|
||||||
<property name="visible">True</property>
|
<property name="visible">True</property>
|
||||||
|
|
|
@ -614,22 +614,8 @@ Window::Window(GtkWindow * _pstWindow, const Glib::RefPtr<Xml> & _poXml) :
|
||||||
poMI = dynamic_cast<Gtk::MenuItem *>(_poXml->get_widget("JoypadConfigure"));
|
poMI = dynamic_cast<Gtk::MenuItem *>(_poXml->get_widget("JoypadConfigure"));
|
||||||
poMI->signal_activate().connect(sigc::mem_fun(*this, &Window::vOnJoypadConfigure));
|
poMI->signal_activate().connect(sigc::mem_fun(*this, &Window::vOnJoypadConfigure));
|
||||||
|
|
||||||
int iDefaultJoypad = m_poInputConfig->oGetKey<int>("active_joypad");
|
EPad eDefaultJoypad = (EPad)m_poInputConfig->oGetKey<int>("active_joypad");
|
||||||
for (int i = m_iJoypadMin; i <= m_iJoypadMax; i++)
|
inputSetDefaultJoypad(eDefaultJoypad);
|
||||||
{
|
|
||||||
char csName[20];
|
|
||||||
snprintf(csName, sizeof(csName), "Joypad%d", i + 1);
|
|
||||||
|
|
||||||
poCMI = dynamic_cast<Gtk::CheckMenuItem *>(_poXml->get_widget(csName));
|
|
||||||
if (i == iDefaultJoypad)
|
|
||||||
{
|
|
||||||
poCMI->set_active();
|
|
||||||
vOnJoypadToggled(poCMI, (EPad)iDefaultJoypad);
|
|
||||||
}
|
|
||||||
poCMI->signal_toggled().connect(sigc::bind(
|
|
||||||
sigc::mem_fun(*this, &Window::vOnJoypadToggled),
|
|
||||||
poCMI, (EPad)i));
|
|
||||||
}
|
|
||||||
|
|
||||||
// Autofire menu
|
// Autofire menu
|
||||||
//
|
//
|
||||||
|
|
|
@ -160,7 +160,6 @@ protected:
|
||||||
virtual void vOnFilter2xToggled(Gtk::CheckMenuItem * _poCMI, int _iFilter2x);
|
virtual void vOnFilter2xToggled(Gtk::CheckMenuItem * _poCMI, int _iFilter2x);
|
||||||
virtual void vOnFilterIBToggled(Gtk::CheckMenuItem * _poCMI, int _iFilterIB);
|
virtual void vOnFilterIBToggled(Gtk::CheckMenuItem * _poCMI, int _iFilterIB);
|
||||||
virtual void vOnJoypadConfigure();
|
virtual void vOnJoypadConfigure();
|
||||||
virtual void vOnJoypadToggled(Gtk::CheckMenuItem * _poCMI, EPad _eJoypad);
|
|
||||||
virtual void vOnAutofireToggled(Gtk::CheckMenuItem * _poCMI, EKey _eKey);
|
virtual void vOnAutofireToggled(Gtk::CheckMenuItem * _poCMI, EKey _eKey);
|
||||||
virtual void vOnHelpAbout();
|
virtual void vOnHelpAbout();
|
||||||
virtual bool bOnEmuIdle();
|
virtual bool bOnEmuIdle();
|
||||||
|
|
|
@ -641,18 +641,8 @@ void Window::vOnJoypadConfigure()
|
||||||
JoypadConfigDialog oDialog;
|
JoypadConfigDialog oDialog;
|
||||||
oDialog.set_transient_for(*this);
|
oDialog.set_transient_for(*this);
|
||||||
oDialog.run();
|
oDialog.run();
|
||||||
}
|
|
||||||
|
|
||||||
void Window::vOnJoypadToggled(Gtk::CheckMenuItem * _poCMI, EPad _eJoypad)
|
m_poInputConfig->vSetKey("active_joypad", inputGetDefaultJoypad());
|
||||||
{
|
|
||||||
if (! _poCMI->get_active())
|
|
||||||
{
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
inputSetDefaultJoypad(_eJoypad);
|
|
||||||
|
|
||||||
m_poInputConfig->vSetKey("active_joypad", _eJoypad);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void Window::vOnAutofireToggled(Gtk::CheckMenuItem * _poCMI, EKey _eKey)
|
void Window::vOnAutofireToggled(Gtk::CheckMenuItem * _poCMI, EKey _eKey)
|
||||||
|
|
|
@ -600,3 +600,8 @@ void inputSetDefaultJoypad(EPad pad)
|
||||||
{
|
{
|
||||||
sdlDefaultJoypad = pad;
|
sdlDefaultJoypad = pad;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
EPad inputGetDefaultJoypad()
|
||||||
|
{
|
||||||
|
return sdlDefaultJoypad;
|
||||||
|
}
|
||||||
|
|
|
@ -128,8 +128,14 @@ int inputGetSensorY();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Set which joypad configuration use when the core doesn't ask for a specific
|
* Set which joypad configuration use when the core doesn't ask for a specific
|
||||||
* pad
|
* @param pad Default pad
|
||||||
*/
|
*/
|
||||||
void inputSetDefaultJoypad(EPad pad);
|
void inputSetDefaultJoypad(EPad pad);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get the default joypad
|
||||||
|
* pad
|
||||||
|
*/
|
||||||
|
EPad inputGetDefaultJoypad();
|
||||||
|
|
||||||
#endif // VBAM_SDL_INPUT_H
|
#endif // VBAM_SDL_INPUT_H
|
||||||
|
|
Loading…
Reference in New Issue