mirror of https://github.com/PCSX2/pcsx2.git
Zeropad: Archiving some hat work. Still disabled and buggy, but I want to be able to revert back here if neccessary.
git-svn-id: http://pcsx2.googlecode.com/svn/trunk@1184 96395faa-99c1-11dd-bbfe-3dabce05a288
This commit is contained in:
parent
bddfd67bae
commit
5b4935dd86
|
@ -136,6 +136,7 @@ void on_joydevicescombo_changed(GtkComboBox *combobox, gpointer user_data)
|
||||||
void on_checkbutton_reverselx_toggled(GtkToggleButton *togglebutton, gpointer user_data)
|
void on_checkbutton_reverselx_toggled(GtkToggleButton *togglebutton, gpointer user_data)
|
||||||
{
|
{
|
||||||
int mask = PADOPTION_REVERTLX << (16 * s_selectedpad);
|
int mask = PADOPTION_REVERTLX << (16 * s_selectedpad);
|
||||||
|
|
||||||
if (gtk_toggle_button_get_active(togglebutton))
|
if (gtk_toggle_button_get_active(togglebutton))
|
||||||
conf.options |= mask;
|
conf.options |= mask;
|
||||||
else
|
else
|
||||||
|
@ -145,6 +146,7 @@ void on_checkbutton_reverselx_toggled(GtkToggleButton *togglebutton, gpointer us
|
||||||
void on_checkbutton_reversely_toggled(GtkToggleButton *togglebutton, gpointer user_data)
|
void on_checkbutton_reversely_toggled(GtkToggleButton *togglebutton, gpointer user_data)
|
||||||
{
|
{
|
||||||
int mask = PADOPTION_REVERTLY << (16 * s_selectedpad);
|
int mask = PADOPTION_REVERTLY << (16 * s_selectedpad);
|
||||||
|
|
||||||
if (gtk_toggle_button_get_active(togglebutton))
|
if (gtk_toggle_button_get_active(togglebutton))
|
||||||
conf.options |= mask;
|
conf.options |= mask;
|
||||||
else
|
else
|
||||||
|
@ -163,6 +165,7 @@ void on_checkbutton_reverserx_toggled(GtkToggleButton *togglebutton, gpointer us
|
||||||
void on_checkbutton_reversery_toggled(GtkToggleButton *togglebutton, gpointer user_data)
|
void on_checkbutton_reversery_toggled(GtkToggleButton *togglebutton, gpointer user_data)
|
||||||
{
|
{
|
||||||
int mask = PADOPTION_REVERTRY << (16 * s_selectedpad);
|
int mask = PADOPTION_REVERTRY << (16 * s_selectedpad);
|
||||||
|
|
||||||
if (gtk_toggle_button_get_active(togglebutton))
|
if (gtk_toggle_button_get_active(togglebutton))
|
||||||
conf.options |= mask;
|
conf.options |= mask;
|
||||||
else
|
else
|
||||||
|
@ -172,11 +175,13 @@ void on_checkbutton_reversery_toggled(GtkToggleButton *togglebutton, gpointer us
|
||||||
void on_forcefeedback_toggled(GtkToggleButton *togglebutton, gpointer user_data)
|
void on_forcefeedback_toggled(GtkToggleButton *togglebutton, gpointer user_data)
|
||||||
{
|
{
|
||||||
int mask = PADOPTION_REVERTLX << (16 * s_selectedpad);
|
int mask = PADOPTION_REVERTLX << (16 * s_selectedpad);
|
||||||
|
|
||||||
if (gtk_toggle_button_get_active(togglebutton))
|
if (gtk_toggle_button_get_active(togglebutton))
|
||||||
{
|
{
|
||||||
conf.options |= mask;
|
conf.options |= mask;
|
||||||
|
|
||||||
int joyid = gtk_combo_box_get_active(GTK_COMBO_BOX(s_devicecombo));
|
int joyid = gtk_combo_box_get_active(GTK_COMBO_BOX(s_devicecombo));
|
||||||
|
|
||||||
if (joyid >= 0 && joyid < (int)s_vjoysticks.size()) s_vjoysticks[joyid]->TestForce();
|
if (joyid >= 0 && joyid < (int)s_vjoysticks.size()) s_vjoysticks[joyid]->TestForce();
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
|
|
|
@ -126,28 +126,16 @@ void CALLBACK PADupdate(int pad)
|
||||||
switch (i)
|
switch (i)
|
||||||
{
|
{
|
||||||
case PAD_R_LEFT:
|
case PAD_R_LEFT:
|
||||||
Analog::ConfigurePad(PAD_RX, pad, DEF_VALUE);
|
|
||||||
break;
|
|
||||||
case PAD_R_UP:
|
case PAD_R_UP:
|
||||||
Analog::ConfigurePad(PAD_RY, pad, DEF_VALUE);
|
|
||||||
break;
|
|
||||||
case PAD_L_LEFT:
|
case PAD_L_LEFT:
|
||||||
Analog::ConfigurePad(PAD_LX, pad, DEF_VALUE);
|
|
||||||
break;
|
|
||||||
case PAD_L_UP:
|
case PAD_L_UP:
|
||||||
Analog::ConfigurePad(PAD_LY, pad, DEF_VALUE);
|
Analog::ConfigurePad(Analog::AnalogToPad(i), pad, DEF_VALUE);
|
||||||
break;
|
|
||||||
case PAD_R_DOWN:
|
|
||||||
Analog::ConfigurePad(PAD_RY, pad, -DEF_VALUE);
|
|
||||||
break;
|
break;
|
||||||
case PAD_R_RIGHT:
|
case PAD_R_RIGHT:
|
||||||
Analog::ConfigurePad(PAD_RX, pad, -DEF_VALUE);
|
case PAD_R_DOWN:
|
||||||
break;
|
|
||||||
case PAD_L_DOWN:
|
|
||||||
Analog::ConfigurePad(PAD_LY, pad, -DEF_VALUE);
|
|
||||||
break;
|
|
||||||
case PAD_L_RIGHT:
|
case PAD_L_RIGHT:
|
||||||
Analog::ConfigurePad(PAD_LX, pad, -DEF_VALUE);
|
case PAD_L_DOWN:
|
||||||
|
Analog::ConfigurePad(Analog::AnalogToPad(i), pad, -DEF_VALUE);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
i += 0xff00;
|
i += 0xff00;
|
||||||
|
@ -172,33 +160,7 @@ void CALLBACK PADupdate(int pad)
|
||||||
|
|
||||||
if ((i > PAD_RY) && (i <= PAD_R_LEFT))
|
if ((i > PAD_RY) && (i <= PAD_R_LEFT))
|
||||||
{
|
{
|
||||||
switch (i)
|
Analog::ResetPad(Analog::AnalogToPad(i), pad);
|
||||||
{
|
|
||||||
case PAD_R_LEFT:
|
|
||||||
Analog::ResetPad(PAD_RX, pad);
|
|
||||||
break;
|
|
||||||
case PAD_R_UP:
|
|
||||||
Analog::ResetPad(PAD_RY, pad);
|
|
||||||
break;
|
|
||||||
case PAD_L_LEFT:
|
|
||||||
Analog::ResetPad(PAD_LX, pad);
|
|
||||||
break;
|
|
||||||
case PAD_L_UP:
|
|
||||||
Analog::ResetPad(PAD_LY, pad);
|
|
||||||
break;
|
|
||||||
case PAD_R_DOWN:
|
|
||||||
Analog::ResetPad(PAD_RY, pad);
|
|
||||||
break;
|
|
||||||
case PAD_R_RIGHT:
|
|
||||||
Analog::ResetPad(PAD_RX, pad);
|
|
||||||
break;
|
|
||||||
case PAD_L_DOWN:
|
|
||||||
Analog::ResetPad(PAD_LY, pad);
|
|
||||||
break;
|
|
||||||
case PAD_L_RIGHT:
|
|
||||||
Analog::ResetPad(PAD_LX, pad);
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
i += 0xff00;
|
i += 0xff00;
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
@ -255,6 +217,7 @@ void CALLBACK PADupdate(int pad)
|
||||||
pjoy = s_vjoysticks[joyid];
|
pjoy = s_vjoysticks[joyid];
|
||||||
int value = SDL_JoystickGetAxis((pjoy)->GetJoy(), PAD_GETJOYSTICK_AXIS(key));
|
int value = SDL_JoystickGetAxis((pjoy)->GetJoy(), PAD_GETJOYSTICK_AXIS(key));
|
||||||
int pad = (pjoy)->GetPAD();
|
int pad = (pjoy)->GetPAD();
|
||||||
|
|
||||||
switch (i)
|
switch (i)
|
||||||
{
|
{
|
||||||
case PAD_LX:
|
case PAD_LX:
|
||||||
|
@ -279,12 +242,46 @@ void CALLBACK PADupdate(int pad)
|
||||||
|
|
||||||
int value = SDL_JoystickGetHat((pjoy)->GetJoy(), PAD_GETJOYSTICK_AXIS(key));
|
int value = SDL_JoystickGetHat((pjoy)->GetJoy(), PAD_GETJOYSTICK_AXIS(key));
|
||||||
int pad = (pjoy)->GetPAD();
|
int pad = (pjoy)->GetPAD();
|
||||||
|
int temp;
|
||||||
|
|
||||||
//PAD_LOG("Hat = %d for key %d\n", PAD_GETPOVSIGN(key), key);
|
//PAD_LOG("Hat = %d for key %d\n", PAD_GETPOVDIR(key), key);
|
||||||
if PAD_GETPOVSIGN(key)
|
if (value != 0)
|
||||||
|
{
|
||||||
|
if (PAD_GETPOVDIR(key) == value)
|
||||||
|
set_bit(status[pad], i);
|
||||||
|
/*else
|
||||||
|
clear_bit(status[pad], i);*/
|
||||||
|
|
||||||
|
switch (value)
|
||||||
|
{
|
||||||
|
case SDL_HAT_UP:
|
||||||
|
PAD_LOG("Up!\n");
|
||||||
|
break;
|
||||||
|
|
||||||
|
case SDL_HAT_RIGHT:
|
||||||
|
PAD_LOG("Right!\n");
|
||||||
|
break;
|
||||||
|
|
||||||
|
case SDL_HAT_DOWN:
|
||||||
|
PAD_LOG("Down!\n");
|
||||||
|
break;
|
||||||
|
|
||||||
|
case SDL_HAT_LEFT:
|
||||||
|
PAD_LOG("Left!\n");
|
||||||
|
break;
|
||||||
|
case SDL_HAT_CENTER:
|
||||||
|
clear_bit(status[pad], i);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
//clear_bit(status[pad], i);
|
||||||
|
}
|
||||||
|
/*if PAD_GETPOVSIGN(key)
|
||||||
set_bit(status[pad], i);
|
set_bit(status[pad], i);
|
||||||
else
|
else
|
||||||
clear_bit(status[pad], i);
|
clear_bit(status[pad], i);*/
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
#else
|
#else
|
||||||
|
@ -357,7 +354,7 @@ void UpdateConf(int pad)
|
||||||
#ifdef EXPERAMENTAL_POV_CODE
|
#ifdef EXPERAMENTAL_POV_CODE
|
||||||
{
|
{
|
||||||
tmp.resize(28);
|
tmp.resize(28);
|
||||||
switch(PAD_GETPOVSIGN(conf.keys[pad][i]))
|
switch(PAD_GETPOVDIR(conf.keys[pad][i]))
|
||||||
{
|
{
|
||||||
case SDL_HAT_UP:
|
case SDL_HAT_UP:
|
||||||
sprintf(&tmp[0], "JPOVU-%d", PAD_GETJOYSTICK_AXIS(conf.keys[pad][i]));
|
sprintf(&tmp[0], "JPOVU-%d", PAD_GETJOYSTICK_AXIS(conf.keys[pad][i]));
|
||||||
|
|
|
@ -128,4 +128,35 @@ namespace Analog
|
||||||
|
|
||||||
PAD_LOG("Setting pad[%d]@%d to %d from %d\n", padvalue, i, value, temp);
|
PAD_LOG("Setting pad[%d]@%d to %d from %d\n", padvalue, i, value, temp);
|
||||||
}
|
}
|
||||||
|
int AnalogToPad(int padvalue)
|
||||||
|
{
|
||||||
|
switch (padvalue)
|
||||||
|
{
|
||||||
|
case PAD_R_LEFT:
|
||||||
|
return PAD_RX;
|
||||||
|
break;
|
||||||
|
case PAD_R_UP:
|
||||||
|
return PAD_RY;
|
||||||
|
break;
|
||||||
|
case PAD_L_LEFT:
|
||||||
|
return PAD_LX;
|
||||||
|
break;
|
||||||
|
case PAD_L_UP:
|
||||||
|
return PAD_LY;
|
||||||
|
break;
|
||||||
|
case PAD_R_DOWN:
|
||||||
|
return PAD_RY;
|
||||||
|
break;
|
||||||
|
case PAD_R_RIGHT:
|
||||||
|
return PAD_RX;
|
||||||
|
break;
|
||||||
|
case PAD_L_DOWN:
|
||||||
|
return PAD_LY;
|
||||||
|
break;
|
||||||
|
case PAD_L_RIGHT:
|
||||||
|
return PAD_LX;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -29,4 +29,5 @@
|
||||||
extern void ResetPad(int padvalue, u8 i);
|
extern void ResetPad(int padvalue, u8 i);
|
||||||
extern void ConfigurePad(int padvalue, u8 i, int value);
|
extern void ConfigurePad(int padvalue, u8 i, int value);
|
||||||
extern int KeypadToPad(u8 keypress);
|
extern int KeypadToPad(u8 keypress);
|
||||||
|
extern int AnalogToPad(int padvalue);
|
||||||
}
|
}
|
|
@ -65,6 +65,7 @@ extern char libraryName[256];
|
||||||
#define PAD_JOYSTICK(joyid, axisid) (0x20000 | ((joyid) << 12) | (axisid))
|
#define PAD_JOYSTICK(joyid, axisid) (0x20000 | ((joyid) << 12) | (axisid))
|
||||||
#define PAD_POV(joyid, sign, axisid) (0x30000 | ((joyid) << 12) | ((sign) << 8) | (axisid))
|
#define PAD_POV(joyid, sign, axisid) (0x30000 | ((joyid) << 12) | ((sign) << 8) | (axisid))
|
||||||
#define PAD_GETPOVSIGN(key) (((key) & 0x100) >> 8)
|
#define PAD_GETPOVSIGN(key) (((key) & 0x100) >> 8)
|
||||||
|
#define PAD_GETPOVDIR(key) (((key) & ~ 0x30000) >> 8)
|
||||||
|
|
||||||
#ifdef __LINUX__
|
#ifdef __LINUX__
|
||||||
#define PADKEYS 28
|
#define PADKEYS 28
|
||||||
|
|
Loading…
Reference in New Issue