mirror of
https://github.com/ZDoom/raze-gles.git
synced 2025-01-16 04:30:38 +00:00
- gamecontrol: Remove old horizon code left behind while cutting over each game.
This commit is contained in:
parent
6476430be6
commit
d16b4651bb
6 changed files with 6 additions and 135 deletions
|
@ -59,11 +59,7 @@ void GameInterface::GetInput(InputPacket* packet, ControlInfo* const hidInput)
|
||||||
sethorizon(&pPlayer->horizon.horiz, input.q16horz, &pPlayer->input.actions, scaleAdjust);
|
sethorizon(&pPlayer->horizon.horiz, input.q16horz, &pPlayer->input.actions, scaleAdjust);
|
||||||
}
|
}
|
||||||
|
|
||||||
// temporary vals to pass through to playerProcessHelpers().
|
playerProcessHelpers(&pPlayer->q16ang, &pPlayer->angAdjust, &pPlayer->angTarget, scaleAdjust);
|
||||||
fixed_t horiz = 0;
|
|
||||||
fixed_t target = 0;
|
|
||||||
double adjust = 0;
|
|
||||||
playerProcessHelpers(&pPlayer->q16ang, &pPlayer->angAdjust, &pPlayer->angTarget, &horiz, &adjust, &target, scaleAdjust);
|
|
||||||
pPlayer->horizon.processhelpers(scaleAdjust);
|
pPlayer->horizon.processhelpers(scaleAdjust);
|
||||||
UpdatePlayerSpriteAngle(pPlayer);
|
UpdatePlayerSpriteAngle(pPlayer);
|
||||||
}
|
}
|
||||||
|
|
|
@ -1568,72 +1568,6 @@ void processMovement(InputPacket* currInput, InputPacket* inputBuffer, ControlIn
|
||||||
//
|
//
|
||||||
//---------------------------------------------------------------------------
|
//---------------------------------------------------------------------------
|
||||||
|
|
||||||
void sethorizon2(fixed_t* q16horiz, fixed_t const q16horz, ESyncBits* actions, double const scaleAdjust)
|
|
||||||
{
|
|
||||||
// Calculate adjustment as true pitch (Fixed point math really sucks...)
|
|
||||||
double horizAngle = HorizToPitch(*q16horiz);
|
|
||||||
|
|
||||||
if (q16horz)
|
|
||||||
{
|
|
||||||
*actions &= ~SB_CENTERVIEW;
|
|
||||||
horizAngle += FixedToFloat(q16horz);
|
|
||||||
}
|
|
||||||
|
|
||||||
// this is the locked type
|
|
||||||
if (*actions & (SB_AIM_UP|SB_AIM_DOWN))
|
|
||||||
{
|
|
||||||
*actions &= ~SB_CENTERVIEW;
|
|
||||||
double const amount = HorizToPitch(250. / GameTicRate);
|
|
||||||
|
|
||||||
if (*actions & SB_AIM_DOWN)
|
|
||||||
horizAngle -= scaleAdjust * amount;
|
|
||||||
|
|
||||||
if (*actions & SB_AIM_UP)
|
|
||||||
horizAngle += scaleAdjust * amount;
|
|
||||||
}
|
|
||||||
|
|
||||||
// this is the unlocked type
|
|
||||||
if (*actions & (SB_LOOK_UP|SB_LOOK_DOWN))
|
|
||||||
{
|
|
||||||
*actions |= SB_CENTERVIEW;
|
|
||||||
double const amount = HorizToPitch(500. / GameTicRate);
|
|
||||||
|
|
||||||
if (*actions & SB_LOOK_DOWN)
|
|
||||||
horizAngle -= scaleAdjust * amount;
|
|
||||||
|
|
||||||
if (*actions & SB_LOOK_UP)
|
|
||||||
horizAngle += scaleAdjust * amount;
|
|
||||||
}
|
|
||||||
|
|
||||||
// clamp horizAngle after processing
|
|
||||||
horizAngle = clamp(horizAngle, -90, 90);
|
|
||||||
|
|
||||||
// return to center if conditions met.
|
|
||||||
if ((*actions & SB_CENTERVIEW) && !(*actions & (SB_LOOK_UP|SB_LOOK_DOWN)))
|
|
||||||
{
|
|
||||||
if (abs(horizAngle) > 0.1375)
|
|
||||||
{
|
|
||||||
// move horizAngle back to 0
|
|
||||||
horizAngle += -scaleAdjust * horizAngle * (9. / GameTicRate);
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
// not looking anymore because horizAngle is back at 0
|
|
||||||
horizAngle = 0;
|
|
||||||
*actions &= ~SB_CENTERVIEW;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// clamp before returning
|
|
||||||
*q16horiz = clamp(PitchToHoriz(horizAngle), gi->playerHorizMin(), gi->playerHorizMax());
|
|
||||||
}
|
|
||||||
|
|
||||||
//---------------------------------------------------------------------------
|
|
||||||
//
|
|
||||||
// Player's horizon function, called from game's ticker or from gi->GetInput() as required.
|
|
||||||
//
|
|
||||||
//---------------------------------------------------------------------------
|
|
||||||
|
|
||||||
static double const aimamount = HorizToPitch(250. / GameTicRate);
|
static double const aimamount = HorizToPitch(250. / GameTicRate);
|
||||||
static double const lookamount = HorizToPitch(500. / GameTicRate);
|
static double const lookamount = HorizToPitch(500. / GameTicRate);
|
||||||
|
|
||||||
|
@ -1789,40 +1723,13 @@ void playerSetAngle(fixed_t* q16ang, fixed_t* helper, double adjustment)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void playerAddHoriz2(fixed_t* q16horiz, double* helper, double adjustment)
|
|
||||||
{
|
|
||||||
if (!cl_syncinput)
|
|
||||||
{
|
|
||||||
*helper += adjustment;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
*q16horiz += FloatToFixed(adjustment);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void playerSetHoriz2(fixed_t* q16horiz, fixed_t* helper, double adjustment)
|
|
||||||
{
|
|
||||||
if (!cl_syncinput)
|
|
||||||
{
|
|
||||||
// Add slight offset if adjustment is coming in as absolute 0.
|
|
||||||
if (adjustment == 0) adjustment += (1. / (FRACUNIT >> 1));
|
|
||||||
|
|
||||||
*helper = FloatToFixed(adjustment);
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
*q16horiz = FloatToFixed(adjustment);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
//---------------------------------------------------------------------------
|
//---------------------------------------------------------------------------
|
||||||
//
|
//
|
||||||
// Player's ticrate helper processor.
|
// Player's ticrate helper processor.
|
||||||
//
|
//
|
||||||
//---------------------------------------------------------------------------
|
//---------------------------------------------------------------------------
|
||||||
|
|
||||||
void playerProcessHelpers(fixed_t* q16ang, double* angAdjust, fixed_t* angTarget, fixed_t* q16horiz, double* horizAdjust, fixed_t* horizTarget, double const scaleAdjust)
|
void playerProcessHelpers(fixed_t* q16ang, double* angAdjust, fixed_t* angTarget, double const scaleAdjust)
|
||||||
{
|
{
|
||||||
// Process angle amendments from the game's ticker.
|
// Process angle amendments from the game's ticker.
|
||||||
if (*angTarget)
|
if (*angTarget)
|
||||||
|
@ -1840,21 +1747,4 @@ void playerProcessHelpers(fixed_t* q16ang, double* angAdjust, fixed_t* angTarget
|
||||||
{
|
{
|
||||||
*q16ang = (*q16ang + FloatToFixed(scaleAdjust * *angAdjust)) & 0x7FFFFFF;
|
*q16ang = (*q16ang + FloatToFixed(scaleAdjust * *angAdjust)) & 0x7FFFFFF;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Process horizon amendments from the game's ticker.
|
|
||||||
if (*horizTarget)
|
|
||||||
{
|
|
||||||
fixed_t horizDelta = *horizTarget - *q16horiz;
|
|
||||||
*q16horiz += xs_CRoundToInt(scaleAdjust * horizDelta);
|
|
||||||
|
|
||||||
if (abs(*q16horiz - *horizTarget) < FRACUNIT)
|
|
||||||
{
|
|
||||||
*q16horiz = *horizTarget;
|
|
||||||
*horizTarget = 0;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else if (*horizAdjust)
|
|
||||||
{
|
|
||||||
*q16horiz += FloatToFixed(scaleAdjust * *horizAdjust);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -144,13 +144,10 @@ struct PlayerHorizon
|
||||||
|
|
||||||
void processMovement(InputPacket* currInput, InputPacket* inputBuffer, ControlInfo* const hidInput, double const scaleAdjust, int const drink_amt = 0, bool const allowstrafe = true, double const turnscale = 1);
|
void processMovement(InputPacket* currInput, InputPacket* inputBuffer, ControlInfo* const hidInput, double const scaleAdjust, int const drink_amt = 0, bool const allowstrafe = true, double const turnscale = 1);
|
||||||
void sethorizon(fixedhoriz* horiz, fixed_t const q16horz, ESyncBits* actions, double const scaleAdjust);
|
void sethorizon(fixedhoriz* horiz, fixed_t const q16horz, ESyncBits* actions, double const scaleAdjust);
|
||||||
void sethorizon2(fixed_t* q16horiz, fixed_t const q16horz, ESyncBits* actions, double const scaleAdjust);
|
|
||||||
void applylook(fixed_t* q16ang, fixed_t* q16look_ang, fixed_t* q16rotscrnang, fixed_t* spin, fixed_t const q16avel, ESyncBits* actions, double const scaleAdjust, bool const crouching);
|
void applylook(fixed_t* q16ang, fixed_t* q16look_ang, fixed_t* q16rotscrnang, fixed_t* spin, fixed_t const q16avel, ESyncBits* actions, double const scaleAdjust, bool const crouching);
|
||||||
void playerAddAngle(fixed_t* q16ang, double* helper, double adjustment);
|
void playerAddAngle(fixed_t* q16ang, double* helper, double adjustment);
|
||||||
void playerSetAngle(fixed_t* q16ang, fixed_t* helper, double adjustment);
|
void playerSetAngle(fixed_t* q16ang, fixed_t* helper, double adjustment);
|
||||||
void playerAddHoriz2(fixed_t* q16horiz, double* helper, double adjustment);
|
void playerProcessHelpers(fixed_t* q16ang, double* angAdjust, fixed_t* angTarget, double const scaleAdjust);
|
||||||
void playerSetHoriz2(fixed_t* q16horiz, fixed_t* helper, double adjustment);
|
|
||||||
void playerProcessHelpers(fixed_t* q16ang, double* angAdjust, fixed_t* angTarget, fixed_t* q16horiz, double* horizAdjust, fixed_t* horizTarget, double const scaleAdjust);
|
|
||||||
|
|
||||||
struct UserConfig
|
struct UserConfig
|
||||||
{
|
{
|
||||||
|
|
|
@ -132,11 +132,7 @@ void GameInterface::GetInput(InputPacket* packet, ControlInfo* const hidInput)
|
||||||
sethorizon(&pPlayer->horizon.horiz, input.q16horz, &sPlayerInput[nLocalPlayer].actions, scaleAdjust);
|
sethorizon(&pPlayer->horizon.horiz, input.q16horz, &sPlayerInput[nLocalPlayer].actions, scaleAdjust);
|
||||||
}
|
}
|
||||||
|
|
||||||
// temporary vals to pass through to playerProcessHelpers().
|
playerProcessHelpers(&pPlayer->q16angle, &pPlayer->angAdjust, &pPlayer->angTarget, scaleAdjust);
|
||||||
fixed_t horiz = 0;
|
|
||||||
fixed_t target = 0;
|
|
||||||
double adjust = 0;
|
|
||||||
playerProcessHelpers(&pPlayer->q16angle, &pPlayer->angAdjust, &pPlayer->angTarget, &horiz, &adjust, &target, scaleAdjust);
|
|
||||||
pPlayer->horizon.processhelpers(scaleAdjust);
|
pPlayer->horizon.processhelpers(scaleAdjust);
|
||||||
UpdatePlayerSpriteAngle(pPlayer);
|
UpdatePlayerSpriteAngle(pPlayer);
|
||||||
}
|
}
|
||||||
|
|
|
@ -926,11 +926,7 @@ void GameInterface::GetInput(InputPacket* packet, ControlInfo* const hidInput)
|
||||||
sethorizon(&p->horizon.horiz, input.q16horz, &p->sync.actions, scaleAdjust);
|
sethorizon(&p->horizon.horiz, input.q16horz, &p->sync.actions, scaleAdjust);
|
||||||
}
|
}
|
||||||
|
|
||||||
// temporary vals to pass through to playerProcessHelpers().
|
playerProcessHelpers(&p->q16ang, &p->angAdjust, &p->angTarget, scaleAdjust);
|
||||||
fixed_t horiz = 0;
|
|
||||||
fixed_t target = 0;
|
|
||||||
double adjust = 0;
|
|
||||||
playerProcessHelpers(&p->q16ang, &p->angAdjust, &p->angTarget, &horiz, &adjust, &target, scaleAdjust);
|
|
||||||
p->horizon.processhelpers(scaleAdjust);
|
p->horizon.processhelpers(scaleAdjust);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -230,11 +230,7 @@ void GameInterface::GetInput(InputPacket *packet, ControlInfo* const hidInput)
|
||||||
DoPlayerTurnTurret(pp, input.q16avel);
|
DoPlayerTurnTurret(pp, input.q16avel);
|
||||||
}
|
}
|
||||||
|
|
||||||
// temporary vals to pass through to playerProcessHelpers().
|
playerProcessHelpers(&pp->q16ang, &pp->angAdjust, &pp->angTarget, scaleAdjust);
|
||||||
fixed_t horiz = 0;
|
|
||||||
fixed_t target = 0;
|
|
||||||
double adjust = 0;
|
|
||||||
playerProcessHelpers(&pp->q16ang, &pp->angAdjust, &pp->angTarget, &horiz, &adjust, &target, scaleAdjust);
|
|
||||||
pp->horizon.processhelpers(scaleAdjust);
|
pp->horizon.processhelpers(scaleAdjust);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue