2020-01-01 10:35:47 +00:00
|
|
|
/*
|
|
|
|
** Main input handler
|
|
|
|
**
|
|
|
|
**---------------------------------------------------------------------------
|
|
|
|
** Copyright 2019 Christoph Oelckers
|
|
|
|
** All rights reserved.
|
|
|
|
**
|
|
|
|
** Redistribution and use in source and binary forms, with or without
|
|
|
|
** modification, are permitted provided that the following conditions
|
|
|
|
** are met:
|
|
|
|
**
|
|
|
|
** 1. Redistributions of source code must retain the above copyright
|
|
|
|
** notice, this list of conditions and the following disclaimer.
|
|
|
|
** 2. Redistributions in binary form must reproduce the above copyright
|
|
|
|
** notice, this list of conditions and the following disclaimer in the
|
|
|
|
** documentation and/or other materials provided with the distribution.
|
|
|
|
** 3. The name of the author may not be used to endorse or promote products
|
|
|
|
** derived from this software without specific prior written permission.
|
|
|
|
**
|
|
|
|
** THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
|
|
|
|
** IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
|
|
|
|
** OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
|
|
|
|
** IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
|
|
|
|
** INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
|
|
|
|
** NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
|
|
|
** DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
|
|
|
|
** THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
|
|
|
** (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
|
|
|
|
** THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
|
|
**---------------------------------------------------------------------------
|
|
|
|
**
|
|
|
|
*/
|
|
|
|
|
2019-11-10 14:15:14 +00:00
|
|
|
#include "inputstate.h"
|
2020-04-23 19:18:40 +00:00
|
|
|
#include "i_system.h"
|
2019-11-10 14:15:14 +00:00
|
|
|
#include "v_draw.h"
|
|
|
|
#include "build.h"
|
|
|
|
#include "gamecvars.h"
|
2020-05-25 15:11:32 +00:00
|
|
|
#include "v_video.h"
|
2020-08-16 00:55:50 +00:00
|
|
|
#include "statusbar.h"
|
2020-08-26 22:25:59 +00:00
|
|
|
#include"packet.h"
|
|
|
|
#include "gamecontrol.h"
|
2020-08-28 07:06:49 +00:00
|
|
|
#include "gamestruct.h"
|
2020-11-29 11:23:31 +00:00
|
|
|
#include "d_net.h"
|
|
|
|
#include "gamestate.h"
|
2021-01-01 23:00:29 +00:00
|
|
|
#include "gameinput.h"
|
2019-11-10 14:15:14 +00:00
|
|
|
|
2020-08-26 22:53:35 +00:00
|
|
|
static int WeaponToSend = 0;
|
2020-08-27 19:25:09 +00:00
|
|
|
ESyncBits ActionsToSend = 0;
|
2020-08-27 20:19:24 +00:00
|
|
|
static int dpad_lock = 0;
|
2020-11-07 20:30:48 +00:00
|
|
|
bool crouch_toggle;
|
2020-09-04 07:53:36 +00:00
|
|
|
|
2022-06-11 07:24:14 +00:00
|
|
|
// Mouse speeds
|
|
|
|
CVAR(Float, m_pitch, 1.f, CVAR_GLOBALCONFIG | CVAR_ARCHIVE)
|
2020-09-28 20:36:43 +00:00
|
|
|
CVAR(Float, m_yaw, 1.f, CVAR_GLOBALCONFIG | CVAR_ARCHIVE)
|
|
|
|
CVAR(Float, m_forward, 1.f, CVAR_GLOBALCONFIG | CVAR_ARCHIVE)
|
|
|
|
CVAR(Float, m_side, 1.f, CVAR_GLOBALCONFIG | CVAR_ARCHIVE)
|
2022-06-11 07:24:14 +00:00
|
|
|
CVARD(Bool, invertmousex, false, CVAR_ARCHIVE | CVAR_GLOBALCONFIG, "invert horizontal mouse movement")
|
|
|
|
CVARD(Bool, invertmouse, false, CVAR_ARCHIVE | CVAR_GLOBALCONFIG, "invert vertical mouse movement")
|
2020-09-28 20:36:43 +00:00
|
|
|
|
2020-01-01 10:35:47 +00:00
|
|
|
//==========================================================================
|
|
|
|
//
|
|
|
|
//
|
|
|
|
//
|
|
|
|
//==========================================================================
|
|
|
|
|
2023-03-17 09:58:11 +00:00
|
|
|
void InputState::GetMouseDelta(HIDInput * hidInput)
|
2019-11-10 14:15:14 +00:00
|
|
|
{
|
2022-09-19 23:54:01 +00:00
|
|
|
g_mousePos *= backendinputscale();
|
|
|
|
|
|
|
|
hidInput->mouseturnx = g_mousePos.X * m_yaw;
|
|
|
|
hidInput->mouseturny = g_mousePos.Y * m_pitch;
|
2021-12-14 09:07:06 +00:00
|
|
|
hidInput->mousemovex = g_mousePos.X * m_side;
|
|
|
|
hidInput->mousemovey = g_mousePos.Y * m_forward;
|
2019-12-03 19:58:43 +00:00
|
|
|
|
2022-06-11 07:24:14 +00:00
|
|
|
if (invertmousex)
|
|
|
|
{
|
|
|
|
hidInput->mouseturnx = -hidInput->mouseturnx;
|
|
|
|
hidInput->mousemovex = -hidInput->mousemovex;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (invertmouse)
|
|
|
|
{
|
|
|
|
hidInput->mouseturny = -hidInput->mouseturny;
|
|
|
|
hidInput->mousemovey = -hidInput->mousemovey;
|
|
|
|
}
|
|
|
|
|
2022-09-19 23:54:01 +00:00
|
|
|
g_mousePos.Zero();
|
2019-11-10 14:15:14 +00:00
|
|
|
}
|
|
|
|
|
2020-01-01 10:35:47 +00:00
|
|
|
//==========================================================================
|
|
|
|
//
|
|
|
|
//
|
|
|
|
//
|
|
|
|
//==========================================================================
|
|
|
|
|
2021-11-18 21:11:32 +00:00
|
|
|
static int exclKeys[] = { KEY_VOLUMEDOWN, KEY_VOLUMEUP };
|
|
|
|
|
2019-11-10 14:15:14 +00:00
|
|
|
void InputState::AddEvent(const event_t *ev)
|
|
|
|
{
|
|
|
|
if (ev->type == EV_KeyDown || ev->type == EV_KeyUp)
|
|
|
|
{
|
2020-08-24 18:34:18 +00:00
|
|
|
int key = ev->data1;
|
|
|
|
bool state = ev->type == EV_KeyDown;
|
2021-11-18 21:11:32 +00:00
|
|
|
bool ignore = false;
|
2020-08-24 18:34:18 +00:00
|
|
|
KeyStatus[key] = (uint8_t)state;
|
2021-11-18 21:11:32 +00:00
|
|
|
|
|
|
|
// Check if key is to be excluded from setting AnyKeyStatus.
|
|
|
|
for (int i = 0; i < 2; i++)
|
|
|
|
{
|
|
|
|
if (exclKeys[i] == key)
|
|
|
|
{
|
|
|
|
ignore = true;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if (key > KEY_LASTJOYBUTTON && key < KEY_PAD_LTHUMB_RIGHT)
|
|
|
|
{
|
|
|
|
ignore = true;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (state && !ignore)
|
2020-08-24 18:34:18 +00:00
|
|
|
AnyKeyStatus = true;
|
2019-11-10 14:15:14 +00:00
|
|
|
}
|
|
|
|
}
|
2019-12-24 12:54:50 +00:00
|
|
|
|
2020-07-17 18:56:10 +00:00
|
|
|
//==========================================================================
|
|
|
|
//
|
|
|
|
//
|
|
|
|
//
|
|
|
|
//==========================================================================
|
|
|
|
|
|
|
|
void InputState::ClearAllInput()
|
|
|
|
{
|
|
|
|
memset(KeyStatus, 0, sizeof(KeyStatus));
|
2020-08-24 18:34:18 +00:00
|
|
|
AnyKeyStatus = false;
|
2023-03-28 22:41:56 +00:00
|
|
|
ActionsToSend = 0;
|
2020-08-27 20:19:24 +00:00
|
|
|
WeaponToSend = 0;
|
|
|
|
dpad_lock = 0;
|
2023-03-28 22:41:56 +00:00
|
|
|
crouch_toggle = false;
|
2020-07-17 18:56:10 +00:00
|
|
|
buttonMap.ResetButtonStates(); // this is important. If all input is cleared, the buttons must be cleared as well.
|
2023-03-28 22:41:56 +00:00
|
|
|
clearLocalInputBuffer(); // also clear game local input state.
|
2021-01-01 23:00:29 +00:00
|
|
|
resetTurnHeldAmt();
|
2020-07-17 18:56:10 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2020-01-01 10:35:47 +00:00
|
|
|
//==========================================================================
|
|
|
|
//
|
|
|
|
//
|
|
|
|
//
|
|
|
|
//==========================================================================
|
|
|
|
|
2019-12-24 12:54:50 +00:00
|
|
|
void I_StartTic();
|
2022-10-02 18:33:18 +00:00
|
|
|
extern bool ToggleFullscreen;
|
2019-12-24 12:54:50 +00:00
|
|
|
|
|
|
|
int32_t handleevents(void)
|
|
|
|
{
|
2020-01-08 00:00:57 +00:00
|
|
|
if (ToggleFullscreen)
|
|
|
|
{
|
|
|
|
vid_fullscreen = !vid_fullscreen;
|
|
|
|
ToggleFullscreen = false;
|
|
|
|
}
|
2020-01-01 08:49:06 +00:00
|
|
|
// fullscreen toggle has been requested
|
|
|
|
if (setmodeneeded)
|
|
|
|
{
|
|
|
|
setmodeneeded = false;
|
2020-01-01 11:36:48 +00:00
|
|
|
screen->ToggleFullscreen(vid_fullscreen);
|
2020-01-01 08:49:06 +00:00
|
|
|
V_OutputResized(screen->GetWidth(), screen->GetHeight());
|
|
|
|
}
|
|
|
|
|
|
|
|
// change the view size if needed
|
|
|
|
if (setsizeneeded)
|
|
|
|
{
|
2021-02-25 11:16:21 +00:00
|
|
|
setVideoMode();
|
2020-08-16 00:55:50 +00:00
|
|
|
setViewport(hud_size);
|
2020-01-01 08:49:06 +00:00
|
|
|
setsizeneeded = false;
|
|
|
|
}
|
|
|
|
|
2020-04-23 19:18:40 +00:00
|
|
|
I_StartFrame();
|
2019-12-24 12:54:50 +00:00
|
|
|
I_StartTic();
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
2020-08-26 22:25:59 +00:00
|
|
|
//---------------------------------------------------------------------------
|
|
|
|
//
|
|
|
|
//
|
|
|
|
//
|
|
|
|
//---------------------------------------------------------------------------
|
|
|
|
|
|
|
|
void SetupGameButtons()
|
|
|
|
{
|
|
|
|
static const char* actions[] = {
|
|
|
|
"Move_Forward",
|
|
|
|
"Move_Backward",
|
|
|
|
"Turn_Left",
|
|
|
|
"Turn_Right",
|
|
|
|
"Strafe",
|
|
|
|
"Fire",
|
|
|
|
"Open",
|
|
|
|
"Run",
|
|
|
|
"Alt_Fire",
|
|
|
|
"Jump",
|
|
|
|
"Crouch",
|
|
|
|
"Look_Up",
|
|
|
|
"Look_Down",
|
|
|
|
"Look_Left",
|
|
|
|
"Look_Right",
|
|
|
|
"Strafe_Left",
|
|
|
|
"Strafe_Right",
|
|
|
|
"Aim_Up",
|
|
|
|
"Aim_Down",
|
|
|
|
"Shrink_Screen",
|
|
|
|
"Enlarge_Screen",
|
|
|
|
"Mouse_Aiming",
|
|
|
|
"Dpad_Select",
|
|
|
|
"Dpad_Aiming",
|
|
|
|
"Toggle_Crouch",
|
|
|
|
"Quick_Kick",
|
2020-09-06 18:49:43 +00:00
|
|
|
"AM_PanLeft",
|
|
|
|
"AM_PanRight",
|
|
|
|
"AM_PanUp",
|
|
|
|
"AM_PanDown",
|
|
|
|
|
2020-08-26 22:25:59 +00:00
|
|
|
};
|
|
|
|
buttonMap.SetButtons(actions, NUM_ACTIONS);
|
|
|
|
}
|
|
|
|
|
2020-08-26 22:53:35 +00:00
|
|
|
//==========================================================================
|
|
|
|
//
|
|
|
|
//
|
|
|
|
//
|
|
|
|
//==========================================================================
|
|
|
|
|
|
|
|
CCMD(slot)
|
|
|
|
{
|
|
|
|
// The max differs between games so we have to handle this here.
|
2021-01-02 03:46:58 +00:00
|
|
|
int max = (g_gameType & GAMEFLAG_PSEXHUMED) || (g_gameType & (GAMEFLAG_DUKE | GAMEFLAG_SHAREWARE)) == (GAMEFLAG_DUKE | GAMEFLAG_SHAREWARE) ? 7 : isBlood() ? 12 : 10;
|
2020-08-26 22:53:35 +00:00
|
|
|
if (argv.argc() != 2)
|
|
|
|
{
|
|
|
|
Printf("slot <weaponslot>: select a weapon from the given slot (1-%d)", max);
|
2022-11-10 06:41:20 +00:00
|
|
|
return;
|
2020-08-26 22:53:35 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
auto slot = atoi(argv[1]);
|
|
|
|
if (slot >= 1 && slot <= max)
|
|
|
|
{
|
|
|
|
WeaponToSend = slot;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
CCMD(weapprev)
|
|
|
|
{
|
|
|
|
WeaponToSend = WeaponSel_Prev;
|
|
|
|
}
|
|
|
|
|
|
|
|
CCMD(weapnext)
|
|
|
|
{
|
|
|
|
WeaponToSend = WeaponSel_Next;
|
|
|
|
}
|
|
|
|
|
|
|
|
CCMD(weapalt)
|
|
|
|
{
|
|
|
|
WeaponToSend = WeaponSel_Alt; // Only used by SW - should also be made usable by Blood ans Duke which put multiple weapons in the same slot.
|
|
|
|
}
|
|
|
|
|
2020-08-27 19:25:09 +00:00
|
|
|
CCMD(useitem)
|
|
|
|
{
|
2021-07-11 02:39:54 +00:00
|
|
|
int max = (g_gameType & GAMEFLAG_PSEXHUMED)? 6 : isSWALL()? 7 : isBlood() ? 4 : 5;
|
2020-08-27 19:25:09 +00:00
|
|
|
if (argv.argc() != 2)
|
|
|
|
{
|
|
|
|
Printf("useitem <itemnum>: activates an inventory item (1-%d)", max);
|
2022-11-10 06:41:20 +00:00
|
|
|
return;
|
2020-08-27 19:25:09 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
auto slot = atoi(argv[1]);
|
|
|
|
if (slot >= 1 && slot <= max)
|
|
|
|
{
|
|
|
|
ActionsToSend |= ESyncBits::FromInt(SB_ITEM_BIT_1 << (slot - 1));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-08-27 20:19:24 +00:00
|
|
|
CCMD(invprev)
|
|
|
|
{
|
|
|
|
ActionsToSend |= SB_INVPREV;
|
|
|
|
}
|
|
|
|
|
|
|
|
CCMD(invnext)
|
|
|
|
{
|
|
|
|
ActionsToSend |= SB_INVNEXT;
|
|
|
|
}
|
|
|
|
|
|
|
|
CCMD(invuse)
|
|
|
|
{
|
|
|
|
ActionsToSend |= SB_INVUSE;
|
|
|
|
}
|
2020-08-27 19:25:09 +00:00
|
|
|
|
2020-08-27 22:03:35 +00:00
|
|
|
CCMD(centerview)
|
|
|
|
{
|
|
|
|
ActionsToSend |= SB_CENTERVIEW;
|
|
|
|
}
|
|
|
|
|
|
|
|
CCMD(turnaround)
|
|
|
|
{
|
|
|
|
ActionsToSend |= SB_TURNAROUND;
|
|
|
|
}
|
|
|
|
|
|
|
|
CCMD(holsterweapon)
|
|
|
|
{
|
|
|
|
ActionsToSend |= SB_HOLSTER;
|
|
|
|
}
|
|
|
|
|
2020-11-29 11:23:31 +00:00
|
|
|
CCMD(warptocoords)
|
|
|
|
{
|
|
|
|
if (netgame)
|
|
|
|
{
|
|
|
|
Printf("warptocoords cannot be used in multiplayer.\n");
|
|
|
|
return;
|
|
|
|
}
|
2020-11-29 15:06:15 +00:00
|
|
|
if (argv.argc() < 4)
|
2020-11-29 11:23:31 +00:00
|
|
|
{
|
2023-03-17 06:28:04 +00:00
|
|
|
Printf("warptocoords [x] [y] [z] [yaw] (optional) [pitch] (optional): warps the player to the specified coordinates\n");
|
2020-11-29 11:23:31 +00:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
if (gamestate != GS_LEVEL)
|
|
|
|
{
|
|
|
|
Printf("warptocoords: must be in a level\n");
|
|
|
|
return;
|
|
|
|
}
|
2023-03-17 06:28:04 +00:00
|
|
|
|
|
|
|
if (const auto pActor = gi->getConsoleActor())
|
2020-11-29 11:23:31 +00:00
|
|
|
{
|
2023-03-17 06:28:04 +00:00
|
|
|
pActor->spr.pos = DVector3(atof(argv[1]), atof(argv[2]), atof(argv[3]));
|
|
|
|
if (argv.argc() > 4) pActor->spr.Angles.Yaw = DAngle::fromDeg(atof(argv[4]));
|
|
|
|
if (argv.argc() > 5) pActor->spr.Angles.Pitch = DAngle::fromDeg(atof(argv[5]));
|
|
|
|
pActor->backuploc();
|
2020-11-29 11:23:31 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
CCMD(third_person_view)
|
|
|
|
{
|
|
|
|
gi->ToggleThirdPerson();
|
|
|
|
}
|
|
|
|
|
|
|
|
CCMD(coop_view)
|
|
|
|
{
|
|
|
|
gi->SwitchCoopView();
|
|
|
|
}
|
|
|
|
|
|
|
|
CCMD(show_weapon)
|
|
|
|
{
|
|
|
|
gi->ToggleShowWeapon();
|
|
|
|
}
|
2020-08-27 19:25:09 +00:00
|
|
|
|
2023-03-18 06:35:30 +00:00
|
|
|
void ApplyGlobalInput(HIDInput* const hidInput, InputPacket* const inputBuffer)
|
2020-08-26 22:53:35 +00:00
|
|
|
{
|
2023-03-29 11:28:44 +00:00
|
|
|
inputState.GetMouseDelta(hidInput);
|
|
|
|
if (use_joystick) I_GetAxes(hidInput->joyaxes);
|
|
|
|
|
2023-03-18 06:35:30 +00:00
|
|
|
if (WeaponToSend != 0) inputBuffer->setNewWeapon(WeaponToSend);
|
2020-08-26 22:53:35 +00:00
|
|
|
WeaponToSend = 0;
|
2020-09-06 10:17:54 +00:00
|
|
|
if (hidInput && buttonMap.ButtonDown(gamefunc_Dpad_Select))
|
2020-08-26 22:53:35 +00:00
|
|
|
{
|
2020-08-27 20:19:24 +00:00
|
|
|
// These buttons should not autorepeat. The game handlers are not really equipped for that.
|
2023-03-18 06:35:30 +00:00
|
|
|
if (hidInput->joyaxes[JOYAXIS_Forward] > 0 && !(dpad_lock & 1)) { dpad_lock |= 1; inputBuffer->setNewWeapon(WeaponSel_Prev); }
|
2020-08-27 20:19:24 +00:00
|
|
|
else dpad_lock &= ~1;
|
2023-03-18 06:35:30 +00:00
|
|
|
if (hidInput->joyaxes[JOYAXIS_Forward] < 0 && !(dpad_lock & 2)) { dpad_lock |= 2; inputBuffer->setNewWeapon(WeaponSel_Next); }
|
2020-08-27 20:19:24 +00:00
|
|
|
else dpad_lock &= ~2;
|
2023-03-18 06:35:30 +00:00
|
|
|
if ((hidInput->joyaxes[JOYAXIS_Side] < 0 || hidInput->joyaxes[JOYAXIS_Yaw] > 0) && !(dpad_lock & 4)) { dpad_lock |= 4; inputBuffer->actions |= SB_INVPREV; }
|
2020-08-27 20:19:24 +00:00
|
|
|
else dpad_lock &= ~4;
|
2023-03-18 06:35:30 +00:00
|
|
|
if ((hidInput->joyaxes[JOYAXIS_Side] > 0 || hidInput->joyaxes[JOYAXIS_Yaw] < 0) && !(dpad_lock & 8)) { dpad_lock |= 8; inputBuffer->actions |= SB_INVNEXT; }
|
2020-08-27 20:19:24 +00:00
|
|
|
else dpad_lock &= ~8;
|
|
|
|
|
2023-03-18 06:35:30 +00:00
|
|
|
// This eats the controller inputBuffer-> for regular use
|
2023-03-17 09:42:19 +00:00
|
|
|
hidInput->joyaxes[JOYAXIS_Side] = 0;
|
|
|
|
hidInput->joyaxes[JOYAXIS_Forward] = 0;
|
|
|
|
hidInput->joyaxes[JOYAXIS_Yaw] = 0;
|
2020-08-26 22:53:35 +00:00
|
|
|
}
|
2020-08-27 20:19:24 +00:00
|
|
|
else dpad_lock = 0;
|
|
|
|
|
2023-03-29 11:20:07 +00:00
|
|
|
gi->reapplyInputBits(inputBuffer);
|
|
|
|
|
2023-03-18 06:35:30 +00:00
|
|
|
inputBuffer->actions |= ActionsToSend;
|
2020-08-27 19:25:09 +00:00
|
|
|
ActionsToSend = 0;
|
2020-08-26 22:53:35 +00:00
|
|
|
|
2023-03-17 09:42:19 +00:00
|
|
|
if (buttonMap.ButtonDown(gamefunc_Aim_Up) || (buttonMap.ButtonDown(gamefunc_Dpad_Aiming) && hidInput->joyaxes[JOYAXIS_Forward] > 0))
|
2023-03-29 11:20:07 +00:00
|
|
|
{
|
2023-03-18 06:35:30 +00:00
|
|
|
inputBuffer->actions |= SB_AIM_UP;
|
2023-03-29 11:20:07 +00:00
|
|
|
inputBuffer->actions &= ~SB_CENTERVIEW;
|
|
|
|
}
|
2020-08-29 11:32:14 +00:00
|
|
|
|
2023-03-17 09:42:19 +00:00
|
|
|
if ((buttonMap.ButtonDown(gamefunc_Aim_Down) || (buttonMap.ButtonDown(gamefunc_Dpad_Aiming) && hidInput->joyaxes[JOYAXIS_Forward] < 0)))
|
2023-03-29 11:20:07 +00:00
|
|
|
{
|
2023-03-18 06:35:30 +00:00
|
|
|
inputBuffer->actions |= SB_AIM_DOWN;
|
2023-03-29 11:20:07 +00:00
|
|
|
inputBuffer->actions &= ~SB_CENTERVIEW;
|
|
|
|
}
|
2020-08-29 11:32:14 +00:00
|
|
|
|
|
|
|
if (buttonMap.ButtonDown(gamefunc_Dpad_Aiming))
|
2023-03-17 09:42:19 +00:00
|
|
|
hidInput->joyaxes[JOYAXIS_Forward] = 0;
|
2020-08-29 11:32:14 +00:00
|
|
|
|
2020-08-28 20:51:05 +00:00
|
|
|
if (buttonMap.ButtonDown(gamefunc_Jump))
|
2023-03-18 06:35:30 +00:00
|
|
|
inputBuffer->actions |= SB_JUMP;
|
2020-08-27 22:03:35 +00:00
|
|
|
|
2020-11-07 07:16:16 +00:00
|
|
|
if (buttonMap.ButtonDown(gamefunc_Crouch) || buttonMap.ButtonDown(gamefunc_Toggle_Crouch) || crouch_toggle)
|
2023-03-18 06:35:30 +00:00
|
|
|
inputBuffer->actions |= SB_CROUCH;
|
2020-08-27 22:03:35 +00:00
|
|
|
|
2020-11-07 07:16:16 +00:00
|
|
|
if (buttonMap.ButtonDown(gamefunc_Toggle_Crouch))
|
|
|
|
{
|
2023-03-17 22:15:15 +00:00
|
|
|
crouch_toggle = !crouch_toggle;
|
|
|
|
buttonMap.ClearButton(gamefunc_Toggle_Crouch);
|
2020-11-07 07:16:16 +00:00
|
|
|
}
|
|
|
|
|
2023-03-17 22:15:15 +00:00
|
|
|
if (buttonMap.ButtonDown(gamefunc_Crouch) || buttonMap.ButtonDown(gamefunc_Jump))
|
2020-11-07 07:16:16 +00:00
|
|
|
crouch_toggle = false;
|
|
|
|
|
2020-08-28 20:51:05 +00:00
|
|
|
if (buttonMap.ButtonDown(gamefunc_Fire))
|
2023-03-18 06:35:30 +00:00
|
|
|
inputBuffer->actions |= SB_FIRE;
|
2020-08-28 20:51:05 +00:00
|
|
|
|
|
|
|
if (buttonMap.ButtonDown(gamefunc_Alt_Fire))
|
2023-03-18 06:35:30 +00:00
|
|
|
inputBuffer->actions |= SB_ALTFIRE;
|
2020-08-28 20:51:05 +00:00
|
|
|
|
|
|
|
if (buttonMap.ButtonDown(gamefunc_Open))
|
|
|
|
{
|
2021-01-02 03:46:58 +00:00
|
|
|
if (isBlood()) buttonMap.ClearButton(gamefunc_Open);
|
2023-03-18 06:35:30 +00:00
|
|
|
inputBuffer->actions |= SB_OPEN;
|
2020-08-28 20:51:05 +00:00
|
|
|
}
|
2020-08-28 22:57:07 +00:00
|
|
|
if (G_CheckAutorun(buttonMap.ButtonDown(gamefunc_Run)))
|
2023-03-18 06:35:30 +00:00
|
|
|
inputBuffer->actions |= SB_RUN;
|
2020-08-27 22:03:35 +00:00
|
|
|
|
2020-08-31 18:51:22 +00:00
|
|
|
if (!in_mousemode && !buttonMap.ButtonDown(gamefunc_Mouse_Aiming))
|
2023-03-18 06:35:30 +00:00
|
|
|
inputBuffer->actions |= SB_AIMMODE;
|
2020-08-29 11:32:14 +00:00
|
|
|
|
|
|
|
if (buttonMap.ButtonDown(gamefunc_Look_Up))
|
2023-03-18 06:35:30 +00:00
|
|
|
inputBuffer->actions |= SB_LOOK_UP;
|
2020-08-27 22:03:35 +00:00
|
|
|
|
2020-08-29 11:32:14 +00:00
|
|
|
if (buttonMap.ButtonDown(gamefunc_Look_Down))
|
2023-03-18 06:35:30 +00:00
|
|
|
inputBuffer->actions |= SB_LOOK_DOWN;
|
2020-08-28 20:51:05 +00:00
|
|
|
|
2020-08-29 11:32:14 +00:00
|
|
|
if (buttonMap.ButtonDown(gamefunc_Look_Left))
|
2023-03-18 06:35:30 +00:00
|
|
|
inputBuffer->actions |= SB_LOOK_LEFT;
|
2020-08-29 11:32:14 +00:00
|
|
|
|
|
|
|
if (buttonMap.ButtonDown(gamefunc_Look_Right))
|
2023-03-18 06:35:30 +00:00
|
|
|
inputBuffer->actions |= SB_LOOK_RIGHT;
|
2022-11-19 17:26:17 +00:00
|
|
|
|
2023-03-18 02:26:15 +00:00
|
|
|
if (buttonMap.ButtonDown(gamefunc_Quick_Kick))
|
2023-03-18 06:35:30 +00:00
|
|
|
inputBuffer->actions |= SB_QUICK_KICK;
|
2023-03-18 02:26:15 +00:00
|
|
|
|
2020-09-04 07:53:36 +00:00
|
|
|
}
|
|
|
|
|