redquark-amiberry-rb/src/od-pandora/pandora_input.cpp

600 lines
16 KiB
C++
Raw Normal View History

#include "sysconfig.h"
#include "sysdeps.h"
#include "options.h"
#include "keyboard.h"
#include "inputdevice.h"
#include <SDL.h>
static int joyXviaCustom = 0;
static int joyYviaCustom = 0;
static int joyButXviaCustom[7] = { 0, 0, 0, 0, 0, 0, 0};
static int mouseBut1viaCustom = 0;
static int mouseBut2viaCustom = 0;
#define MAX_MOUSE_BUTTONS 2
#define MAX_MOUSE_AXES 2
#define FIRST_MOUSE_AXIS 0
#define FIRST_MOUSE_BUTTON MAX_MOUSE_AXES
static int init_mouse (void)
{
return 1;
}
static void close_mouse (void)
{
}
static int acquire_mouse (int num, int flags)
{
return 1;
}
static void unacquire_mouse (int num)
{
}
static int get_mouse_num (void)
{
return 2;
}
static TCHAR *get_mouse_friendlyname (int mouse)
{
if(mouse == 0)
return "Nubs as mouse";
else
return "dPad as mouse";
}
static TCHAR *get_mouse_uniquename (int mouse)
{
if(mouse == 0)
return "MOUSE0";
else
return "MOUSE1";
}
static int get_mouse_widget_num (int mouse)
{
return MAX_MOUSE_AXES + MAX_MOUSE_BUTTONS;
}
static int get_mouse_widget_first (int mouse, int type)
{
switch (type) {
case IDEV_WIDGET_BUTTON:
return FIRST_MOUSE_BUTTON;
case IDEV_WIDGET_AXIS:
return FIRST_MOUSE_AXIS;
case IDEV_WIDGET_BUTTONAXIS:
return MAX_MOUSE_AXES + MAX_MOUSE_BUTTONS;
}
return -1;
}
static int get_mouse_widget_type (int mouse, int num, TCHAR *name, uae_u32 *code)
{
if (num >= MAX_MOUSE_AXES && num < MAX_MOUSE_AXES + MAX_MOUSE_BUTTONS) {
if (name)
sprintf (name, "Button %d", num + 1 - MAX_MOUSE_AXES);
return IDEV_WIDGET_BUTTON;
} else if (num < MAX_MOUSE_AXES) {
if (name) {
if(num == 0)
sprintf (name, "X Axis");
else if (num == 1)
sprintf (name, "Y Axis");
else
sprintf (name, "Axis %d", num + 1);
}
return IDEV_WIDGET_AXIS;
}
return IDEV_WIDGET_NONE;
}
static void read_mouse (void)
{
if(currprefs.input_tablet > TABLET_OFF) {
// Mousehack active
int x, y;
SDL_GetMouseState(&x, &y);
setmousestate(0, 0, x, 1);
setmousestate(0, 1, y, 1);
}
if(currprefs.jports[0].id == JSEM_MICE + 1 || currprefs.jports[1].id == JSEM_MICE + 1) {
// dPad is mouse
Uint8 *keystate = SDL_GetKeyState(NULL);
int mouseScale = currprefs.input_joymouse_multiplier / 4;
if(keystate[SDLK_LEFT])
setmousestate(1, 0, -mouseScale, 0);
if(keystate[SDLK_RIGHT])
setmousestate(1, 0, mouseScale, 0);
if(keystate[SDLK_UP])
setmousestate(1, 1, -mouseScale, 0);
if(keystate[SDLK_DOWN])
setmousestate(1, 1, mouseScale, 0);
if(!mouseBut1viaCustom)
setmousebuttonstate (1, 0, keystate[SDLK_HOME]); // A button -> left mouse
if(!mouseBut2viaCustom)
setmousebuttonstate (1, 1, keystate[SDLK_END]); // B button -> right mouse
}
// Nubs as mouse handled in handle_msgpump()
}
static int get_mouse_flags (int num)
{
return 0;
}
struct inputdevice_functions inputdevicefunc_mouse = {
init_mouse, close_mouse, acquire_mouse, unacquire_mouse, read_mouse,
get_mouse_num, get_mouse_friendlyname, get_mouse_uniquename,
get_mouse_widget_num, get_mouse_widget_type,
get_mouse_widget_first,
get_mouse_flags
};
static void setid (struct uae_input_device *uid, int i, int slot, int sub, int port, int evt)
{
uid->eventid[slot][SPARE_SUB_EVENT] = uid->eventid[slot][sub];
uid->flags[slot][SPARE_SUB_EVENT] = uid->flags[slot][sub];
uid->port[slot][SPARE_SUB_EVENT] = MAX_JPORTS + 1;
uid[i].eventid[slot][sub] = evt;
uid[i].port[slot][sub] = port + 1;
}
static void setid_af (struct uae_input_device *uid, int i, int slot, int sub, int port, int evt, int af)
{
setid (uid, i, slot, sub, port, evt);
uid[i].flags[slot][sub] &= ~ID_FLAG_AUTOFIRE_MASK;
if (af >= JPORT_AF_NORMAL)
uid[i].flags[slot][sub] |= ID_FLAG_AUTOFIRE;
}
int input_get_default_mouse (struct uae_input_device *uid, int i, int port, int af)
{
setid (uid, i, ID_AXIS_OFFSET + 0, 0, port, port ? INPUTEVENT_MOUSE2_HORIZ : INPUTEVENT_MOUSE1_HORIZ);
setid (uid, i, ID_AXIS_OFFSET + 1, 0, port, port ? INPUTEVENT_MOUSE2_VERT : INPUTEVENT_MOUSE1_VERT);
setid_af (uid, i, ID_BUTTON_OFFSET + 0, 0, port, port ? INPUTEVENT_JOY2_FIRE_BUTTON : INPUTEVENT_JOY1_FIRE_BUTTON, af);
setid (uid, i, ID_BUTTON_OFFSET + 1, 0, port, port ? INPUTEVENT_JOY2_2ND_BUTTON : INPUTEVENT_JOY1_2ND_BUTTON);
if (i == 0)
return 1;
return 0;
}
static int init_kb (void)
{
return 1;
}
static void close_kb (void)
{
}
static int acquire_kb (int num, int flags)
{
return 1;
}
static void unacquire_kb (int num)
{
}
static void read_kb (void)
{
}
static int get_kb_num (void)
{
return 1;
}
static TCHAR *get_kb_friendlyname (int kb)
{
return strdup("Default Keyboard");
}
static TCHAR *get_kb_uniquename (int kb)
{
return strdup("KEYBOARD0");
}
static int get_kb_widget_num (int kb)
{
return 255;
}
static int get_kb_widget_first (int kb, int type)
{
return 0;
}
static int get_kb_widget_type (int kb, int num, TCHAR *name, uae_u32 *code)
{
if(code)
*code = num;
return IDEV_WIDGET_KEY;
}
static int get_kb_flags (int num)
{
return 0;
}
struct inputdevice_functions inputdevicefunc_keyboard = {
init_kb, close_kb, acquire_kb, unacquire_kb, read_kb,
get_kb_num, get_kb_friendlyname, get_kb_uniquename,
get_kb_widget_num, get_kb_widget_type,
get_kb_widget_first,
get_kb_flags
};
int input_get_default_keyboard (int num)
{
if (num == 0) {
return 1;
}
return 0;
}
#define MAX_JOY_BUTTONS 7
#define MAX_JOY_AXES 2
#define FIRST_JOY_AXIS 0
#define FIRST_JOY_BUTTON MAX_JOY_AXES
2016-07-24 12:38:03 +02:00
static int nr_joysticks = 0;
static char JoystickName[MAX_INPUT_DEVICES][40];
static SDL_Joystick* Joysticktable[MAX_INPUT_DEVICES];
2016-07-24 12:38:03 +02:00
static int get_joystick_num (void)
{
2016-07-24 12:38:03 +02:00
// Keep joystick 0 as Pandora implementation...
return (nr_joysticks + 1);
}
static int init_joystick (void)
{
//This function is called too many times... we can filter if number of joy is good...
if (nr_joysticks == SDL_NumJoysticks ())
2016-07-24 12:38:03 +02:00
return 1;
nr_joysticks = SDL_NumJoysticks ();
if (nr_joysticks > MAX_INPUT_DEVICES)
nr_joysticks = MAX_INPUT_DEVICES;
2016-07-24 12:38:03 +02:00
for (int cpt; cpt < nr_joysticks; cpt++)
{
Joysticktable[cpt] = SDL_JoystickOpen (cpt);
strncpy(JoystickName[cpt],SDL_JoystickName(cpt),40);
printf("Joystick %i : %s\n",cpt,JoystickName[cpt]);
printf(" Buttons: %i Axis: %i Hats: %i\n",SDL_JoystickNumButtons(Joysticktable[cpt]),SDL_JoystickNumAxes(Joysticktable[cpt]),SDL_JoystickNumHats(Joysticktable[cpt]));
}
return 1;
}
static void close_joystick (void)
{
2016-07-24 12:38:03 +02:00
for (int cpt; cpt < nr_joysticks; cpt++)
{
SDL_JoystickClose (Joysticktable[cpt]);
}
}
2016-07-24 12:38:03 +02:00
static int acquire_joystick (int num, int flags)
{
return 1;
}
static void unacquire_joystick (int num)
{
}
static TCHAR *get_joystick_friendlyname (int joy)
{
2016-07-24 12:38:03 +02:00
if (joy == 0)
return "dPad as joystick";
else
return JoystickName[joy - 1];
}
static TCHAR *get_joystick_uniquename (int joy)
{
if (joy == 0)
return "JOY0";
if (joy == 1)
return "JOY1";
if (joy == 2)
return "JOY2";
if (joy == 3)
return "JOY3";
if (joy == 4)
return "JOY4";
if (joy == 5)
return "JOY5";
if (joy == 6)
return "JOY6";
return "JOY7";
}
static int get_joystick_widget_num (int joy)
{
return MAX_JOY_AXES + MAX_JOY_BUTTONS;
}
static int get_joystick_widget_first (int joy, int type)
{
switch (type) {
case IDEV_WIDGET_BUTTON:
return FIRST_JOY_BUTTON;
case IDEV_WIDGET_AXIS:
return FIRST_JOY_AXIS;
case IDEV_WIDGET_BUTTONAXIS:
return MAX_JOY_AXES + MAX_JOY_BUTTONS;
}
return -1;
}
static int get_joystick_widget_type (int joy, int num, TCHAR *name, uae_u32 *code)
{
if (num >= MAX_JOY_AXES && num < MAX_JOY_AXES + MAX_JOY_BUTTONS) {
if (name) {
switch(num)
{
case FIRST_JOY_BUTTON:
sprintf (name, "Button X/CD32 red");
break;
case FIRST_JOY_BUTTON + 1:
sprintf (name, "Button B/CD32 blue");
break;
case FIRST_JOY_BUTTON + 2:
sprintf (name, "Button A/CD32 green");
break;
case FIRST_JOY_BUTTON + 3:
sprintf (name, "Button Y/CD32 yellow");
break;
case FIRST_JOY_BUTTON + 4:
sprintf (name, "CD32 start");
break;
case FIRST_JOY_BUTTON + 5:
sprintf (name, "CD32 ffw");
break;
case FIRST_JOY_BUTTON + 6:
sprintf (name, "CD32 rwd");
break;
}
}
return IDEV_WIDGET_BUTTON;
} else if (num < MAX_JOY_AXES) {
if (name) {
if(num == 0)
sprintf (name, "X Axis");
else if (num == 1)
sprintf (name, "Y Axis");
else
sprintf (name, "Axis %d", num + 1);
}
return IDEV_WIDGET_AXIS;
}
return IDEV_WIDGET_NONE;
}
static int get_joystick_flags (int num)
{
return 0;
}
static void read_joystick (void)
{
for (int joyid = 0; joyid < MAX_JPORTS ; joyid ++)
// First handle fake joystick from pandora...
if(currprefs.jports[joyid].id == JSEM_JOYS)
{
Uint8 *keystate = SDL_GetKeyState(NULL);
if(!keystate[SDLK_RCTRL])
{ // Right shoulder + dPad -> cursor keys
int axis = (keystate[SDLK_LEFT] ? -32767 : (keystate[SDLK_RIGHT] ? 32767 : 0));
if(!joyXviaCustom)
setjoystickstate (0, 0, axis, 32767);
axis = (keystate[SDLK_UP] ? -32767 : (keystate[SDLK_DOWN] ? 32767 : 0));
if(!joyYviaCustom)
setjoystickstate (0, 1, axis, 32767);
}
if(!joyButXviaCustom[0])
setjoybuttonstate (0, 0, keystate[SDLK_PAGEDOWN]);
if(!joyButXviaCustom[1])
setjoybuttonstate (0, 1, keystate[SDLK_END]);
if(!joyButXviaCustom[2])
setjoybuttonstate (0, 2, keystate[SDLK_HOME]);
if(!joyButXviaCustom[3])
setjoybuttonstate (0, 3, keystate[SDLK_PAGEUP]);
int cd32_start = 0, cd32_ffw = 0, cd32_rwd = 0;
if(keystate[SDLK_LALT]) { // Pandora Start button
if(keystate[SDLK_RSHIFT]) // Left shoulder
cd32_rwd = 1;
else if (keystate[SDLK_RCTRL]) // Right shoulder
cd32_ffw = 1;
else
cd32_start = 1;
}
if(!joyButXviaCustom[6])
setjoybuttonstate (0, 6, cd32_start);
if(!joyButXviaCustom[5])
setjoybuttonstate (0, 5, cd32_ffw);
if(!joyButXviaCustom[4])
setjoybuttonstate (0, 4, cd32_rwd);
}
else if (jsem_isjoy(joyid,&currprefs) != -1)
{
// Now we handle real SDL joystick...
int hostjoyid = currprefs.jports[joyid].id - JSEM_JOYS -1;
int hat = SDL_JoystickGetHat(Joysticktable[hostjoyid],0);
int val = SDL_JoystickGetAxis(Joysticktable[hostjoyid], 0);
if (hat & SDL_HAT_RIGHT)
setjoystickstate (hostjoyid + 1, 0, 32767, 32767);
else
if (hat & SDL_HAT_LEFT)
setjoystickstate (hostjoyid + 1, 0, -32767, 32767);
else
setjoystickstate (hostjoyid + 1, 0, val, 32767);
val = SDL_JoystickGetAxis(Joysticktable[hostjoyid], 1);
if (hat & SDL_HAT_UP)
setjoystickstate (hostjoyid + 1, 1, -32767, 32767);
else
if (hat & SDL_HAT_DOWN)
setjoystickstate (hostjoyid + 1, 1, 32767, 32767);
else
setjoystickstate (hostjoyid + 1, 1, val, 32767);
2016-07-24 12:38:03 +02:00
setjoybuttonstate (hostjoyid + 1, 0, (SDL_JoystickGetButton(Joysticktable[hostjoyid], 0) & 1) );
setjoybuttonstate (hostjoyid + 1, 1, (SDL_JoystickGetButton(Joysticktable[hostjoyid], 1) & 1) );
setjoybuttonstate (hostjoyid + 1, 2, (SDL_JoystickGetButton(Joysticktable[hostjoyid], 2) & 1) );
setjoybuttonstate (hostjoyid + 1, 3, (SDL_JoystickGetButton(Joysticktable[hostjoyid], 3) & 1) );
2016-07-24 12:38:03 +02:00
// cd32 start, ffw, rwd
setjoybuttonstate (hostjoyid + 1, 4, (SDL_JoystickGetButton(Joysticktable[hostjoyid], 4) & 1) );
setjoybuttonstate (hostjoyid + 1, 5, (SDL_JoystickGetButton(Joysticktable[hostjoyid], 5) & 1) );
setjoybuttonstate (hostjoyid + 1, 6, (SDL_JoystickGetButton(Joysticktable[hostjoyid], 6) & 1) );
}
}
struct inputdevice_functions inputdevicefunc_joystick = {
init_joystick, close_joystick, acquire_joystick, unacquire_joystick,
read_joystick, get_joystick_num, get_joystick_friendlyname, get_joystick_uniquename,
get_joystick_widget_num, get_joystick_widget_type,
get_joystick_widget_first,
get_joystick_flags
};
int input_get_default_joystick (struct uae_input_device *uid, int num, int port, int af, int mode)
{
int h, v;
h = port ? INPUTEVENT_JOY2_HORIZ : INPUTEVENT_JOY1_HORIZ;;
v = port ? INPUTEVENT_JOY2_VERT : INPUTEVENT_JOY1_VERT;
setid (uid, num, ID_AXIS_OFFSET + 0, 0, port, h);
setid (uid, num, ID_AXIS_OFFSET + 1, 0, port, v);
setid_af (uid, num, ID_BUTTON_OFFSET + 0, 0, port, port ? INPUTEVENT_JOY2_FIRE_BUTTON : INPUTEVENT_JOY1_FIRE_BUTTON, af);
setid (uid, num, ID_BUTTON_OFFSET + 1, 0, port, port ? INPUTEVENT_JOY2_2ND_BUTTON : INPUTEVENT_JOY1_2ND_BUTTON);
setid (uid, num, ID_BUTTON_OFFSET + 2, 0, port, port ? INPUTEVENT_JOY2_3RD_BUTTON : INPUTEVENT_JOY1_3RD_BUTTON);
if (mode == JSEM_MODE_JOYSTICK_CD32) {
setid_af (uid, num, ID_BUTTON_OFFSET + 0, 0, port, port ? INPUTEVENT_JOY2_CD32_RED : INPUTEVENT_JOY1_CD32_RED, af);
setid_af (uid, num, ID_BUTTON_OFFSET + 0, 1, port, port ? INPUTEVENT_JOY2_FIRE_BUTTON : INPUTEVENT_JOY1_FIRE_BUTTON, af);
setid (uid, num, ID_BUTTON_OFFSET + 1, 0, port, port ? INPUTEVENT_JOY2_CD32_BLUE : INPUTEVENT_JOY1_CD32_BLUE);
setid (uid, num, ID_BUTTON_OFFSET + 1, 1, port, port ? INPUTEVENT_JOY2_2ND_BUTTON : INPUTEVENT_JOY1_2ND_BUTTON);
setid (uid, num, ID_BUTTON_OFFSET + 2, 0, port, port ? INPUTEVENT_JOY2_CD32_GREEN : INPUTEVENT_JOY1_CD32_GREEN);
setid (uid, num, ID_BUTTON_OFFSET + 3, 0, port, port ? INPUTEVENT_JOY2_CD32_YELLOW : INPUTEVENT_JOY1_CD32_YELLOW);
setid (uid, num, ID_BUTTON_OFFSET + 4, 0, port, port ? INPUTEVENT_JOY2_CD32_RWD : INPUTEVENT_JOY1_CD32_RWD);
setid (uid, num, ID_BUTTON_OFFSET + 5, 0, port, port ? INPUTEVENT_JOY2_CD32_FFW : INPUTEVENT_JOY1_CD32_FFW);
setid (uid, num, ID_BUTTON_OFFSET + 6, 0, port, port ? INPUTEVENT_JOY2_CD32_PLAY : INPUTEVENT_JOY1_CD32_PLAY);
}
if (num == 0) {
return 1;
}
return 0;
}
int input_get_default_joystick_analog (struct uae_input_device *uid, int num, int port, int af)
{
return 0;
}
void SimulateMouseOrJoy(int code, int keypressed)
{
switch(code) {
case REMAP_MOUSEBUTTON_LEFT:
mouseBut1viaCustom = keypressed;
setmousebuttonstate (0, 0, keypressed);
setmousebuttonstate (1, 0, keypressed);
break;
case REMAP_MOUSEBUTTON_RIGHT:
mouseBut2viaCustom = keypressed;
setmousebuttonstate (0, 1, keypressed);
setmousebuttonstate (1, 1, keypressed);
break;
case REMAP_JOYBUTTON_ONE:
joyButXviaCustom[0] = keypressed;
setjoybuttonstate (0, 0, keypressed);
break;
case REMAP_JOYBUTTON_TWO:
joyButXviaCustom[1] = keypressed;
setjoybuttonstate (0, 1, keypressed);
break;
case REMAP_JOY_UP:
joyYviaCustom = keypressed;
setjoystickstate (0, 1, keypressed ? -32767 : 0, 32767);
break;
case REMAP_JOY_DOWN:
joyYviaCustom = keypressed;
setjoystickstate (0, 1, keypressed ? 32767 : 0, 32767);
break;
case REMAP_JOY_LEFT:
joyXviaCustom = keypressed;
setjoystickstate (0, 0, keypressed ? -32767 : 0, 32767);
break;
case REMAP_JOY_RIGHT:
joyXviaCustom = keypressed;
setjoystickstate (0, 0, keypressed ? 32767 : 0, 32767);
break;
case REMAP_CD32_GREEN:
joyButXviaCustom[2] = keypressed;
setjoybuttonstate (0, 2, keypressed);
break;
case REMAP_CD32_YELLOW:
joyButXviaCustom[3] = keypressed;
setjoybuttonstate (0, 3, keypressed);
break;
case REMAP_CD32_PLAY:
joyButXviaCustom[6] = keypressed;
setjoybuttonstate (0, 6, keypressed);
break;
case REMAP_CD32_FFW:
joyButXviaCustom[5] = keypressed;
setjoybuttonstate (0, 5, keypressed);
break;
case REMAP_CD32_RWD:
joyButXviaCustom[4] = keypressed;
setjoybuttonstate (0, 4, keypressed);
break;
}
}