mirror of
https://github.com/ZDoom/qzdoom.git
synced 2024-11-10 23:02:08 +00:00
- Fixed SetActorPitch and ChangeActorPitch issue.
The code did not take into account the player's limited pitch.
This commit is contained in:
parent
0b3a22d6d2
commit
4546df7dc3
3 changed files with 19 additions and 19 deletions
|
@ -823,7 +823,7 @@ public:
|
||||||
}
|
}
|
||||||
|
|
||||||
// These also set CF_INTERPVIEW for players.
|
// These also set CF_INTERPVIEW for players.
|
||||||
void SetPitch(int p, bool interpolate);
|
void SetPitch(int p, bool interpolate, bool forceclamp = false);
|
||||||
void SetAngle(angle_t ang, bool interpolate);
|
void SetAngle(angle_t ang, bool interpolate);
|
||||||
void SetRoll(angle_t roll, bool interpolate);
|
void SetRoll(angle_t roll, bool interpolate);
|
||||||
|
|
||||||
|
|
|
@ -3115,8 +3115,24 @@ void AActor::SetShade (int r, int g, int b)
|
||||||
fillcolor = MAKEARGB(ColorMatcher.Pick (r, g, b), r, g, b);
|
fillcolor = MAKEARGB(ColorMatcher.Pick (r, g, b), r, g, b);
|
||||||
}
|
}
|
||||||
|
|
||||||
void AActor::SetPitch(int p, bool interpolate)
|
void AActor::SetPitch(int p, bool interpolate, bool forceclamp)
|
||||||
{
|
{
|
||||||
|
if (player != NULL || forceclamp)
|
||||||
|
{ // clamp the pitch we set
|
||||||
|
int min, max;
|
||||||
|
|
||||||
|
if (player != NULL)
|
||||||
|
{
|
||||||
|
min = player->MinPitch;
|
||||||
|
max = player->MaxPitch;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
min = -ANGLE_90 + (1 << ANGLETOFINESHIFT);
|
||||||
|
max = ANGLE_90 - (1 << ANGLETOFINESHIFT);
|
||||||
|
}
|
||||||
|
p = clamp<int>(p, min, max);
|
||||||
|
}
|
||||||
if (p != pitch)
|
if (p != pitch)
|
||||||
{
|
{
|
||||||
pitch = p;
|
pitch = p;
|
||||||
|
|
|
@ -3989,23 +3989,7 @@ DEFINE_ACTION_FUNCTION_PARAMS(AActor, A_SetPitch)
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (ref->player != NULL || (flags & SPF_FORCECLAMP))
|
ref->SetPitch(pitch, !!(flags & SPF_INTERPOLATE), !!(flags & SPF_FORCECLAMP));
|
||||||
{ // clamp the pitch we set
|
|
||||||
int min, max;
|
|
||||||
|
|
||||||
if (ref->player != NULL)
|
|
||||||
{
|
|
||||||
min = ref->player->MinPitch;
|
|
||||||
max = ref->player->MaxPitch;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
min = -ANGLE_90 + (1 << ANGLETOFINESHIFT);
|
|
||||||
max = ANGLE_90 - (1 << ANGLETOFINESHIFT);
|
|
||||||
}
|
|
||||||
pitch = clamp<int>(pitch, min, max);
|
|
||||||
}
|
|
||||||
ref->SetPitch(pitch, !!(flags & SPF_INTERPOLATE));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
//===========================================================================
|
//===========================================================================
|
||||||
|
|
Loading…
Reference in a new issue