mirror of
https://github.com/ZDoom/raze-gles.git
synced 2025-01-04 07:20:39 +00:00
- SW: Split getinput()
's input bits code into its own static function.
This commit is contained in:
parent
ce160f7ac1
commit
dd4251da09
1 changed files with 39 additions and 28 deletions
|
@ -68,6 +68,40 @@ void GameInterface::ResetFollowPos(bool)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
//---------------------------------------------------------------------------
|
||||||
|
//
|
||||||
|
// handles the input bits
|
||||||
|
//
|
||||||
|
//---------------------------------------------------------------------------
|
||||||
|
|
||||||
|
static void processInputBits(PLAYERp const pp, ControlInfo* const hidInput, bool* mouseaim)
|
||||||
|
{
|
||||||
|
ApplyGlobalInput(loc, hidInput);
|
||||||
|
*mouseaim = !(loc.actions & SB_AIMMODE);
|
||||||
|
|
||||||
|
if (!CommEnabled)
|
||||||
|
{
|
||||||
|
// Go back to the source to set this - the old code here was catastrophically bad.
|
||||||
|
// this needs to be fixed properly - as it is this can never be compatible with demo playback.
|
||||||
|
|
||||||
|
if (mouseaim)
|
||||||
|
SET(Player[myconnectindex].Flags, PF_MOUSE_AIMING_ON);
|
||||||
|
else
|
||||||
|
RESET(Player[myconnectindex].Flags, PF_MOUSE_AIMING_ON);
|
||||||
|
|
||||||
|
if (cl_autoaim)
|
||||||
|
SET(Player[myconnectindex].Flags, PF_AUTO_AIM);
|
||||||
|
else
|
||||||
|
RESET(Player[myconnectindex].Flags, PF_AUTO_AIM);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (buttonMap.ButtonDown(gamefunc_Toggle_Crouch))
|
||||||
|
{
|
||||||
|
// this shares a bit with another function so cannot be in the common code.
|
||||||
|
loc.actions |= SB_CROUCH_LOCK;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
//---------------------------------------------------------------------------
|
//---------------------------------------------------------------------------
|
||||||
//
|
//
|
||||||
// handles movement
|
// handles movement
|
||||||
|
@ -155,7 +189,7 @@ static void processWeapon(PLAYERp const pp)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
static void getinput(ControlInfo* const hidInput)
|
static void getinput(ControlInfo* const hidInput, bool const mouseaim)
|
||||||
{
|
{
|
||||||
PLAYERp pp = Player + myconnectindex;
|
PLAYERp pp = Player + myconnectindex;
|
||||||
PLAYERp newpp = Player + myconnectindex;
|
PLAYERp newpp = Player + myconnectindex;
|
||||||
|
@ -213,32 +247,6 @@ static void getinput(ControlInfo* const hidInput)
|
||||||
// for dividing controller input to match speed input speed of other games.
|
// for dividing controller input to match speed input speed of other games.
|
||||||
float const ticrateScale = 0.75f;
|
float const ticrateScale = 0.75f;
|
||||||
|
|
||||||
ApplyGlobalInput(loc, hidInput);
|
|
||||||
|
|
||||||
bool mouseaim = !(loc.actions & SB_AIMMODE);
|
|
||||||
|
|
||||||
if (!CommEnabled)
|
|
||||||
{
|
|
||||||
// Go back to the source to set this - the old code here was catastrophically bad.
|
|
||||||
// this needs to be fixed properly - as it is this can never be compatible with demo playback.
|
|
||||||
|
|
||||||
if (mouseaim)
|
|
||||||
SET(Player[myconnectindex].Flags, PF_MOUSE_AIMING_ON);
|
|
||||||
else
|
|
||||||
RESET(Player[myconnectindex].Flags, PF_MOUSE_AIMING_ON);
|
|
||||||
|
|
||||||
if (cl_autoaim)
|
|
||||||
SET(Player[myconnectindex].Flags, PF_AUTO_AIM);
|
|
||||||
else
|
|
||||||
RESET(Player[myconnectindex].Flags, PF_AUTO_AIM);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
if (buttonMap.ButtonDown(gamefunc_Toggle_Crouch)) // this shares a bit with another function so cannot be in the common code.
|
|
||||||
loc.actions |= SB_CROUCH_LOCK;
|
|
||||||
|
|
||||||
|
|
||||||
if (loc.actions & SB_RUN)
|
if (loc.actions & SB_RUN)
|
||||||
{
|
{
|
||||||
if (pp->sop_control)
|
if (pp->sop_control)
|
||||||
|
@ -369,8 +377,11 @@ static void getinput(ControlInfo* const hidInput)
|
||||||
void GameInterface::GetInput(InputPacket *packet, ControlInfo* const hidInput)
|
void GameInterface::GetInput(InputPacket *packet, ControlInfo* const hidInput)
|
||||||
{
|
{
|
||||||
PLAYERp pp = &Player[myconnectindex];
|
PLAYERp pp = &Player[myconnectindex];
|
||||||
|
bool mouseaim;
|
||||||
|
|
||||||
getinput(hidInput);
|
processInputBits(pp, hidInput, &mouseaim);
|
||||||
|
|
||||||
|
getinput(hidInput, &mouseaim);
|
||||||
|
|
||||||
processWeapon(pp);
|
processWeapon(pp);
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue