mirror of
https://github.com/ekeeke/Genesis-Plus-GX.git
synced 2025-01-28 10:55:28 +01:00
improved Wiimote support for mouse emulation
VDP code cleanup
This commit is contained in:
parent
0f4da285f8
commit
9092121e60
@ -455,9 +455,6 @@ static void wpad_config(u8 chan, u8 exp, u8 max_keys)
|
|||||||
VIDEO_Flush();
|
VIDEO_Flush();
|
||||||
}
|
}
|
||||||
|
|
||||||
static float old_x = 0.0;
|
|
||||||
static float old_y = 0.0;
|
|
||||||
|
|
||||||
static void wpad_update(s8 chan, u8 i, u32 exp)
|
static void wpad_update(s8 chan, u8 i, u32 exp)
|
||||||
{
|
{
|
||||||
/* WPAD data */
|
/* WPAD data */
|
||||||
@ -551,10 +548,13 @@ static void wpad_update(s8 chan, u8 i, u32 exp)
|
|||||||
|
|
||||||
case DEVICE_MOUSE:
|
case DEVICE_MOUSE:
|
||||||
{
|
{
|
||||||
/* Mouse relative movement (-255,255) */
|
/* Mouse relative movement (9 bits signed value) */
|
||||||
|
input.analog[2][0] = 0;
|
||||||
|
input.analog[2][1] = 0;
|
||||||
|
|
||||||
|
/* Nunchuk/Classic controller analog stick */
|
||||||
if (x || y)
|
if (x || y)
|
||||||
{
|
{
|
||||||
/* analog stick relative positions */
|
|
||||||
input.analog[2][0] = (x * 2) / ANALOG_SENSITIVITY;
|
input.analog[2][0] = (x * 2) / ANALOG_SENSITIVITY;
|
||||||
input.analog[2][1] = -(y * 2) / ANALOG_SENSITIVITY;
|
input.analog[2][1] = -(y * 2) / ANALOG_SENSITIVITY;
|
||||||
}
|
}
|
||||||
@ -564,19 +564,10 @@ static void wpad_update(s8 chan, u8 i, u32 exp)
|
|||||||
{
|
{
|
||||||
struct ir_t ir;
|
struct ir_t ir;
|
||||||
WPAD_IR(chan, &ir);
|
WPAD_IR(chan, &ir);
|
||||||
if (ir.valid)
|
if(ir.smooth_valid)
|
||||||
{
|
{
|
||||||
/* calculate mouse values (FIXME) */
|
input.analog[2][0] = (int)((ir.sx - 512) / 2 / ANALOG_SENSITIVITY);
|
||||||
input.analog[2][0] = (ir.x - old_x);
|
input.analog[2][1] = (int)((ir.sy - 384) * 2 / 3 / ANALOG_SENSITIVITY);
|
||||||
input.analog[2][1] = (ir.y - old_y);
|
|
||||||
old_x = ir.x;
|
|
||||||
old_y = ir.y;
|
|
||||||
if (input.analog[2][0] > 255)
|
|
||||||
input.analog[2][0] = 255;
|
|
||||||
else if (input.analog[2][0] < -255)
|
|
||||||
input.analog[2][0] = -255;
|
|
||||||
if (input.analog[2][1] > 255) input.analog[2][1] = 255;
|
|
||||||
else if (input.analog[2][1] < -255) input.analog[2][1] = -255;
|
|
||||||
|
|
||||||
/* use default trigger button */
|
/* use default trigger button */
|
||||||
if (p & WPAD_BUTTON_B)
|
if (p & WPAD_BUTTON_B)
|
||||||
@ -585,7 +576,7 @@ static void wpad_update(s8 chan, u8 i, u32 exp)
|
|||||||
}
|
}
|
||||||
|
|
||||||
#ifdef USB_MOUSE
|
#ifdef USB_MOUSE
|
||||||
/* USB mouse support (NOT WORKING) */
|
/* USB mouse support (FIXME) */
|
||||||
if (MOUSE_IsConnected())
|
if (MOUSE_IsConnected())
|
||||||
{
|
{
|
||||||
mouse_event event;
|
mouse_event event;
|
||||||
|
25
source/vdp.c
25
source/vdp.c
@ -438,7 +438,7 @@ unsigned int vdp_ctrl_r(void)
|
|||||||
if (!(reg[1] & 0x40))
|
if (!(reg[1] & 0x40))
|
||||||
temp |= 0x08;
|
temp |= 0x08;
|
||||||
|
|
||||||
/* HBLANK flag (Sonic 3 and Sonic 2 "VS Modes", Lemmings 2, Mega Turrican, Gouketsuji Ichizoku) */
|
/* HBLANK flag (Sonic 3 and Sonic 2 "VS Modes", Lemmings 2, Mega Turrican, V.R Troopers, Gouketsuji Ichizoku, ...) */
|
||||||
if ((mcycles_68k % MCYCLES_PER_LINE) < 588)
|
if ((mcycles_68k % MCYCLES_PER_LINE) < 588)
|
||||||
temp |= 0x04;
|
temp |= 0x04;
|
||||||
|
|
||||||
@ -456,10 +456,13 @@ unsigned int vdp_ctrl_r(void)
|
|||||||
|
|
||||||
unsigned int vdp_hvc_r(void)
|
unsigned int vdp_hvc_r(void)
|
||||||
{
|
{
|
||||||
|
/* Horizontal Counter (Striker, Mickey Mania, Skitchin, Road Rash I,II,III, ...) */
|
||||||
uint8 hc = (hc_latch & 0x100) ? (hc_latch & 0xFF) : hctab[mcycles_68k%MCYCLES_PER_LINE];
|
uint8 hc = (hc_latch & 0x100) ? (hc_latch & 0xFF) : hctab[mcycles_68k%MCYCLES_PER_LINE];
|
||||||
|
|
||||||
|
/* Vertical Counter */
|
||||||
uint8 vc = vctab[v_counter];
|
uint8 vc = vctab[v_counter];
|
||||||
|
|
||||||
/* interlace mode 2 */
|
/* interlace mode 2 (Sonic the Hedgehog 2, Combat Cars) */
|
||||||
if (im2_flag)
|
if (im2_flag)
|
||||||
vc = (vc << 1) | ((vc >> 7) & 1);
|
vc = (vc << 1) | ((vc >> 7) & 1);
|
||||||
|
|
||||||
@ -813,13 +816,13 @@ static inline void reg_w(unsigned int r, unsigned int d)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Display status modified during Horizontal Blanking (Legend of Galahad, Lemmings 2, */
|
/* Display status modified during HBLANK (Legend of Galahad, Lemmings 2, Formula 1 Championship, */
|
||||||
/* Nigel Mansell's World Championship Racing, Deadly Moves, Power Athlete, ...) */
|
/* Nigel Mansell's World Championship Racing, ...) */
|
||||||
/* */
|
/* */
|
||||||
/* Note that this is not entirely correct since we are cheating with the HBLANK period limits */
|
/* Note that this is not entirely correct since we are cheating with the HBLANK period limits and */
|
||||||
/* and still redrawing the whole line. This is done because some game (PAL version of Nigel */
|
/* still redrawing the whole line. This is done because some games (forexample, the PAL version */
|
||||||
/* Mansell's World Championship Racing actually) appear to disable display outside HBLANK. On */
|
/* of Nigel Mansell's World Championship Racing) appear to disable display outside HBLANK. */
|
||||||
/* real hardware, the raster line would appear partially blanked. */
|
/* On real hardware, the raster line would appear partially blanked. */
|
||||||
if ((r & 0x40) && !(status & 8))
|
if ((r & 0x40) && !(status & 8))
|
||||||
{
|
{
|
||||||
if (mcycles_68k <= (hint_68k + 860))
|
if (mcycles_68k <= (hint_68k + 860))
|
||||||
@ -863,11 +866,7 @@ static inline void reg_w(unsigned int r, unsigned int d)
|
|||||||
|
|
||||||
case 5: /* SATB */
|
case 5: /* SATB */
|
||||||
reg[5] = d;
|
reg[5] = d;
|
||||||
if (reg[12] & 1)
|
satb = (d << 9) & sat_base_mask;
|
||||||
satb = (d << 9) & 0xFC00;
|
|
||||||
else
|
|
||||||
satb = (d << 9) & 0xFE00;
|
|
||||||
|
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 7:
|
case 7:
|
||||||
|
Loading…
x
Reference in New Issue
Block a user