mirror of
https://github.com/libretro/RetroArch
synced 2025-04-10 06:44:27 +00:00
implement keymapper
This commit is contained in:
parent
fe8a0657b4
commit
cd72bd1bb4
@ -275,6 +275,7 @@ typedef struct settings
|
|||||||
unsigned audio_block_frames;
|
unsigned audio_block_frames;
|
||||||
unsigned audio_latency;
|
unsigned audio_latency;
|
||||||
unsigned input_remap_ids[MAX_USERS][RARCH_CUSTOM_BIND_LIST_END];
|
unsigned input_remap_ids[MAX_USERS][RARCH_CUSTOM_BIND_LIST_END];
|
||||||
|
unsigned input_keymapper_ids[RARCH_CUSTOM_BIND_LIST_END];
|
||||||
|
|
||||||
/* Set by autoconfiguration in joypad_autoconfig_dir.
|
/* Set by autoconfiguration in joypad_autoconfig_dir.
|
||||||
* Does not override main binds. */
|
* Does not override main binds. */
|
||||||
|
@ -579,6 +579,11 @@ void input_poll(void)
|
|||||||
if (input_driver_remote)
|
if (input_driver_remote)
|
||||||
input_remote_poll(input_driver_remote, max_users);
|
input_remote_poll(input_driver_remote, max_users);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#ifdef HAVE_KEYMAPPER
|
||||||
|
if (input_driver_mapper)
|
||||||
|
input_mapper_poll(input_driver_mapper);
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -662,6 +667,11 @@ int16_t input_state(unsigned port, unsigned device,
|
|||||||
input_remote_state(&res, port, device, idx, id);
|
input_remote_state(&res, port, device, idx, id);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#ifdef HAVE_KEYMAPPER
|
||||||
|
if (input_driver_mapper)
|
||||||
|
input_mapper_state(&res, port, device, idx, id);
|
||||||
|
#endif
|
||||||
|
|
||||||
/* Don't allow turbo for D-pad. */
|
/* Don't allow turbo for D-pad. */
|
||||||
if (device == RETRO_DEVICE_JOYPAD && (id < RETRO_DEVICE_ID_JOYPAD_UP ||
|
if (device == RETRO_DEVICE_JOYPAD && (id < RETRO_DEVICE_ID_JOYPAD_UP ||
|
||||||
id > RETRO_DEVICE_ID_JOYPAD_RIGHT))
|
id > RETRO_DEVICE_ID_JOYPAD_RIGHT))
|
||||||
|
@ -28,11 +28,8 @@
|
|||||||
|
|
||||||
#include <compat/strl.h>
|
#include <compat/strl.h>
|
||||||
#include <compat/posix_string.h>
|
#include <compat/posix_string.h>
|
||||||
#include <file/file_path.h>
|
|
||||||
#include <retro_miscellaneous.h>
|
#include <retro_miscellaneous.h>
|
||||||
#include <libretro.h>
|
#include <libretro.h>
|
||||||
#include <net/net_compat.h>
|
|
||||||
#include <net/net_socket.h>
|
|
||||||
|
|
||||||
#ifdef HAVE_CONFIG_H
|
#ifdef HAVE_CONFIG_H
|
||||||
#include "../config.h"
|
#include "../config.h"
|
||||||
@ -44,45 +41,82 @@
|
|||||||
#include "../msg_hash.h"
|
#include "../msg_hash.h"
|
||||||
#include "../verbosity.h"
|
#include "../verbosity.h"
|
||||||
|
|
||||||
|
#define MAPPER_GET_KEY(state, key) (((state)->keys[(key) / 32] >> ((key) % 32)) & 1)
|
||||||
|
#define MAPPER_SET_KEY(state, key) (state)->keys[(key) / 32] |= 1 << ((key) % 32)
|
||||||
|
|
||||||
struct input_mapper
|
struct input_mapper
|
||||||
{
|
{
|
||||||
|
/* The controller port that will be polled*/
|
||||||
#if defined(HAVE_NETWORKING) && defined(HAVE_NETWORKGAMEPAD)
|
uint8_t port;
|
||||||
int net_fd[MAX_USERS];
|
|
||||||
#endif
|
|
||||||
|
|
||||||
bool state[RARCH_BIND_LIST_END];
|
|
||||||
};
|
|
||||||
|
|
||||||
typedef struct input_mapper_state
|
|
||||||
{
|
|
||||||
/* This is a bitmask of (1 << key_bind_id). */
|
/* This is a bitmask of (1 << key_bind_id). */
|
||||||
uint64_t buttons;
|
uint64_t buttons;
|
||||||
/* Left X, Left Y, Right X, Right Y */
|
/* Left X, Left Y, Right X, Right Y */
|
||||||
int16_t analog[4];
|
int16_t analog[4];
|
||||||
/* the whole keyboard state */
|
/* the whole keyboard state */
|
||||||
uint32_t keys[RETROK_LAST / 32 + 1];
|
uint32_t keys[RETROK_LAST / 32 + 1];
|
||||||
} input_mapper_state_t;
|
};
|
||||||
|
|
||||||
|
static input_mapper_t *mapper_ptr;
|
||||||
|
|
||||||
input_mapper_t *input_mapper_new(uint16_t port)
|
input_mapper_t *input_mapper_new(uint16_t port)
|
||||||
{
|
{
|
||||||
return NULL;
|
settings_t *settings = config_get_ptr();
|
||||||
|
input_mapper_t* handle = (input_mapper_t*)
|
||||||
|
calloc(1, sizeof(*handle));
|
||||||
|
|
||||||
|
if (!handle)
|
||||||
|
return NULL;
|
||||||
|
|
||||||
|
/* testing values*/
|
||||||
|
settings->uints.input_keymapper_ids[0] = RETROK_n;
|
||||||
|
settings->uints.input_keymapper_ids[1] = RETROK_SPACE;
|
||||||
|
settings->uints.input_keymapper_ids[2] = RETROK_F1;
|
||||||
|
settings->uints.input_keymapper_ids[3] = RETROK_RETURN;
|
||||||
|
settings->uints.input_keymapper_ids[4] = RETROK_UP;
|
||||||
|
settings->uints.input_keymapper_ids[5] = RETROK_DOWN;
|
||||||
|
settings->uints.input_keymapper_ids[6] = RETROK_LEFT;
|
||||||
|
settings->uints.input_keymapper_ids[7] = RETROK_RIGHT;
|
||||||
|
settings->uints.input_keymapper_ids[8] = RETROK_F1;
|
||||||
|
settings->uints.input_keymapper_ids[9] = RETROK_F2;
|
||||||
|
settings->uints.input_keymapper_ids[10] = RETROK_F3;
|
||||||
|
settings->uints.input_keymapper_ids[11] = RETROK_F4;
|
||||||
|
settings->uints.input_keymapper_ids[12] = RETROK_F5;
|
||||||
|
settings->uints.input_keymapper_ids[13] = RETROK_F6;
|
||||||
|
settings->uints.input_keymapper_ids[14] = RETROK_F7;
|
||||||
|
settings->uints.input_keymapper_ids[15] = RETROK_F8;
|
||||||
|
|
||||||
|
|
||||||
|
handle->port = port;
|
||||||
|
mapper_ptr = handle;
|
||||||
|
return handle;
|
||||||
}
|
}
|
||||||
|
|
||||||
void input_mapper_free(input_mapper_t *handle)
|
void input_mapper_free(input_mapper_t *handle)
|
||||||
{
|
{
|
||||||
return;
|
free (handle);
|
||||||
}
|
}
|
||||||
|
|
||||||
void input_mapper_poll(input_mapper_t *handle, unsigned max_users)
|
void input_mapper_poll(input_mapper_t *handle)
|
||||||
{
|
{
|
||||||
return;
|
settings_t *settings = config_get_ptr();
|
||||||
}
|
unsigned device = settings->uints.input_libretro_device[handle->port];
|
||||||
|
device &= RETRO_DEVICE_MASK;
|
||||||
|
|
||||||
bool input_mapper_key_pressed(int key, unsigned port)
|
/* for now we only handle keyboard inputs */
|
||||||
{
|
if (device == RETRO_DEVICE_KEYBOARD)
|
||||||
return false;
|
{
|
||||||
|
memset(handle->keys, 0, sizeof(handle->keys));
|
||||||
|
|
||||||
|
for (int i = 0; i < RARCH_CUSTOM_BIND_LIST_END; i++)
|
||||||
|
{
|
||||||
|
if(i < RETROK_LAST)
|
||||||
|
{
|
||||||
|
if (input_state(0, RETRO_DEVICE_JOYPAD, handle->port, i))
|
||||||
|
MAPPER_SET_KEY (handle, settings->uints.input_keymapper_ids[i]);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
void input_mapper_state(
|
void input_mapper_state(
|
||||||
@ -92,5 +126,25 @@ void input_mapper_state(
|
|||||||
unsigned idx,
|
unsigned idx,
|
||||||
unsigned id)
|
unsigned id)
|
||||||
{
|
{
|
||||||
|
|
||||||
|
switch (device)
|
||||||
|
{
|
||||||
|
case RETRO_DEVICE_KEYBOARD:
|
||||||
|
if (id < RETROK_LAST)
|
||||||
|
{
|
||||||
|
/*
|
||||||
|
RARCH_LOG("State: UDLR %u %u %u %u\n",
|
||||||
|
MAPPER_GET_KEY(mapper_ptr, RETROK_UP),
|
||||||
|
MAPPER_GET_KEY(mapper_ptr, RETROK_DOWN),
|
||||||
|
MAPPER_GET_KEY(mapper_ptr, RETROK_LEFT),
|
||||||
|
MAPPER_GET_KEY(mapper_ptr, RETROK_RIGHT)
|
||||||
|
);*/
|
||||||
|
|
||||||
|
if (MAPPER_GET_KEY(mapper_ptr, id))
|
||||||
|
*ret |= 1;
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
@ -35,9 +35,9 @@ input_mapper_t *input_mapper_new(uint16_t port);
|
|||||||
|
|
||||||
void input_mapper_free(input_mapper_t *handle);
|
void input_mapper_free(input_mapper_t *handle);
|
||||||
|
|
||||||
void input_mapper_poll(input_mapper_t *handle, unsigned max_users);
|
void input_mapper_poll(input_mapper_t *handle);
|
||||||
|
|
||||||
bool input_mapper_key_pressed(int key, unsigned port);
|
bool input_mapper_key_pressed(int key);
|
||||||
|
|
||||||
void input_mapper_state(
|
void input_mapper_state(
|
||||||
int16_t *ret,
|
int16_t *ret,
|
||||||
|
@ -734,6 +734,12 @@ void input_state_overlay(input_overlay_t *ol, int16_t *ret,
|
|||||||
case RETRO_DEVICE_KEYBOARD:
|
case RETRO_DEVICE_KEYBOARD:
|
||||||
if (id < RETROK_LAST)
|
if (id < RETROK_LAST)
|
||||||
{
|
{
|
||||||
|
/*RARCH_LOG("UDLR %u %u %u %u\n",
|
||||||
|
OVERLAY_GET_KEY(ol_state, RETROK_UP),
|
||||||
|
OVERLAY_GET_KEY(ol_state, RETROK_DOWN),
|
||||||
|
OVERLAY_GET_KEY(ol_state, RETROK_LEFT),
|
||||||
|
OVERLAY_GET_KEY(ol_state, RETROK_RIGHT)
|
||||||
|
);*/
|
||||||
if (OVERLAY_GET_KEY(ol_state, id))
|
if (OVERLAY_GET_KEY(ol_state, id))
|
||||||
*ret |= 1;
|
*ret |= 1;
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user