From a658822289e10e37363fc60153492738fb43095a Mon Sep 17 00:00:00 2001 From: svdijk Date: Mon, 23 Dec 2013 14:37:41 +0100 Subject: setup: Add key_mission to the controls group. Otherwise, the same key can be bound to "Show mission" and one of the other "More controls..." at the same time. --- src/setup/keyboard.c | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/setup/keyboard.c b/src/setup/keyboard.c index 6b1667e1..0e576870 100644 --- a/src/setup/keyboard.c +++ b/src/setup/keyboard.c @@ -43,7 +43,7 @@ static int *controls[] = { &key_left, &key_right, &key_up, &key_down, &key_flyup, &key_flydown, &key_flycenter, &key_lookup, &key_lookdown, &key_lookcenter, &key_invleft, &key_invright, &key_invquery, - &key_invuse, &key_invpop, &key_invkey, + &key_invuse, &key_invpop, &key_mission, &key_invkey, &key_invhome, &key_invend, &key_invdrop, &key_useartifact, &key_pause, &key_usehealth, &key_weapon1, &key_weapon2, &key_weapon3, -- cgit v1.2.3 From 5a35c4381b1559e5d12709f9692de4984f9c64e6 Mon Sep 17 00:00:00 2001 From: svdijk Date: Mon, 23 Dec 2013 14:45:20 +0100 Subject: heretic, hexen: Fix mouse (and joystick) weapon cycling. Implement this the same way it is implemented for doom and strife. --- src/heretic/g_game.c | 52 ++++++++++++++++++++++++++++++++++++++---- src/hexen/g_game.c | 64 +++++++++++++++++++++++++++++++++++++++++++++------- 2 files changed, 103 insertions(+), 13 deletions(-) diff --git a/src/heretic/g_game.c b/src/heretic/g_game.c index e9302e83..20858cb7 100644 --- a/src/heretic/g_game.c +++ b/src/heretic/g_game.c @@ -185,7 +185,7 @@ int turnheld; // for accelerative turning int lookheld; -boolean mousearray[4]; +boolean mousearray[MAX_MOUSE_BUTTONS + 1]; boolean *mousebuttons = &mousearray[1]; // allow [-1] int mousex, mousey; // mouse values are used once @@ -681,7 +681,51 @@ static void SetJoyButtons(unsigned int buttons_mask) for (i=0; idata1 & 1; - mousebuttons[1] = ev->data1 & 2; - mousebuttons[2] = ev->data1 & 4; + SetMouseButtons(ev->data1); mousex = ev->data2 * (mouseSensitivity + 5) / 10; mousey = ev->data3 * (mouseSensitivity + 5) / 10; return (true); // eat events diff --git a/src/hexen/g_game.c b/src/hexen/g_game.c index a304d0f6..a448134b 100644 --- a/src/hexen/g_game.c +++ b/src/hexen/g_game.c @@ -152,7 +152,7 @@ int turnheld; // for accelerative turning int lookheld; -boolean mousearray[4]; +boolean mousearray[MAX_MOUSE_BUTTONS + 1]; boolean *mousebuttons = &mousearray[1]; // allow [-1] int mousex, mousey; // mouse values are used once @@ -671,6 +671,59 @@ void G_DoLoadLevel(void) } } +static void SetJoyButtons(unsigned int buttons_mask) +{ + int i; + + for (i=0; idata1 & 1; - mousebuttons[1] = ev->data1 & 2; - mousebuttons[2] = ev->data1 & 4; + SetMouseButtons(ev->data1); mousex = ev->data2 * (mouseSensitivity + 5) / 10; mousey = ev->data3 * (mouseSensitivity + 5) / 10; return (true); // eat events case ev_joystick: - joybuttons[0] = ev->data1 & 1; - joybuttons[1] = ev->data1 & 2; - joybuttons[2] = ev->data1 & 4; - joybuttons[3] = ev->data1 & 8; + SetJoyButtons(ev->data1); joyxmove = ev->data2; joyymove = ev->data3; return (true); // eat events -- cgit v1.2.3