mirror of
https://github.com/ZDoom/qzdoom-gpl.git
synced 2025-01-19 05:30:49 +00:00
671291227e
Patched up everything so that it compiles without errors again. This only addresses code related to some compile error. A large portion of the angle code still uses angle_t and converts back and forth.
150 lines
3.2 KiB
C++
150 lines
3.2 KiB
C++
/*
|
|
#include "actor.h"
|
|
#include "m_random.h"
|
|
#include "a_action.h"
|
|
#include "p_local.h"
|
|
#include "s_sound.h"
|
|
#include "m_random.h"
|
|
#include "a_strifeglobal.h"
|
|
#include "thingdef/thingdef.h"
|
|
*/
|
|
|
|
class ASpectralMonster : public AActor
|
|
{
|
|
DECLARE_CLASS (ASpectralMonster, AActor)
|
|
public:
|
|
void Touch (AActor *toucher);
|
|
};
|
|
|
|
IMPLEMENT_CLASS (ASpectralMonster)
|
|
|
|
void ASpectralMonster::Touch (AActor *toucher)
|
|
{
|
|
P_DamageMobj (toucher, this, this, 5, NAME_Melee);
|
|
}
|
|
|
|
|
|
DEFINE_ACTION_FUNCTION(AActor, A_SpectralLightningTail)
|
|
{
|
|
PARAM_ACTION_PROLOGUE;
|
|
|
|
AActor *foo = Spawn("SpectralLightningHTail", self->Vec3Offset(-self->vel.x, -self->vel.y, 0), ALLOW_REPLACE);
|
|
|
|
foo->Angles.Yaw = self->Angles.Yaw;
|
|
foo->FriendPlayer = self->FriendPlayer;
|
|
return 0;
|
|
}
|
|
|
|
DEFINE_ACTION_FUNCTION(AActor, A_SpectralBigBallLightning)
|
|
{
|
|
PARAM_ACTION_PROLOGUE;
|
|
|
|
PClassActor *cls = PClass::FindActor("SpectralLightningH3");
|
|
if (cls)
|
|
{
|
|
self->Angles.Yaw += 90.;
|
|
P_SpawnSubMissile (self, cls, self->target);
|
|
self->Angles.Yaw += 180.;
|
|
P_SpawnSubMissile (self, cls, self->target);
|
|
self->Angles.Yaw -= 270.;
|
|
P_SpawnSubMissile (self, cls, self->target);
|
|
}
|
|
return 0;
|
|
}
|
|
|
|
static FRandom pr_zap5 ("Zap5");
|
|
|
|
DEFINE_ACTION_FUNCTION(AActor, A_SpectralLightning)
|
|
{
|
|
PARAM_ACTION_PROLOGUE;
|
|
|
|
AActor *flash;
|
|
|
|
if (self->threshold != 0)
|
|
--self->threshold;
|
|
|
|
self->vel.x += pr_zap5.Random2(3) << FRACBITS;
|
|
self->vel.y += pr_zap5.Random2(3) << FRACBITS;
|
|
|
|
fixedvec2 pos = self->Vec2Offset(
|
|
pr_zap5.Random2(3) * FRACUNIT * 50,
|
|
pr_zap5.Random2(3) * FRACUNIT * 50);
|
|
|
|
flash = Spawn (self->threshold > 25 ? PClass::FindActor(NAME_SpectralLightningV2) :
|
|
PClass::FindActor(NAME_SpectralLightningV1), pos.x, pos.y, ONCEILINGZ, ALLOW_REPLACE);
|
|
|
|
flash->target = self->target;
|
|
flash->vel.z = -18*FRACUNIT;
|
|
flash->FriendPlayer = self->FriendPlayer;
|
|
|
|
flash = Spawn(NAME_SpectralLightningV2, self->X(), self->Y(), ONCEILINGZ, ALLOW_REPLACE);
|
|
|
|
flash->target = self->target;
|
|
flash->vel.z = -18*FRACUNIT;
|
|
flash->FriendPlayer = self->FriendPlayer;
|
|
return 0;
|
|
}
|
|
|
|
// In Strife, this number is stored in the data segment, but it doesn't seem to be
|
|
// altered anywhere.
|
|
#define TRACEANGLE (19.6875)
|
|
|
|
DEFINE_ACTION_FUNCTION(AActor, A_Tracer2)
|
|
{
|
|
PARAM_ACTION_PROLOGUE;
|
|
|
|
AActor *dest;
|
|
fixed_t dist;
|
|
fixed_t slope;
|
|
|
|
dest = self->tracer;
|
|
|
|
if (!dest || dest->health <= 0 || self->Speed == 0 || !self->CanSeek(dest))
|
|
return 0;
|
|
|
|
DAngle exact = self->_f_AngleTo(dest);
|
|
DAngle diff = deltaangle(self->Angles.Yaw, exact);
|
|
|
|
if (diff < 0)
|
|
{
|
|
self->Angles.Yaw -= TRACEANGLE;
|
|
if (deltaangle(self->Angles.Yaw, exact) > 0)
|
|
self->Angles.Yaw = exact;
|
|
}
|
|
else if (diff > 0)
|
|
{
|
|
self->Angles.Yaw += TRACEANGLE;
|
|
if (deltaangle(self->Angles.Yaw, exact) < 0.)
|
|
self->Angles.Yaw = exact;
|
|
}
|
|
|
|
self->VelFromAngle();
|
|
|
|
if (!(self->flags3 & (MF3_FLOORHUGGER|MF3_CEILINGHUGGER)))
|
|
{
|
|
// change slope
|
|
dist = self->AproxDistance (dest) / self->Speed;
|
|
|
|
if (dist < 1)
|
|
{
|
|
dist = 1;
|
|
}
|
|
if (dest->height >= 56*FRACUNIT)
|
|
{
|
|
slope = (dest->Z()+40*FRACUNIT - self->Z()) / dist;
|
|
}
|
|
else
|
|
{
|
|
slope = (dest->Z() + self->height*2/3 - self->Z()) / dist;
|
|
}
|
|
if (slope < self->vel.z)
|
|
{
|
|
self->vel.z -= FRACUNIT/8;
|
|
}
|
|
else
|
|
{
|
|
self->vel.z += FRACUNIT/8;
|
|
}
|
|
}
|
|
return 0;
|
|
}
|