gamecube controller support

This commit is contained in:
Fabio Olimpieri 2017-04-30 23:10:59 +02:00
parent 42c3df0ccd
commit 02e416169c
6 changed files with 344 additions and 81 deletions

View File

@ -199,15 +199,30 @@ struct virtkey *get_key_internal()
i = y/key_h*KEY_COLS + x/key_w; i = y/key_h*KEY_COLS + x/key_w;
#ifdef HW_RVL #ifdef HW_RVL
if (ordenador.vk_rumble) WPAD_Rumble(joy_n, 1); if (ordenador.vk_rumble)
SDL_Delay(90); {
if (ordenador.vk_rumble) WPAD_Rumble(joy_n, 0); if (joy_n < 2)
{
WPAD_Rumble(joy_n, 1);
SDL_Delay(90);
WPAD_Rumble(joy_n, 0);
}
else if (joy_n > 3)//gamepad
{
PAD_ControlMotor(joy_n-4,PAD_MOTOR_RUMBLE);
SDL_Delay(90);
PAD_ControlMotor(joy_n-4,PAD_MOTOR_STOP);
}
}
#endif #endif
#ifdef HW_DOL #ifdef HW_DOL
if (ordenador.vk_rumble) PAD_ControlMotor(joy_n,PAD_MOTOR_RUMBLE); if (ordenador.vk_rumble)
SDL_Delay(90); {
if (ordenador.vk_rumble) PAD_ControlMotor(joy_n,PAD_MOTOR_STOP); PAD_ControlMotor(joy_n,PAD_MOTOR_RUMBLE);
SDL_Delay(90);
PAD_ControlMotor(joy_n,PAD_MOTOR_STOP);
}
#endif #endif
virtkey_t *key = &keys[i]; virtkey_t *key = &keys[i];
@ -251,11 +266,14 @@ void virtkey_ir_run(void)
int key_sel = 0; int key_sel = 0;
int joy_n; int joy_n;
SDL_Joystick *joy; SDL_Joystick *joy;
static int joy_bottons_last[2][5]; static int joy_bottons_last[6][5];
static char countdown_rumble[2]; static char countdown_rumble[6];
for(joy_n=0;joy_n<ordenador.joystick_number;joy_n++) for(joy_n=0;joy_n<ordenador.joystick_number;joy_n++)
{ {
#ifdef HW_RVL
if ((joy_n == 2) || (joy_n == 3)) continue; // No wimote 3 and 4
#endif
key_sel = 0; key_sel = 0;
#ifdef HW_RVL #ifdef HW_RVL

View File

@ -54,7 +54,7 @@ extern FILE *fdebug;
#endif #endif
int countdown_buffer; int countdown_buffer;
unsigned char joybutton_matrix[2][322]; unsigned char joybutton_matrix[6][322];
void update_npixels() void update_npixels()
{ {
@ -106,6 +106,8 @@ void computer_init () { //Called only on start-up
ordenador.joystick[1] = 0; // Cursor ordenador.joystick[1] = 0; // Cursor
ordenador.joypad_as_joystick[0]= 1; ordenador.joypad_as_joystick[0]= 1;
ordenador.joypad_as_joystick[1]= 1; ordenador.joypad_as_joystick[1]= 1;
ordenador.joypad_as_joystick[4]= 1; //Gamecube controller 1
ordenador.joypad_as_joystick[5]= 1; //Gamecube controller 2
#ifdef HW_RVL #ifdef HW_RVL
ordenador.vk_auto = 1; //auto Vk ordenador.vk_auto = 1; //auto Vk
ordenador.vk_rumble = 1; //enabled ordenador.vk_rumble = 1; //enabled
@ -188,6 +190,8 @@ void computer_init () { //Called only on start-up
#ifdef HW_RVL #ifdef HW_RVL
ordenador.joybuttonkey[0][3]=SDLK_LALT; //Fire button to wiimote1 button 2 ordenador.joybuttonkey[0][3]=SDLK_LALT; //Fire button to wiimote1 button 2
ordenador.joybuttonkey[1][3]=SDLK_LALT; //Fire button to wiimote1 button 2 ordenador.joybuttonkey[1][3]=SDLK_LALT; //Fire button to wiimote1 button 2
ordenador.joybuttonkey[4][0]=SDLK_LALT; //Fire button to gamecube controller button A
ordenador.joybuttonkey[5][0]=SDLK_LALT; //Fire button to gamecube controller button A
#else // HW_DOL - Win #else // HW_DOL - Win
ordenador.joybuttonkey[0][0]=SDLK_LALT; //Fire button to gamepad button A ordenador.joybuttonkey[0][0]=SDLK_LALT; //Fire button to gamepad button A
ordenador.joybuttonkey[1][0]=SDLK_LALT; //Fire button to gamepad button A ordenador.joybuttonkey[1][0]=SDLK_LALT; //Fire button to gamepad button A
@ -1184,7 +1188,7 @@ inline void paint_one_pixel(unsigned char *colour,unsigned char *address ) {
inline void pause() { inline void pause() {
unsigned int temporal_io; unsigned int temporal_io;
SDL_Event evento,*pevento; SDL_Event evento,*pevento;
unsigned char minus_pressed[2]={2,2}; unsigned char minus_pressed[6]={2,2,2,2,2,2};
int joy_n; int joy_n;
pevento=&evento; pevento=&evento;
@ -1196,17 +1200,32 @@ inline void pause() {
for(joy_n=0;joy_n<ordenador.joystick_number;joy_n++) for(joy_n=0;joy_n<ordenador.joystick_number;joy_n++)
{ {
#ifdef HW_RVL
if ((joy_n == 2) || (joy_n == 3)) continue; // No wimote 3 and 4
#endif
#ifdef HW_DOL //Gamecube button "Z" #ifdef HW_DOL //Gamecube button "Z"
if (!SDL_JoystickGetButton(ordenador.joystick_sdl[joy_n], 4 ) && minus_pressed[joy_n]==2) minus_pressed[joy_n] = 1; //Released if (!SDL_JoystickGetButton(ordenador.joystick_sdl[joy_n], 4 ) && minus_pressed[joy_n]==2) minus_pressed[joy_n] = 1; //Released
if (SDL_JoystickGetButton(ordenador.joystick_sdl[joy_n], 4 ) && minus_pressed[joy_n]==1) minus_pressed[joy_n] = 0; //Pressed if (SDL_JoystickGetButton(ordenador.joystick_sdl[joy_n], 4 ) && minus_pressed[joy_n]==1) minus_pressed[joy_n] = 0; //Pressed
if (!SDL_JoystickGetButton(ordenador.joystick_sdl[joy_n], 4 ) && minus_pressed[joy_n]==0) return; //Released if (!SDL_JoystickGetButton(ordenador.joystick_sdl[joy_n], 4 ) && minus_pressed[joy_n]==0) return; //Released
#else //HW_RVL - WIN // Wii button "-" #else //HW_RVL - WIN // Wii button "-"
if (joy_n<2)
{
if (!SDL_JoystickGetButton(ordenador.joystick_sdl[joy_n], 4) && if (!SDL_JoystickGetButton(ordenador.joystick_sdl[joy_n], 4) &&
!SDL_JoystickGetButton(ordenador.joystick_sdl[joy_n], 17) && minus_pressed[joy_n]==2) minus_pressed[joy_n]=1; //Released !SDL_JoystickGetButton(ordenador.joystick_sdl[joy_n], 17) && minus_pressed[joy_n]==2) minus_pressed[joy_n]= 1; //Released
if ((SDL_JoystickGetButton(ordenador.joystick_sdl[joy_n], 4) || if ((SDL_JoystickGetButton(ordenador.joystick_sdl[joy_n], 4) ||
SDL_JoystickGetButton(ordenador.joystick_sdl[joy_n], 17)) && minus_pressed[joy_n]==1) minus_pressed[joy_n] = 0; //Pressed SDL_JoystickGetButton(ordenador.joystick_sdl[joy_n], 17)) && minus_pressed[joy_n]==1) minus_pressed[joy_n] = 0; //Pressed
if (!SDL_JoystickGetButton(ordenador.joystick_sdl[joy_n], 4) && if (!SDL_JoystickGetButton(ordenador.joystick_sdl[joy_n], 4) &&
!SDL_JoystickGetButton(ordenador.joystick_sdl[joy_n], 17) && minus_pressed[joy_n]==0) return; //Released !SDL_JoystickGetButton(ordenador.joystick_sdl[joy_n], 17) && minus_pressed[joy_n]==0) return; //Released
}
else //Gamecube pad button "L"
{
if (!SDL_JoystickGetButton(ordenador.joystick_sdl[joy_n], 6)
&& minus_pressed[joy_n]==2) minus_pressed[joy_n]= 1; //Released
if (SDL_JoystickGetButton(ordenador.joystick_sdl[joy_n], 6)
&& minus_pressed[joy_n]==1) minus_pressed[joy_n] = 0; //Pressed
if (!SDL_JoystickGetButton(ordenador.joystick_sdl[joy_n], 6)
&& minus_pressed[joy_n]==0) return; //Released
}
#endif #endif
} }
memset(&evento,0, sizeof(SDL_Event)); memset(&evento,0, sizeof(SDL_Event));
@ -1254,11 +1273,13 @@ inline void read_keyboard () {
SDL_Event evento,*pevento; SDL_Event evento,*pevento;
enum joystate_x {JOY_CENTER_X, JOY_LEFT, JOY_RIGHT}; enum joystate_x {JOY_CENTER_X, JOY_LEFT, JOY_RIGHT};
enum joystate_y {JOY_CENTER_Y, JOY_UP, JOY_DOWN}; enum joystate_y {JOY_CENTER_Y, JOY_UP, JOY_DOWN};
int joy_axis_x[2],joy_axis_y[2], joy_n, joybutton_n; int joy_axis_x[6],joy_axis_y[6], joy_n, joybutton_n;
unsigned char status_hat[2]; unsigned char status_hat[6];
int fire_on[2]; int fire_on[6];
fire_on[0]=0; fire_on[0]=0;
fire_on[1]=0; fire_on[1]=0;
fire_on[4]=0;
fire_on[5]=0;
ordenador.k8 = ordenador.k9 = ordenador.k10 = ordenador.k11 = ordenador.k8 = ordenador.k9 = ordenador.k10 = ordenador.k11 =
@ -1281,18 +1302,34 @@ inline void read_keyboard () {
for(joy_n=0;joy_n<ordenador.joystick_number;joy_n++) for(joy_n=0;joy_n<ordenador.joystick_number;joy_n++)
{ {
#ifdef HW_RVL
if ((joy_n == 2) || (joy_n == 3)) continue; // No wimote 3 and 4
#endif
#ifdef HW_DOL #ifdef HW_DOL
if (SDL_JoystickGetButton(ordenador.joystick_sdl[joy_n], 7)) //Gamecube button "Start" if (SDL_JoystickGetButton(ordenador.joystick_sdl[joy_n], 7)) //Gamecube button "Start"
{if (ordenador.vk_is_active) virtkey_ir_deactivate();main_menu(); } {if (ordenador.vk_is_active) virtkey_ir_deactivate();main_menu(); }
if (SDL_JoystickGetButton(ordenador.joystick_sdl[joy_n], 4)) //Gamecube button "Z" if (SDL_JoystickGetButton(ordenador.joystick_sdl[joy_n], 4)) //Gamecube button "Z"
pause(); pause();
#else //HW_RVL - WIN #else //HW_RVL - WIN
if (joy_n<2)
{
if (SDL_JoystickGetButton(ordenador.joystick_sdl[joy_n], 6) ||//Wii button "Home" if (SDL_JoystickGetButton(ordenador.joystick_sdl[joy_n], 6) ||//Wii button "Home"
SDL_JoystickGetButton(ordenador.joystick_sdl[joy_n], 19)) SDL_JoystickGetButton(ordenador.joystick_sdl[joy_n], 19))
{if (ordenador.vk_is_active) virtkey_ir_deactivate();main_menu(); } {if (ordenador.vk_is_active) virtkey_ir_deactivate();main_menu(); }
if (SDL_JoystickGetButton(ordenador.joystick_sdl[joy_n], 4) ||//Wii button "-" if (SDL_JoystickGetButton(ordenador.joystick_sdl[joy_n], 4) ||//Wii button "-"
SDL_JoystickGetButton(ordenador.joystick_sdl[joy_n], 17)) SDL_JoystickGetButton(ordenador.joystick_sdl[joy_n], 17))
pause(); pause();
}
else //Gamecube pad
{
if (SDL_JoystickGetButton(ordenador.joystick_sdl[joy_n], 7))//gamecube button "Start"
{if (ordenador.vk_is_active) virtkey_ir_deactivate();main_menu(); }
if (SDL_JoystickGetButton(ordenador.joystick_sdl[joy_n], 6))//gamecube button "L"
pause();
}
#endif #endif
#if defined(HW_RVL) || defined(HW_DOL) #if defined(HW_RVL) || defined(HW_DOL)
@ -1326,6 +1363,8 @@ inline void read_keyboard () {
} }
#ifndef HW_DOL // HW_RVL - WIN #ifndef HW_DOL // HW_RVL - WIN
if (joy_n<2)
{
for(joybutton_n=7;joybutton_n<17;joybutton_n++) for(joybutton_n=7;joybutton_n<17;joybutton_n++)
{ {
joybutton_matrix[joy_n][(ordenador.joybuttonkey[joy_n][joybutton_n])] = joybutton_matrix[joy_n][(ordenador.joybuttonkey[joy_n][joybutton_n])] =
@ -1338,6 +1377,9 @@ inline void read_keyboard () {
joybutton_matrix[joy_n][(ordenador.joybuttonkey[joy_n][18])] = joybutton_matrix[joy_n][(ordenador.joybuttonkey[joy_n][18])] =
SDL_JoystickGetButton(ordenador.joystick_sdl[joy_n], 18); SDL_JoystickGetButton(ordenador.joystick_sdl[joy_n], 18);
} }
}
else joybutton_matrix[joy_n][(ordenador.joybuttonkey[joy_n][4])] = //"Z" gamepad button
SDL_JoystickGetButton(ordenador.joystick_sdl[joy_n], 4);
#endif #endif
} }
//JOY HAT //JOY HAT
@ -1535,6 +1577,10 @@ inline void read_keyboard () {
} }
} }
for(joy_n=0;joy_n<ordenador.joystick_number;joy_n++) for(joy_n=0;joy_n<ordenador.joystick_number;joy_n++)
{
#ifdef HW_RVL
if ((joy_n == 2) || (joy_n == 3)) continue; // No wimote 3 and 4
#endif
if (!ordenador.joypad_as_joystick[joy_n]) if (!ordenador.joypad_as_joystick[joy_n])
{ //No Joypad { //No Joypad
@ -1639,17 +1685,22 @@ inline void read_keyboard () {
if (joybutton_matrix[joy_n][SDLK_LALT]) {ordenador.k15|=1; fire_on[joy_n]=1;}//fire button if (joybutton_matrix[joy_n][SDLK_LALT]) {ordenador.k15|=1; fire_on[joy_n]=1;}//fire button
break; break;
} }
}
} }
#ifdef GEKKO #ifdef GEKKO
//Wiimote Rumble //Wiimote Rumble
static Uint32 last_ticks[2]; static Uint32 last_ticks[6];
Uint32 cur_ticks; Uint32 cur_ticks;
static int rumble_on[2]; static int rumble_on[6];
static int fire_pressed[2]; static int fire_pressed[6];
for(joy_n=0;joy_n<ordenador.joystick_number;joy_n++) for(joy_n=0;joy_n<ordenador.joystick_number;joy_n++)
{
#ifdef HW_RVL
if ((joy_n == 2) || (joy_n == 3)) continue; // No wimote 3 and 4
#endif
if (ordenador.rumble[joy_n]) if (ordenador.rumble[joy_n])
{ {
@ -1658,7 +1709,10 @@ inline void read_keyboard () {
if (fire_on[joy_n] && !rumble_on[joy_n] && !fire_pressed[joy_n]) if (fire_on[joy_n] && !rumble_on[joy_n] && !fire_pressed[joy_n])
{ {
#ifdef HW_RVL #ifdef HW_RVL
if (joy_n <2)
WPAD_Rumble(joy_n, 1); WPAD_Rumble(joy_n, 1);
else if (joy_n>3)
PAD_ControlMotor(joy_n-4,PAD_MOTOR_RUMBLE);
#else //HW_DOL #else //HW_DOL
PAD_ControlMotor(joy_n,PAD_MOTOR_RUMBLE); PAD_ControlMotor(joy_n,PAD_MOTOR_RUMBLE);
#endif #endif
@ -1676,7 +1730,10 @@ inline void read_keyboard () {
if (((cur_ticks - last_ticks[joy_n] > 90) && rumble_on[joy_n] && !fire_pressed[joy_n]) ||(!fire_on[joy_n] && !rumble_on[joy_n] && fire_pressed[joy_n])) if (((cur_ticks - last_ticks[joy_n] > 90) && rumble_on[joy_n] && !fire_pressed[joy_n]) ||(!fire_on[joy_n] && !rumble_on[joy_n] && fire_pressed[joy_n]))
{ {
#ifdef HW_RVL #ifdef HW_RVL
if (joy_n <2)
WPAD_Rumble(joy_n, 0); WPAD_Rumble(joy_n, 0);
else if (joy_n>3)
PAD_ControlMotor(joy_n-4,PAD_MOTOR_STOP);
#else //HW_DOL #else //HW_DOL
PAD_ControlMotor(joy_n,PAD_MOTOR_STOP); PAD_ControlMotor(joy_n,PAD_MOTOR_STOP);
#endif #endif
@ -1687,7 +1744,10 @@ inline void read_keyboard () {
if ((cur_ticks - last_ticks[joy_n] > 90) && rumble_on[joy_n] && fire_pressed[joy_n]) if ((cur_ticks - last_ticks[joy_n] > 90) && rumble_on[joy_n] && fire_pressed[joy_n])
{ {
#ifdef HW_RVL #ifdef HW_RVL
if (joy_n <2)
WPAD_Rumble(joy_n, 0); WPAD_Rumble(joy_n, 0);
else if (joy_n>3)
PAD_ControlMotor(joy_n-4,PAD_MOTOR_STOP);
#else //HW_DOL #else //HW_DOL
PAD_ControlMotor(joy_n,PAD_MOTOR_STOP); PAD_ControlMotor(joy_n,PAD_MOTOR_STOP);
#endif #endif
@ -1696,68 +1756,69 @@ inline void read_keyboard () {
} }
} }
#endif }
#endif //GEKKO
if (ordenador.key[SDLK_SPACE]|| joybutton_matrix[0][SDLK_SPACE] || joybutton_matrix[1][SDLK_SPACE]) ordenador.k15|=1; if (ordenador.key[SDLK_SPACE]|| joybutton_matrix[0][SDLK_SPACE] || joybutton_matrix[1][SDLK_SPACE] || joybutton_matrix[4][SDLK_SPACE] || joybutton_matrix[5][SDLK_SPACE])ordenador.k15|=1;
if (ordenador.key[SDLK_LCTRL]|| joybutton_matrix[0][SDLK_LCTRL] || joybutton_matrix[1][SDLK_LCTRL]) ordenador.k15|=2; //Symbol shift if (ordenador.key[SDLK_LCTRL]|| joybutton_matrix[0][SDLK_LCTRL] || joybutton_matrix[1][SDLK_LCTRL] || joybutton_matrix[4][SDLK_LCTRL] || joybutton_matrix[5][SDLK_LCTRL]) ordenador.k15|=2; //Symbol shift
if (ordenador.key[SDLK_m] || joybutton_matrix[0][SDLK_m] || joybutton_matrix[1][SDLK_m]) ordenador.k15|=4; if (ordenador.key[SDLK_m] || joybutton_matrix[0][SDLK_m] || joybutton_matrix[1][SDLK_m] || joybutton_matrix[4][SDLK_m] || joybutton_matrix[5][SDLK_m]) ordenador.k15|=4;
if (ordenador.key[SDLK_n] || joybutton_matrix[0][SDLK_n] || joybutton_matrix[1][SDLK_n]) ordenador.k15|=8; if (ordenador.key[SDLK_n] || joybutton_matrix[0][SDLK_n] || joybutton_matrix[1][SDLK_n] || joybutton_matrix[4][SDLK_n] || joybutton_matrix[5][SDLK_n]) ordenador.k15|=8;
if (ordenador.key[SDLK_b] || joybutton_matrix[0][SDLK_b] || joybutton_matrix[1][SDLK_b]) ordenador.k15|=16; if (ordenador.key[SDLK_b] || joybutton_matrix[0][SDLK_b] || joybutton_matrix[1][SDLK_b] || joybutton_matrix[4][SDLK_b] || joybutton_matrix[5][SDLK_b]) ordenador.k15|=16;
if (ordenador.key[SDLK_PERIOD]) ordenador.k15|=6; if (ordenador.key[SDLK_PERIOD]) ordenador.k15|=6;
if (ordenador.key[SDLK_COMMA]) ordenador.k15|=10; if (ordenador.key[SDLK_COMMA]) ordenador.k15|=10;
//if (ordenador.key[SDLK_SEMICOLON]|| joybutton_matrix[0][SDLK_SEMICOLON] || joybutton_matrix[1][SDLK_SEMICOLON]) {ordenador.k13|=2; ordenador.k15|=2;} //if (ordenador.key[SDLK_SEMICOLON]|| joybutton_matrix[0][SDLK_SEMICOLON] || joybutton_matrix[1][SDLK_SEMICOLON]) {ordenador.k13|=2; ordenador.k15|=2;}
//if (ordenador.key[SDLK_QUOTEDBL]|| joybutton_matrix[0][SDLK_QUOTEDBL] || joybutton_matrix[1][SDLK_QUOTEDBL]) {ordenador.k13|=1; ordenador.k15|=2;} //if (ordenador.key[SDLK_QUOTEDBL]|| joybutton_matrix[0][SDLK_QUOTEDBL] || joybutton_matrix[1][SDLK_QUOTEDBL]) {ordenador.k13|=1; ordenador.k15|=2;}
if (ordenador.key[SDLK_RETURN] || joybutton_matrix[0][SDLK_RETURN] || joybutton_matrix[1][SDLK_RETURN]) ordenador.k14|=1; if (ordenador.key[SDLK_RETURN] || joybutton_matrix[0][SDLK_RETURN] || joybutton_matrix[1][SDLK_RETURN]) ordenador.k14|=1;
if (ordenador.key[SDLK_l] || joybutton_matrix[0][SDLK_l] || joybutton_matrix[1][SDLK_l]) ordenador.k14|=2; if (ordenador.key[SDLK_l] || joybutton_matrix[0][SDLK_l] || joybutton_matrix[1][SDLK_l] || joybutton_matrix[4][SDLK_l] || joybutton_matrix[5][SDLK_l]) ordenador.k14|=2;
if (ordenador.key[SDLK_k] || joybutton_matrix[0][SDLK_k] || joybutton_matrix[1][SDLK_k]) ordenador.k14|=4; if (ordenador.key[SDLK_k] || joybutton_matrix[0][SDLK_k] || joybutton_matrix[1][SDLK_k] || joybutton_matrix[4][SDLK_k] || joybutton_matrix[5][SDLK_k]) ordenador.k14|=4;
if (ordenador.key[SDLK_j] || joybutton_matrix[0][SDLK_j] || joybutton_matrix[1][SDLK_j]) ordenador.k14|=8; if (ordenador.key[SDLK_j] || joybutton_matrix[0][SDLK_j] || joybutton_matrix[1][SDLK_j] || joybutton_matrix[4][SDLK_j] || joybutton_matrix[5][SDLK_j]) ordenador.k14|=8;
if (ordenador.key[SDLK_h] || joybutton_matrix[0][SDLK_h] || joybutton_matrix[1][SDLK_h]) ordenador.k14|=16; if (ordenador.key[SDLK_h] || joybutton_matrix[0][SDLK_h] || joybutton_matrix[1][SDLK_h] || joybutton_matrix[4][SDLK_h] || joybutton_matrix[5][SDLK_h]) ordenador.k14|=16;
if (ordenador.key[SDLK_p] || joybutton_matrix[0][SDLK_p] || joybutton_matrix[1][SDLK_p]) ordenador.k13|=1; if (ordenador.key[SDLK_p] || joybutton_matrix[0][SDLK_p] || joybutton_matrix[1][SDLK_p] || joybutton_matrix[4][SDLK_p] || joybutton_matrix[5][SDLK_p]) ordenador.k13|=1;
if (ordenador.key[SDLK_o] || joybutton_matrix[0][SDLK_o] || joybutton_matrix[1][SDLK_o]) ordenador.k13|=2; if (ordenador.key[SDLK_o] || joybutton_matrix[0][SDLK_o] || joybutton_matrix[1][SDLK_o] || joybutton_matrix[4][SDLK_o] || joybutton_matrix[5][SDLK_o]) ordenador.k13|=2;
if (ordenador.key[SDLK_i] || joybutton_matrix[0][SDLK_i] || joybutton_matrix[1][SDLK_i]) ordenador.k13|=4; if (ordenador.key[SDLK_i] || joybutton_matrix[0][SDLK_i] || joybutton_matrix[1][SDLK_i] || joybutton_matrix[4][SDLK_i] || joybutton_matrix[5][SDLK_i]) ordenador.k13|=4;
if (ordenador.key[SDLK_u] || joybutton_matrix[0][SDLK_u] || joybutton_matrix[1][SDLK_u]) ordenador.k13|=8; if (ordenador.key[SDLK_u] || joybutton_matrix[0][SDLK_u] || joybutton_matrix[1][SDLK_u] || joybutton_matrix[4][SDLK_u] || joybutton_matrix[5][SDLK_u]) ordenador.k13|=8;
if (ordenador.key[SDLK_y] || joybutton_matrix[0][SDLK_y] || joybutton_matrix[1][SDLK_y]) ordenador.k13|=16; if (ordenador.key[SDLK_y] || joybutton_matrix[0][SDLK_y] || joybutton_matrix[1][SDLK_y] || joybutton_matrix[4][SDLK_y] || joybutton_matrix[5][SDLK_y]) ordenador.k13|=16;
if (ordenador.key[SDLK_0] || joybutton_matrix[0][SDLK_0] || joybutton_matrix[1][SDLK_0]) ordenador.k12|=1; if (ordenador.key[SDLK_0] || joybutton_matrix[0][SDLK_0] || joybutton_matrix[1][SDLK_0] || joybutton_matrix[4][SDLK_0] || joybutton_matrix[5][SDLK_0]) ordenador.k12|=1;
if (ordenador.key[SDLK_9] || joybutton_matrix[0][SDLK_9] || joybutton_matrix[1][SDLK_9]) ordenador.k12|=2; if (ordenador.key[SDLK_9] || joybutton_matrix[0][SDLK_9] || joybutton_matrix[1][SDLK_9] || joybutton_matrix[4][SDLK_9] || joybutton_matrix[5][SDLK_9]) ordenador.k12|=2;
if (ordenador.key[SDLK_8] || joybutton_matrix[0][SDLK_8] || joybutton_matrix[1][SDLK_8]) ordenador.k12|=4; if (ordenador.key[SDLK_8] || joybutton_matrix[0][SDLK_8] || joybutton_matrix[1][SDLK_8] || joybutton_matrix[4][SDLK_8] || joybutton_matrix[5][SDLK_8]) ordenador.k12|=4;
if (ordenador.key[SDLK_7] || joybutton_matrix[0][SDLK_7] || joybutton_matrix[1][SDLK_7]) ordenador.k12|=8; if (ordenador.key[SDLK_7] || joybutton_matrix[0][SDLK_7] || joybutton_matrix[1][SDLK_7] || joybutton_matrix[4][SDLK_7] || joybutton_matrix[5][SDLK_7]) ordenador.k12|=8;
if (ordenador.key[SDLK_6] || joybutton_matrix[0][SDLK_6] || joybutton_matrix[1][SDLK_6]) ordenador.k12|=16; if (ordenador.key[SDLK_6] || joybutton_matrix[0][SDLK_6] || joybutton_matrix[1][SDLK_6] || joybutton_matrix[4][SDLK_6] || joybutton_matrix[5][SDLK_6]) ordenador.k12|=16;
if (ordenador.key[SDLK_BACKSPACE] || joybutton_matrix[0][SDLK_BACKSPACE] || joybutton_matrix[1][SDLK_BACKSPACE]) {ordenador.k12|=1; ordenador.k8 |=1;} if (ordenador.key[SDLK_BACKSPACE] || joybutton_matrix[0][SDLK_BACKSPACE] || joybutton_matrix[1][SDLK_BACKSPACE] || joybutton_matrix[4][SDLK_BACKSPACE] || joybutton_matrix[5][SDLK_BACKSPACE]) {ordenador.k12|=1; ordenador.k8 |=1;}
if (ordenador.key[SDLK_1] || joybutton_matrix[0][SDLK_1] || joybutton_matrix[1][SDLK_1]) ordenador.k11|=1; if (ordenador.key[SDLK_1] || joybutton_matrix[0][SDLK_1] || joybutton_matrix[1][SDLK_1] || joybutton_matrix[4][SDLK_1] || joybutton_matrix[5][SDLK_1]) ordenador.k11|=1;
if (ordenador.key[SDLK_2] || joybutton_matrix[0][SDLK_2] || joybutton_matrix[1][SDLK_2]) ordenador.k11|=2; if (ordenador.key[SDLK_2] || joybutton_matrix[0][SDLK_2] || joybutton_matrix[1][SDLK_2] || joybutton_matrix[4][SDLK_2] || joybutton_matrix[5][SDLK_2]) ordenador.k11|=2;
if (ordenador.key[SDLK_3] || joybutton_matrix[0][SDLK_3] || joybutton_matrix[1][SDLK_3]) ordenador.k11|=4; if (ordenador.key[SDLK_3] || joybutton_matrix[0][SDLK_3] || joybutton_matrix[1][SDLK_3] || joybutton_matrix[4][SDLK_3] || joybutton_matrix[5][SDLK_3]) ordenador.k11|=4;
if (ordenador.key[SDLK_4] || joybutton_matrix[0][SDLK_4] || joybutton_matrix[1][SDLK_4]) ordenador.k11|=8; if (ordenador.key[SDLK_4] || joybutton_matrix[0][SDLK_4] || joybutton_matrix[1][SDLK_4] || joybutton_matrix[4][SDLK_4] || joybutton_matrix[5][SDLK_4]) ordenador.k11|=8;
if (ordenador.key[SDLK_5] || joybutton_matrix[0][SDLK_5] || joybutton_matrix[1][SDLK_5]) ordenador.k11|=16; if (ordenador.key[SDLK_5] || joybutton_matrix[0][SDLK_5] || joybutton_matrix[1][SDLK_5] || joybutton_matrix[4][SDLK_5] || joybutton_matrix[5][SDLK_5]) ordenador.k11|=16;
if (ordenador.key[SDLK_q] || joybutton_matrix[0][SDLK_q] || joybutton_matrix[1][SDLK_q]) ordenador.k10|=1; if (ordenador.key[SDLK_q] || joybutton_matrix[0][SDLK_q] || joybutton_matrix[1][SDLK_q] || joybutton_matrix[4][SDLK_q] || joybutton_matrix[5][SDLK_q]) ordenador.k10|=1;
if (ordenador.key[SDLK_w] || joybutton_matrix[0][SDLK_w] || joybutton_matrix[1][SDLK_w]) ordenador.k10|=2; if (ordenador.key[SDLK_w] || joybutton_matrix[0][SDLK_w] || joybutton_matrix[1][SDLK_w] || joybutton_matrix[4][SDLK_w] || joybutton_matrix[5][SDLK_w]) ordenador.k10|=2;
if (ordenador.key[SDLK_e] || joybutton_matrix[0][SDLK_e] || joybutton_matrix[1][SDLK_e]) ordenador.k10|=4; if (ordenador.key[SDLK_e] || joybutton_matrix[0][SDLK_e] || joybutton_matrix[1][SDLK_e] || joybutton_matrix[4][SDLK_e] || joybutton_matrix[5][SDLK_e]) ordenador.k10|=4;
if (ordenador.key[SDLK_r] || joybutton_matrix[0][SDLK_r] || joybutton_matrix[1][SDLK_r]) ordenador.k10|=8; if (ordenador.key[SDLK_r] || joybutton_matrix[0][SDLK_r] || joybutton_matrix[1][SDLK_r] || joybutton_matrix[4][SDLK_r] || joybutton_matrix[5][SDLK_r]) ordenador.k10|=8;
if (ordenador.key[SDLK_t] || joybutton_matrix[0][SDLK_t] || joybutton_matrix[1][SDLK_t]) ordenador.k10|=16; if (ordenador.key[SDLK_t] || joybutton_matrix[0][SDLK_t] || joybutton_matrix[1][SDLK_t]) ordenador.k10|=16;
if (ordenador.key[SDLK_a] || joybutton_matrix[0][SDLK_a] || joybutton_matrix[1][SDLK_a]) ordenador.k9 |=1; if (ordenador.key[SDLK_a] || joybutton_matrix[0][SDLK_a] || joybutton_matrix[1][SDLK_a] || joybutton_matrix[4][SDLK_a] || joybutton_matrix[5][SDLK_a]) ordenador.k9 |=1;
if (ordenador.key[SDLK_s] || joybutton_matrix[0][SDLK_s] || joybutton_matrix[1][SDLK_s]) ordenador.k9 |=2; if (ordenador.key[SDLK_s] || joybutton_matrix[0][SDLK_s] || joybutton_matrix[1][SDLK_s] || joybutton_matrix[4][SDLK_s] || joybutton_matrix[5][SDLK_s]) ordenador.k9 |=2;
if (ordenador.key[SDLK_d] || joybutton_matrix[0][SDLK_d] || joybutton_matrix[1][SDLK_d]) ordenador.k9 |=4; if (ordenador.key[SDLK_d] || joybutton_matrix[0][SDLK_d] || joybutton_matrix[1][SDLK_d] || joybutton_matrix[4][SDLK_d] || joybutton_matrix[5][SDLK_d]) ordenador.k9 |=4;
if (ordenador.key[SDLK_f] || joybutton_matrix[0][SDLK_f] || joybutton_matrix[1][SDLK_f]) ordenador.k9 |=8; if (ordenador.key[SDLK_f] || joybutton_matrix[0][SDLK_f] || joybutton_matrix[1][SDLK_f] || joybutton_matrix[4][SDLK_f] || joybutton_matrix[5][SDLK_f]) ordenador.k9 |=8;
if (ordenador.key[SDLK_g] || joybutton_matrix[0][SDLK_g] || joybutton_matrix[1][SDLK_g]) ordenador.k9 |=16; if (ordenador.key[SDLK_g] || joybutton_matrix[0][SDLK_g] || joybutton_matrix[1][SDLK_g] || joybutton_matrix[4][SDLK_g] || joybutton_matrix[5][SDLK_g]) ordenador.k9 |=16;
if (ordenador.key[SDLK_RSHIFT]||ordenador.key[SDLK_LSHIFT]|| joybutton_matrix[0][SDLK_LSHIFT] || joybutton_matrix[1][SDLK_LSHIFT]) ordenador.k8 |=1; //Caps shift if (ordenador.key[SDLK_RSHIFT]||ordenador.key[SDLK_LSHIFT]|| joybutton_matrix[0][SDLK_LSHIFT] || joybutton_matrix[1][SDLK_LSHIFT] || joybutton_matrix[4][SDLK_LSHIFT] || joybutton_matrix[5][SDLK_LSHIFT]) ordenador.k8 |=1; //Caps shift
if (ordenador.key[SDLK_z] || joybutton_matrix[0][SDLK_z] || joybutton_matrix[1][SDLK_z]) ordenador.k8 |=2; if (ordenador.key[SDLK_z] || joybutton_matrix[0][SDLK_z] || joybutton_matrix[1][SDLK_z] || joybutton_matrix[4][SDLK_z] || joybutton_matrix[5][SDLK_z]) ordenador.k8 |=2;
if (ordenador.key[SDLK_x] || joybutton_matrix[0][SDLK_x] || joybutton_matrix[1][SDLK_x]) ordenador.k8 |=4; if (ordenador.key[SDLK_x] || joybutton_matrix[0][SDLK_x] || joybutton_matrix[1][SDLK_x] || joybutton_matrix[4][SDLK_x] || joybutton_matrix[5][SDLK_x]) ordenador.k8 |=4;
if (ordenador.key[SDLK_c] || joybutton_matrix[0][SDLK_c] || joybutton_matrix[1][SDLK_c]) ordenador.k8 |=8; if (ordenador.key[SDLK_c] || joybutton_matrix[0][SDLK_c] || joybutton_matrix[1][SDLK_c] || joybutton_matrix[4][SDLK_c] || joybutton_matrix[5][SDLK_c]) ordenador.k8 |=8;
if (ordenador.key[SDLK_v] || joybutton_matrix[0][SDLK_v] || joybutton_matrix[1][SDLK_v]) ordenador.k8 |=16; if (ordenador.key[SDLK_v] || joybutton_matrix[0][SDLK_v] || joybutton_matrix[1][SDLK_v] || joybutton_matrix[4][SDLK_v] || joybutton_matrix[5][SDLK_v]) ordenador.k8 |=16;
if (ordenador.key[SDLK_UP]) {ordenador.k12 |=8;ordenador.k8|=1;} if (ordenador.key[SDLK_UP]) {ordenador.k12 |=8;ordenador.k8|=1;}
if (ordenador.key[SDLK_DOWN]) {ordenador.k12 |=16;ordenador.k8|=1;} if (ordenador.key[SDLK_DOWN]) {ordenador.k12 |=16;ordenador.k8|=1;}
if (ordenador.key[SDLK_LEFT]) {ordenador.k11 |=16;ordenador.k8|=1;} if (ordenador.key[SDLK_LEFT]) {ordenador.k11 |=16;ordenador.k8|=1;}
if (ordenador.key[SDLK_RIGHT]) {ordenador.k12 |=4;ordenador.k8|=1;} if (ordenador.key[SDLK_RIGHT]) {ordenador.k12 |=4;ordenador.k8|=1;}
if (ordenador.key[SDLK_TAB]|| joybutton_matrix[0][SDLK_TAB] || joybutton_matrix[1][SDLK_TAB]) {ordenador.k15|=2;ordenador.k8|=1;} //Extended mode if (ordenador.key[SDLK_TAB]|| joybutton_matrix[0][SDLK_TAB] || joybutton_matrix[1][SDLK_TAB] || joybutton_matrix[4][SDLK_TAB] || joybutton_matrix[5][SDLK_TAB]) {ordenador.k15|=2;ordenador.k8|=1;} //Extended mode
if (ordenador.key[SDLK_INSERT]|| joybutton_matrix[0][SDLK_INSERT] || joybutton_matrix[1][SDLK_INSERT]) {ordenador.k11|=1;ordenador.k8|=1;} //Edit if (ordenador.key[SDLK_INSERT]|| joybutton_matrix[0][SDLK_INSERT] || joybutton_matrix[1][SDLK_INSERT] || joybutton_matrix[4][SDLK_INSERT] || joybutton_matrix[5][SDLK_INSERT]) {ordenador.k11|=1;ordenador.k8|=1;} //Edit
ordenador.s8 = (ordenador.s8 & 0xE0) | (ordenador.k8 ^ 0x1F); ordenador.s8 = (ordenador.s8 & 0xE0) | (ordenador.k8 ^ 0x1F);
ordenador.s9 = (ordenador.s9 & 0xE0) | (ordenador.k9 ^ 0x1F); ordenador.s9 = (ordenador.s9 & 0xE0) | (ordenador.k9 ^ 0x1F);
@ -1780,13 +1841,17 @@ inline void read_keyboard () {
//VK activation/deactivation //VK activation/deactivation
static char old_plus_button[2]; static char old_plus_button[6];
char plus_button[2]; char plus_button[6];
if (!ordenador.vk_auto) if (!ordenador.vk_auto)
for(joy_n=0;joy_n<ordenador.joystick_number;joy_n++) for(joy_n=0;joy_n<ordenador.joystick_number;joy_n++)
{ {
#ifdef HW_RVL
if ((joy_n == 2) || (joy_n == 3)) continue; // No wimote 3 and 4
#endif
plus_button[joy_n] = SDL_JoystickGetButton(ordenador.joystick_sdl[joy_n], 5) || //Wii button "+" - Gamecube "R" plus_button[joy_n] = SDL_JoystickGetButton(ordenador.joystick_sdl[joy_n], 5) || //Wii button "+" - Gamecube "R"
SDL_JoystickGetButton(ordenador.joystick_sdl[joy_n], 18); SDL_JoystickGetButton(ordenador.joystick_sdl[joy_n], 18);

View File

@ -38,7 +38,7 @@ enum taptypes {TAP_TAP, TAP_TZX};
enum block_type {NOBLOCK, PROG, VAR, DATA}; enum block_type {NOBLOCK, PROG, VAR, DATA};
extern int countdown_buffer; extern int countdown_buffer;
extern unsigned char joybutton_matrix[2][322]; extern unsigned char joybutton_matrix[6][322];
struct computer { struct computer {
@ -164,7 +164,7 @@ struct computer {
unsigned char mode128k; // 0=48K, 1=128K, 2=+2, 3=+3 4=sp unsigned char mode128k; // 0=48K, 1=128K, 2=+2, 3=+3 4=sp
unsigned char videosystem; //0=PAL, 1=NTSC unsigned char videosystem; //0=PAL, 1=NTSC
unsigned char se_basic; //0=0ff; 1=0n unsigned char se_basic; //0=0ff; 1=0n
unsigned char joystick[2]; // 0=cursor, 1=kempston, 2=sinclair1, 3=sinclair2, 4=Fuller, 5=QAOP unsigned char joystick[6]; // 0=cursor, 1=kempston, 2=sinclair1, 3=sinclair2, 4=Fuller, 5=QAOP
unsigned char port254; unsigned char port254;
@ -268,12 +268,12 @@ struct computer {
unsigned int kbd_buffer_pointer; unsigned int kbd_buffer_pointer;
unsigned char *key; unsigned char *key;
unsigned char joystick_number; unsigned char joystick_number;
SDL_Joystick *joystick_sdl[2]; SDL_Joystick *joystick_sdl[6];
unsigned char joy_axis_x_state[2]; unsigned char joy_axis_x_state[6];
unsigned char joy_axis_y_state[2]; unsigned char joy_axis_y_state[6];
unsigned int joybuttonkey[2][23]; unsigned int joybuttonkey[6][23];
unsigned char joypad_as_joystick[2]; unsigned char joypad_as_joystick[6];
unsigned char rumble[2]; unsigned char rumble[6];
unsigned char vk_auto; unsigned char vk_auto;
unsigned char vk_rumble; unsigned char vk_rumble;
unsigned char vk_is_active; unsigned char vk_is_active;

View File

@ -560,7 +560,11 @@ if (sound_type==SOUND_SDL)
// Open joystick // Open joystick
ordenador.joystick_number = SDL_NumJoysticks(); ordenador.joystick_number = SDL_NumJoysticks();
printf("Found %d joysticks \n", ordenador.joystick_number); printf("Found %d joysticks \n", ordenador.joystick_number);
#ifdef HW_RVL
if (ordenador.joystick_number>6) ordenador.joystick_number = 6; //Open max 6 joysticks (4 wimotes + 2 gamecube controllers)
#else
if (ordenador.joystick_number>2) ordenador.joystick_number = 2; //Open max 2 joysticks if (ordenador.joystick_number>2) ordenador.joystick_number = 2; //Open max 2 joysticks
#endif
printf("Try to open %d joysticks \n", ordenador.joystick_number); printf("Try to open %d joysticks \n", ordenador.joystick_number);
for (bucle=0;bucle<ordenador.joystick_number;bucle++) { for (bucle=0;bucle<ordenador.joystick_number;bucle++) {
ordenador.joystick_sdl [bucle] = SDL_JoystickOpen(bucle); ordenador.joystick_sdl [bucle] = SDL_JoystickOpen(bucle);
@ -784,6 +788,10 @@ int save_config(struct computer *object, char *filename) {
fprintf(fconfig,"se_basic=%c%c",48+object->se_basic,10); fprintf(fconfig,"se_basic=%c%c",48+object->se_basic,10);
fprintf(fconfig,"joystick1=%c%c",48+object->joystick[0],10); fprintf(fconfig,"joystick1=%c%c",48+object->joystick[0],10);
fprintf(fconfig,"joystick2=%c%c",48+object->joystick[1],10); fprintf(fconfig,"joystick2=%c%c",48+object->joystick[1],10);
#ifdef HW_RVL
fprintf(fconfig,"joystick5=%c%c",48+object->joystick[4],10); //Gamecube controller 1
fprintf(fconfig,"joystick6=%c%c",48+object->joystick[5],10); //Gamecube controller 2
#endif
fprintf(fconfig,"ay_sound=%c%c",48+object->ay_emul,10); fprintf(fconfig,"ay_sound=%c%c",48+object->ay_emul,10);
fprintf(fconfig,"fuller_box_sound=%c%c",48+object->fuller_box_sound,10); fprintf(fconfig,"fuller_box_sound=%c%c",48+object->fuller_box_sound,10);
fprintf(fconfig,"currah_microspeech=%c%c",48+object->currah_active,10); fprintf(fconfig,"currah_microspeech=%c%c",48+object->currah_active,10);
@ -803,8 +811,16 @@ int save_config(struct computer *object, char *filename) {
fprintf(fconfig,"rewind_on_reset=%c%c",48+object->rewind_on_reset,10); fprintf(fconfig,"rewind_on_reset=%c%c",48+object->rewind_on_reset,10);
fprintf(fconfig,"joypad1=%c%c",48+object->joypad_as_joystick[0],10); fprintf(fconfig,"joypad1=%c%c",48+object->joypad_as_joystick[0],10);
fprintf(fconfig,"joypad2=%c%c",48+object->joypad_as_joystick[1],10); fprintf(fconfig,"joypad2=%c%c",48+object->joypad_as_joystick[1],10);
#ifdef HW_RVL
fprintf(fconfig,"joypad5=%c%c",48+object->joypad_as_joystick[4],10); //Gamecube controller 1
fprintf(fconfig,"joypad6=%c%c",48+object->joypad_as_joystick[5],10); //Gamecube controller 1
#endif
fprintf(fconfig,"rumble1=%c%c",48+object->rumble[0],10); fprintf(fconfig,"rumble1=%c%c",48+object->rumble[0],10);
fprintf(fconfig,"rumble2=%c%c",48+object->rumble[1],10); fprintf(fconfig,"rumble2=%c%c",48+object->rumble[1],10);
#ifdef HW_RVL
fprintf(fconfig,"rumble5=%c%c",48+object->rumble[4],10); //Gamecube controller 1
fprintf(fconfig,"rumble6=%c%c",48+object->rumble[5],10); //Gamecube controller 1
#endif
fprintf(fconfig,"port=%c%c",48+object->port,10); fprintf(fconfig,"port=%c%c",48+object->port,10);
fprintf(fconfig,"autoconf=%c%c",48+object->autoconf,10); fprintf(fconfig,"autoconf=%c%c",48+object->autoconf,10);
fprintf(fconfig,"ignore_z80_joy_conf=%c%c",48+object->ignore_z80_joy_conf,10); fprintf(fconfig,"ignore_z80_joy_conf=%c%c",48+object->ignore_z80_joy_conf,10);
@ -812,9 +828,14 @@ int save_config(struct computer *object, char *filename) {
fprintf(fconfig,"vk_auto=%c%c",48+object->vk_auto,10); fprintf(fconfig,"vk_auto=%c%c",48+object->vk_auto,10);
fprintf(fconfig,"vk_rumble=%c%c",48+object->vk_rumble,10); fprintf(fconfig,"vk_rumble=%c%c",48+object->vk_rumble,10);
for (joy_n=0; joy_n<2; joy_n++) for (joy_n=0; joy_n<ordenador.joystick_number; joy_n++)
{
#ifdef HW_RVL
if ((joy_n == 2) || (joy_n == 3)) continue; // No wimote 3 and 4
#endif
for (key=0; key<23; key++) for (key=0; key<23; key++)
fprintf(fconfig,"joybutton_%c_%c=%.3d%c",joy_n+48,key+97, object->joybuttonkey[joy_n][key],10); fprintf(fconfig,"joybutton_%c_%c=%.3d%c",joy_n+48,key+97, object->joybuttonkey[joy_n][key],10);
}
fclose(fconfig); fclose(fconfig);
return 0; return 0;
@ -839,18 +860,34 @@ int save_config_game(struct computer *object, char *filename, int overwrite) {
fprintf(fconfig,"joystick1=%c%c",48+object->joystick[0],10); fprintf(fconfig,"joystick1=%c%c",48+object->joystick[0],10);
fprintf(fconfig,"joystick2=%c%c",48+object->joystick[1],10); fprintf(fconfig,"joystick2=%c%c",48+object->joystick[1],10);
#ifdef HW_RVL
fprintf(fconfig,"joystick5=%c%c",48+object->joystick[4],10); //Gamecube controller 1
fprintf(fconfig,"joystick6=%c%c",48+object->joystick[5],10); //Gamecube controller 2
#endif
fprintf(fconfig,"joypad1=%c%c",48+object->joypad_as_joystick[0],10); fprintf(fconfig,"joypad1=%c%c",48+object->joypad_as_joystick[0],10);
fprintf(fconfig,"joypad2=%c%c",48+object->joypad_as_joystick[1],10); fprintf(fconfig,"joypad2=%c%c",48+object->joypad_as_joystick[1],10);
#ifdef HW_RVL
fprintf(fconfig,"joypad5=%c%c",48+object->joypad_as_joystick[4],10); //Gamecube controller 1
fprintf(fconfig,"joypad6=%c%c",48+object->joypad_as_joystick[5],10); //Gamecube controller 1
#endif
fprintf(fconfig,"rumble1=%c%c",48+object->rumble[0],10); fprintf(fconfig,"rumble1=%c%c",48+object->rumble[0],10);
fprintf(fconfig,"rumble2=%c%c",48+object->rumble[1],10); fprintf(fconfig,"rumble2=%c%c",48+object->rumble[1],10);
#ifdef HW_RVL
fprintf(fconfig,"rumble5=%c%c",48+object->rumble[4],10); //Gamecube controller 1
fprintf(fconfig,"rumble6=%c%c",48+object->rumble[5],10); //Gamecube controller 1
#endif
for (joy_n=0; joy_n<2; joy_n++) for (joy_n=0; joy_n<ordenador.joystick_number; joy_n++)
{
#ifdef HW_RVL
if ((joy_n == 2) || (joy_n == 3)) continue; // No wimote 3 and 4
#endif
for (key=0; key<23; key++) for (key=0; key<23; key++)
fprintf(fconfig,"joybutton_%c_%c=%.3d%c",joy_n+48,key+97, object->joybuttonkey[joy_n][key],10); fprintf(fconfig,"joybutton_%c_%c=%.3d%c",joy_n+48,key+97, object->joybuttonkey[joy_n][key],10);
}
fclose(fconfig); fclose(fconfig);
return 0; return 0;
} }
void load_config_network(struct computer *object) { void load_config_network(struct computer *object) {
@ -975,9 +1012,9 @@ int load_config(struct computer *object, char *filename) {
char line[256],carac,done; char line[256],carac,done;
int pos, key_sdl=0; int pos, key_sdl=0;
FILE *fconfig; FILE *fconfig;
unsigned char volume=255,mode128k=255,issue=255,ntsc=255, joystick1=255,joystick2=255,ay_emul=255,mdr_active=255, unsigned char volume=255,mode128k=255,issue=255,ntsc=255, joystick1=255,joystick2=255,joystick5=255,joystick6=255,ay_emul=255,mdr_active=255,
dblscan=255,framerate =255, screen =255, text=255, precision=255, bw=255, tap_fast=255, audio_mode=255, dblscan=255,framerate =255, screen =255, text=255, precision=255, bw=255, tap_fast=255, audio_mode=255,
joypad1=255, joypad2=255, rumble1=255, rumble2=255, joy_n=255, key_n=255, port=255, autoconf=255, turbo=225, vk_auto=255, vk_rumble=255, joypad1=255, joypad2=255, joypad5=255, joypad6=255,rumble1=255, rumble2=255, rumble5=255, rumble6=255,joy_n=255, key_n=255, port=255, autoconf=255, turbo=225, vk_auto=255, vk_rumble=255,
rewind_on_reset=255, pause_instant_load =255, ignore_z80_joy_conf=255, gui_volume=255, fuller_box_sound=255, currah_active = 255, se_basic =255, currah_volume = 255; rewind_on_reset=255, pause_instant_load =255, ignore_z80_joy_conf=255, gui_volume=255, fuller_box_sound=255, currah_active = 255, se_basic =255, currah_volume = 255;
if (filename) strcpy(config_path,filename); if (filename) strcpy(config_path,filename);
@ -1036,6 +1073,14 @@ int load_config(struct computer *object, char *filename) {
joystick2=line[10]-'0'; joystick2=line[10]-'0';
continue; continue;
} }
if (!strncmp(line,"joystick5=",10)) {
joystick5=line[10]-'0';
continue;
}
if (!strncmp(line,"joystick6=",10)) {
joystick6=line[10]-'0';
continue;
}
if (!strncmp(line,"ay_sound=",9)) { if (!strncmp(line,"ay_sound=",9)) {
ay_emul=line[9]-'0'; ay_emul=line[9]-'0';
continue; continue;
@ -1112,6 +1157,14 @@ int load_config(struct computer *object, char *filename) {
joypad2=line[8]-'0'; joypad2=line[8]-'0';
continue; continue;
} }
if (!strncmp(line,"joypad5=",8)) {
joypad5=line[8]-'0';
continue;
}
if (!strncmp(line,"joypad6=",8)) {
joypad6=line[8]-'0';
continue;
}
if (!strncmp(line,"rumble1=",8)) { if (!strncmp(line,"rumble1=",8)) {
rumble1=line[8]-'0'; rumble1=line[8]-'0';
continue; continue;
@ -1120,6 +1173,14 @@ int load_config(struct computer *object, char *filename) {
rumble2=line[8]-'0'; rumble2=line[8]-'0';
continue; continue;
} }
if (!strncmp(line,"rumble5=",8)) {
rumble5=line[8]-'0';
continue;
}
if (!strncmp(line,"rumble6=",8)) {
rumble6=line[8]-'0';
continue;
}
if (!strncmp(line,"port=",5)) { if (!strncmp(line,"port=",5)) {
port=line[5]-'0'; port=line[5]-'0';
continue; continue;
@ -1146,7 +1207,7 @@ int load_config(struct computer *object, char *filename) {
} }
if (!strncmp(line,"joybutton_",10)) { if (!strncmp(line,"joybutton_",10)) {
sscanf(line, "joybutton_%c_%c=%3d",&joy_n ,&key_n, &key_sdl); sscanf(line, "joybutton_%c_%c=%3d",&joy_n ,&key_n, &key_sdl);
if ((joy_n<50) && (joy_n>47) && (key_n<120) && (key_n>96)) if ((joy_n<54) && (joy_n>47) && (key_n<120) && (key_n>96))
object->joybuttonkey[joy_n-48][key_n-97]=key_sdl; object->joybuttonkey[joy_n-48][key_n-97]=key_sdl;
continue; continue;
} }
@ -1170,6 +1231,12 @@ int load_config(struct computer *object, char *filename) {
if (joystick2<6) { if (joystick2<6) {
object->joystick[1]=joystick2; object->joystick[1]=joystick2;
} }
if (joystick5<6) {
object->joystick[4]=joystick5;
}
if (joystick6<6) {
object->joystick[5]=joystick6;
}
if (ay_emul<2) { if (ay_emul<2) {
object->ay_emul=ay_emul; object->ay_emul=ay_emul;
} }
@ -1229,12 +1296,24 @@ int load_config(struct computer *object, char *filename) {
if (joypad2<2) { if (joypad2<2) {
object->joypad_as_joystick[1]=joypad2; object->joypad_as_joystick[1]=joypad2;
} }
if (joypad5<2) {
object->joypad_as_joystick[4]=joypad5;
}
if (joypad6<2) {
object->joypad_as_joystick[5]=joypad6;
}
if (rumble1<2) { if (rumble1<2) {
object->rumble[0]=rumble1; object->rumble[0]=rumble1;
} }
if (rumble2<2) { if (rumble2<2) {
object->rumble[1]=rumble2; object->rumble[1]=rumble2;
} }
if (rumble5<2) {
object->rumble[4]=rumble5;
}
if (rumble6<2) {
object->rumble[5]=rumble6;
}
if (port<5) { if (port<5) {
object->port=port; object->port=port;
} }

View File

@ -79,7 +79,11 @@ static const char *main_menu_messages[] = {
/*03*/ "^|Load|Save|Delete", /*03*/ "^|Load|Save|Delete",
/*04*/ "#1------------------------", /*04*/ "#1------------------------",
/*05*/ "Controller configuration", /*05*/ "Controller configuration",
/*06*/ "^|Controller1|Controller2", #ifdef HW_RVL
/*06*/ "^|Wiimote1|Wiimote2|GCube1|GCube2",
#else
/*06*/ "^|Controller1|Controller2",
#endif
/*07*/ "Tape settings", /*07*/ "Tape settings",
/*08*/ "Emulation settings", /*08*/ "Emulation settings",
/*09*/ "Screen settings", /*09*/ "Screen settings",
@ -193,6 +197,20 @@ static const char *input_messages[] = {
NULL NULL
}; };
static const char *input_messages_gamecube_controller[] = {
/*00*/ "Joystick type",
/*01*/ "^|Curs|Kemps|Sincl1|Sincl2|Fuller|QAOP",
/*02*/ "Bind key to button",
/*03*/ "^|A|B|X|Y|Z",
/*04*/ "Bind key to D-pad",
/*05*/ "^|Up|Down|Left|Right",
/*06*/ "Use D-pad as Joystick",
/*07*/ "^|On|Off",
/*08*/ "Rumble",
/*09*/ "^|On|Off",
NULL
};
static const char *microdrive_messages[] = { static const char *microdrive_messages[] = {
/*00*/ "Microdrive", /*00*/ "Microdrive",
/*01*/ "^|Insert|Load|Make|Delete", /*01*/ "^|Insert|Load|Make|Delete",
@ -880,7 +898,7 @@ static void setup_joystick(int joy, unsigned int sdl_key, int joy_key)
if (ordenador.joybuttonkey[joy][loop] == sdl_key) ordenador.joybuttonkey[joy][loop] =0; if (ordenador.joybuttonkey[joy][loop] == sdl_key) ordenador.joybuttonkey[joy][loop] =0;
ordenador.joybuttonkey[joy][joy_key] = sdl_key; ordenador.joybuttonkey[joy][joy_key] = sdl_key;
printf("Configurated button %d of controller %d as SDL_KEY %d\n", joy_key, joy, sdl_key);
} }
static void input_options(int joy) static void input_options(int joy)
@ -896,6 +914,8 @@ static void input_options(int joy)
struct virtkey *virtualkey; struct virtkey *virtualkey;
if ((joy != 0) && (joy != 1)) return; //only wiimote
do { do {
memset(submenus, 0, sizeof(submenus)); memset(submenus, 0, sizeof(submenus));
@ -944,8 +964,65 @@ static void input_options(int joy)
setup_joystick(joy, sdl_key, joy_key); setup_joystick(joy, sdl_key, joy_key);
} while (opt == 2 || opt == 4 || opt == 6 || opt == 8); } while (opt == 2 || opt == 4 || opt == 6 || opt == 8);
}
static void input_options_gamecube_controller(int joy)
{
const unsigned int gamecube_controller_to_sdl[] = {0, 1, 2, 3, 4};
const unsigned int pad_to_sdl[] = {19, 20, 21, 22};
int joy_key = 1;
unsigned int sdl_key;
unsigned int submenus[5];
int opt;
struct virtkey *virtualkey;
if ((joy != 4) && (joy != 5)) return; //only gamecube controllers
do {
memset(submenus, 0, sizeof(submenus));
submenus[0] = ordenador.joystick[joy];
submenus[3] = !ordenador.joypad_as_joystick[joy];
submenus[4] = !ordenador.rumble[joy];
opt = menu_select_title("Gamecube controller configuration",
input_messages_gamecube_controller, submenus);
if (opt < 0)
return;
ordenador.joystick[joy] = submenus[0];
ordenador.joypad_as_joystick[joy] = !submenus[3];
ordenador.rumble[joy] = !submenus[4];
if (opt == 0 || opt == 6|| opt == 8)
return;
VirtualKeyboard.sel_x = 64;
VirtualKeyboard.sel_y = 90;
virtualkey = get_key();
if (virtualkey == NULL)
return;
sdl_key = virtualkey->sdl_code;
if (virtualkey->sdl_code==1) //"Done" selected
{if (virtualkey->caps_on) sdl_key = 304; //Caps Shit
else if (virtualkey->sym_on) sdl_key = 306; //Sym Shit
else return; }
switch(opt)
{
case 2: // buttons
joy_key = gamecube_controller_to_sdl[submenus[1]]; break;
case 4: // D-pad
joy_key = pad_to_sdl[submenus[2]]; break;
default:
break;
}
setup_joystick(joy, sdl_key, joy_key);
} while (opt == 2 || opt == 4);
} }
static int select_mdr() static int select_mdr()
@ -2476,7 +2553,8 @@ void main_menu()
retorno = save_load_snapshot(submenus[1]); retorno = save_load_snapshot(submenus[1]);
break; break;
case 5: case 5:
input_options(submenus[2]); if (submenus[2]<2) input_options(submenus[2]);
else input_options_gamecube_controller(submenus[2]+2);
break; break;
case 7: case 7:
tape_settings(); tape_settings();

View File

@ -1156,12 +1156,14 @@ uint32_t menu_wait_key_press(int *joy_n_p)
SDL_Joystick *joy; SDL_Joystick *joy;
static int joy_keys_changed; static int joy_keys_changed;
static int joy_keys_last; static int joy_keys_last;
static int joy_bottons_last[2][8]; static int joy_bottons_last[6][8];
SDL_JoystickUpdate(); SDL_JoystickUpdate();
/* Wii-specific, sorry */ /* Wii-specific, sorry */
for (nr = 0; nr < ordenador.joystick_number; nr++) { for (nr = 0; nr < ordenador.joystick_number; nr++) {
#ifdef HW_RVL
if ((nr == 2) || (nr == 3)) continue; // No wimote 3 and 4
#endif
joy = ordenador.joystick_sdl[nr]; joy = ordenador.joystick_sdl[nr];
if (!joy) if (!joy)
continue; continue;
@ -1196,7 +1198,8 @@ uint32_t menu_wait_key_press(int *joy_n_p)
if (axis1 < -15000 ) keys |= KEY_UP; if (axis1 < -15000 ) keys |= KEY_UP;
else if( axis1 > 15000 ) keys |= KEY_DOWN; else if( axis1 > 15000 ) keys |= KEY_DOWN;
if (nr<2)
{
if ((!SDL_JoystickGetButton(joy, 0) && joy_bottons_last[nr][0]) || /* A */ if ((!SDL_JoystickGetButton(joy, 0) && joy_bottons_last[nr][0]) || /* A */
(!SDL_JoystickGetButton(joy, 3) && joy_bottons_last[nr][1]) || /* 2 */ (!SDL_JoystickGetButton(joy, 3) && joy_bottons_last[nr][1]) || /* 2 */
(!SDL_JoystickGetButton(joy, 9) && joy_bottons_last[nr][2]) || /* CA */ (!SDL_JoystickGetButton(joy, 9) && joy_bottons_last[nr][2]) || /* CA */
@ -1222,6 +1225,21 @@ uint32_t menu_wait_key_press(int *joy_n_p)
joy_bottons_last[nr][5] =SDL_JoystickGetButton(joy, 11) ; /* CX */ joy_bottons_last[nr][5] =SDL_JoystickGetButton(joy, 11) ; /* CX */
joy_bottons_last[nr][6] =SDL_JoystickGetButton(joy, 12) ; /* CY */ joy_bottons_last[nr][6] =SDL_JoystickGetButton(joy, 12) ; /* CY */
joy_bottons_last[nr][7] =SDL_JoystickGetButton(joy, 1) ; /* B */ joy_bottons_last[nr][7] =SDL_JoystickGetButton(joy, 1) ; /* B */
}
else
{
if ((!SDL_JoystickGetButton(joy, 0) && joy_bottons_last[nr][0])) /* Gamecube button A */
keys |= KEY_SELECT;
if ((!SDL_JoystickGetButton(joy, 1) && joy_bottons_last[nr][1])) /* Gamecube button B */
keys |= KEY_ESCAPE;
if (SDL_JoystickGetButton(joy, 2) != 0) /* Gamecube button X */
keys |= KEY_PAGEUP;
if (SDL_JoystickGetButton(joy, 3) != 0) /* Gamecube button Y */
keys |= KEY_PAGEDOWN;
joy_bottons_last[nr][0]=SDL_JoystickGetButton(joy, 0) ; /* Gamecube button A */
joy_bottons_last[nr][1] =SDL_JoystickGetButton(joy, 1) ; /* Gamecube button B */
}
joy_keys_changed = keys != joy_keys_last; joy_keys_changed = keys != joy_keys_last;
@ -1239,6 +1257,11 @@ uint32_t menu_wait_key_press(int *joy_n_p)
//Quick scrolling //Quick scrolling
if (!joy_n_p) //We do not want fast scrolling with the vk if (!joy_n_p) //We do not want fast scrolling with the vk
for (nr = 0; nr < ordenador.joystick_number; nr++) { for (nr = 0; nr < ordenador.joystick_number; nr++) {
#ifdef HW_RVL
if ((nr == 2) || (nr == 3)) continue; // No wimote 3 and 4
#endif
joy = ordenador.joystick_sdl[nr]; joy = ordenador.joystick_sdl[nr];
Sint16 axis3 = SDL_JoystickGetAxis(joy, 3); Sint16 axis3 = SDL_JoystickGetAxis(joy, 3);