mirror of
https://github.com/ZDoom/qzdoom.git
synced 2024-11-28 06:53:58 +00:00
- Used new functionality to avoid moving the puff around in SpawnDeepSplash.
- Fixed: P_RailAttack used the shooting actor or a default puff for some splash related actions. It should use the puff type passed to it as a parameter instead. - Changed splash handling in P_LineAttack to use the actual hit position to spawn the splash and not the puff's spawn position which is offset a little. - made some precision related changes to P_HitWater. The precise hit coordinate can now be passed as parameters. SVN r1350 (trunk)
This commit is contained in:
parent
3fe5db901c
commit
f7148b6b40
4 changed files with 42 additions and 56 deletions
|
@ -1,3 +1,12 @@
|
||||||
|
January 4, 2009 (Changes by Graf Zahl)
|
||||||
|
- Used new functionality to avoid moving the puff around in SpawnDeepSplash.
|
||||||
|
- Fixed: P_RailAttack used the shooting actor or a default puff for some splash
|
||||||
|
related actions. It should use the puff type passed to it as a parameter instead.
|
||||||
|
- Changed splash handling in P_LineAttack to use the actual hit position to
|
||||||
|
spawn the splash and not the puff's spawn position which is offset a little.
|
||||||
|
- made some precision related changes to P_HitWater. The precise hit coordinate
|
||||||
|
can now be passed as parameters.
|
||||||
|
|
||||||
January 3, 2009 (Changes by Graf Zahl)
|
January 3, 2009 (Changes by Graf Zahl)
|
||||||
- Made spawning of floor- and ceiling huggers a little more intelligent.
|
- Made spawning of floor- and ceiling huggers a little more intelligent.
|
||||||
- Fixed: 'None' was no longer recognized as a NULL class name by the
|
- Fixed: 'None' was no longer recognized as a NULL class name by the
|
||||||
|
|
|
@ -389,7 +389,7 @@ void P_TraceBleed (int damage, AActor *target, AActor *missile); // missile ver
|
||||||
void P_TraceBleed (int damage, AActor *target); // random direction version
|
void P_TraceBleed (int damage, AActor *target); // random direction version
|
||||||
void P_RailAttack (AActor *source, int damage, int offset, int color1 = 0, int color2 = 0, float maxdiff = 0, bool silent = false, const PClass *puff = NULL); // [RH] Shoot a railgun
|
void P_RailAttack (AActor *source, int damage, int offset, int color1 = 0, int color2 = 0, float maxdiff = 0, bool silent = false, const PClass *puff = NULL); // [RH] Shoot a railgun
|
||||||
bool P_HitFloor (AActor *thing);
|
bool P_HitFloor (AActor *thing);
|
||||||
bool P_HitWater (AActor *thing, sector_t *sec, fixed_t splashz=FIXED_MIN);
|
bool P_HitWater (AActor *thing, sector_t *sec, fixed_t splashx = FIXED_MIN, fixed_t splashy = FIXED_MIN, fixed_t splashz=FIXED_MIN, bool checkabove = false);
|
||||||
bool P_CheckMissileSpawn (AActor *missile);
|
bool P_CheckMissileSpawn (AActor *missile);
|
||||||
void P_PlaySpawnSound(AActor *missile, AActor *spawner);
|
void P_PlaySpawnSound(AActor *missile, AActor *spawner);
|
||||||
|
|
||||||
|
|
|
@ -2724,7 +2724,12 @@ AActor *P_LineAttack (AActor *t1, angle_t angle, fixed_t distance,
|
||||||
trace.Sector->heightsec == NULL &&
|
trace.Sector->heightsec == NULL &&
|
||||||
trace.HitType == TRACE_HitFloor)
|
trace.HitType == TRACE_HitFloor)
|
||||||
{
|
{
|
||||||
P_HitWater (puff, trace.Sector);
|
// Using the puff's position is not accurate enough.
|
||||||
|
// Instead make it splash at the actual hit position
|
||||||
|
hitx = t1->x + FixedMul (vx, trace.Distance);
|
||||||
|
hity = t1->y + FixedMul (vy, trace.Distance);
|
||||||
|
hitz = shootz + FixedMul (vz, trace.Distance);
|
||||||
|
P_HitWater (puff, P_PointInSector(hitx, hity), hitx, hity, hitz);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
|
@ -2998,6 +3003,8 @@ void P_RailAttack (AActor *source, int damage, int offset, int color1, int color
|
||||||
FTraceResults trace;
|
FTraceResults trace;
|
||||||
fixed_t shootz;
|
fixed_t shootz;
|
||||||
|
|
||||||
|
if (puffclass == NULL) puffclass = PClass::FindClass(NAME_BulletPuff);
|
||||||
|
|
||||||
pitch = (angle_t)(-source->pitch) >> ANGLETOFINESHIFT;
|
pitch = (angle_t)(-source->pitch) >> ANGLETOFINESHIFT;
|
||||||
angle = source->angle >> ANGLETOFINESHIFT;
|
angle = source->angle >> ANGLETOFINESHIFT;
|
||||||
|
|
||||||
|
@ -3040,39 +3047,16 @@ void P_RailAttack (AActor *source, int damage, int offset, int color1, int color
|
||||||
trace.CrossedWater == NULL &&
|
trace.CrossedWater == NULL &&
|
||||||
trace.Sector->heightsec == NULL)
|
trace.Sector->heightsec == NULL)
|
||||||
{
|
{
|
||||||
fixed_t savex, savey, savez;
|
AActor *thepuff = Spawn (puffclass, trace.X, trace.Y, trace.Z, ALLOW_REPLACE);
|
||||||
fixed_t savefloor, saveceil, savedropoff;
|
if (thepuff != NULL)
|
||||||
FTextureID savefloorpic;
|
{
|
||||||
sector_t *savefloorsec;
|
P_HitWater (thepuff, trace.Sector);
|
||||||
FTextureID saveceilingpic;
|
thepuff->Destroy ();
|
||||||
sector_t *saveceilingsec;
|
}
|
||||||
|
|
||||||
savex = source->x;
|
|
||||||
savey = source->y;
|
|
||||||
savez = source->z;
|
|
||||||
savefloor = source->floorz;
|
|
||||||
saveceil = source->ceilingz;
|
|
||||||
savedropoff = source->dropoffz;
|
|
||||||
savefloorpic = source->floorpic;
|
|
||||||
savefloorsec = source->floorsector;
|
|
||||||
saveceilingpic = source->ceilingpic;
|
|
||||||
saveceilingsec = source->ceilingsector;
|
|
||||||
|
|
||||||
source->SetOrigin (trace.X, trace.Y, trace.Z);
|
|
||||||
P_HitWater (source, trace.Sector);
|
|
||||||
source->SetOrigin (savex, savey, savez);
|
|
||||||
|
|
||||||
source->floorz = savefloor;
|
|
||||||
source->ceilingz = saveceil;
|
|
||||||
source->dropoffz = savedropoff;
|
|
||||||
source->floorpic = savefloorpic;
|
|
||||||
source->floorsector = savefloorsec;
|
|
||||||
source->ceilingpic = saveceilingpic;
|
|
||||||
source->ceilingsector = saveceilingsec;
|
|
||||||
}
|
}
|
||||||
if (trace.CrossedWater)
|
if (trace.CrossedWater)
|
||||||
{
|
{
|
||||||
AActor *thepuff = Spawn ("BulletPuff", 0, 0, 0, ALLOW_REPLACE);
|
AActor *thepuff = Spawn (puffclass, 0, 0, 0, ALLOW_REPLACE);
|
||||||
if (thepuff != NULL)
|
if (thepuff != NULL)
|
||||||
{
|
{
|
||||||
SpawnDeepSplash (source, trace, thepuff, vx, vy, vz, shootz);
|
SpawnDeepSplash (source, trace, thepuff, vx, vy, vz, shootz);
|
||||||
|
@ -3082,7 +3066,6 @@ void P_RailAttack (AActor *source, int damage, int offset, int color1, int color
|
||||||
|
|
||||||
// Now hurt anything the trace hit
|
// Now hurt anything the trace hit
|
||||||
unsigned int i;
|
unsigned int i;
|
||||||
if (puffclass == NULL) puffclass = PClass::FindClass(NAME_BulletPuff);
|
|
||||||
AActor *puffDefaults = puffclass == NULL? NULL : GetDefaultByType (puffclass);
|
AActor *puffDefaults = puffclass == NULL? NULL : GetDefaultByType (puffclass);
|
||||||
FName damagetype = (puffDefaults == NULL || puffDefaults->DamageType == NAME_None) ? FName(NAME_Railgun) : puffDefaults->DamageType;
|
FName damagetype = (puffDefaults == NULL || puffDefaults->DamageType == NAME_None) ? FName(NAME_Railgun) : puffDefaults->DamageType;
|
||||||
|
|
||||||
|
@ -4532,22 +4515,11 @@ static void SpawnDeepSplash (AActor *t1, const FTraceResults &trace, AActor *puf
|
||||||
|
|
||||||
if (hitdist >= 0 && hitdist <= trace.Distance)
|
if (hitdist >= 0 && hitdist <= trace.Distance)
|
||||||
{
|
{
|
||||||
fixed_t savex, savey, savez;
|
fixed_t hitx = t1->x+FixedMul (vx, hitdist);
|
||||||
|
fixed_t hity = t1->y+FixedMul (vy, hitdist);
|
||||||
|
fixed_t hitz = shootz+FixedMul (vz, hitdist);
|
||||||
|
|
||||||
// Move the puff onto the water surface, splash, then move it back.
|
P_HitWater (puff != NULL? puff:t1, P_PointInSector(hitx, hity), hitx, hity, hitz);
|
||||||
if (puff == NULL)
|
|
||||||
{
|
|
||||||
puff = t1;
|
|
||||||
}
|
|
||||||
|
|
||||||
savex = puff->x;
|
|
||||||
savey = puff->y;
|
|
||||||
savez = puff->z;
|
|
||||||
puff->SetOrigin (t1->x+FixedMul (vx, hitdist),
|
|
||||||
t1->y+FixedMul (vy, hitdist),
|
|
||||||
shootz+FixedMul (vz, hitdist));
|
|
||||||
P_HitWater (puff, puff->Sector);
|
|
||||||
puff->SetOrigin (savex, savey, savez);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -3058,7 +3058,10 @@ bool AActor::UpdateWaterLevel (fixed_t oldz, bool dosplash)
|
||||||
|
|
||||||
// some additional checks to make deep sectors like Boom's splash without setting
|
// some additional checks to make deep sectors like Boom's splash without setting
|
||||||
// the water flags.
|
// the water flags.
|
||||||
if (boomwaterlevel == 0 && waterlevel != 0 && dosplash) P_HitWater(this, Sector, fh);
|
if (boomwaterlevel == 0 && waterlevel != 0 && dosplash)
|
||||||
|
{
|
||||||
|
P_HitWater(this, Sector, FIXED_MIN, FIXED_MIN, fh, true);
|
||||||
|
}
|
||||||
boomwaterlevel=waterlevel;
|
boomwaterlevel=waterlevel;
|
||||||
if (reset) waterlevel=lastwaterlevel;
|
if (reset) waterlevel=lastwaterlevel;
|
||||||
return false; // we did the splash ourselves! ;)
|
return false; // we did the splash ourselves! ;)
|
||||||
|
@ -4214,7 +4217,7 @@ int P_GetThingFloorType (AActor *thing)
|
||||||
// Returns true if hit liquid and splashed, false if not.
|
// Returns true if hit liquid and splashed, false if not.
|
||||||
//---------------------------------------------------------------------------
|
//---------------------------------------------------------------------------
|
||||||
|
|
||||||
bool P_HitWater (AActor * thing, sector_t * sec, fixed_t z)
|
bool P_HitWater (AActor * thing, sector_t * sec, fixed_t x, fixed_t y, fixed_t z, bool checkabove)
|
||||||
{
|
{
|
||||||
if (thing->flags2 & MF2_FLOATBOB || thing->flags3 & MF3_DONTSPLASH)
|
if (thing->flags2 & MF2_FLOATBOB || thing->flags3 & MF3_DONTSPLASH)
|
||||||
return false;
|
return false;
|
||||||
|
@ -4226,9 +4229,11 @@ bool P_HitWater (AActor * thing, sector_t * sec, fixed_t z)
|
||||||
FSplashDef *splash;
|
FSplashDef *splash;
|
||||||
int terrainnum;
|
int terrainnum;
|
||||||
|
|
||||||
if (z==FIXED_MIN) z=thing->z;
|
if (x == FIXED_MIN) x = thing->x;
|
||||||
|
if (y == FIXED_MIN) y = thing->y;
|
||||||
|
if (z == FIXED_MIN) z = thing->z;
|
||||||
// don't splash above the object
|
// don't splash above the object
|
||||||
else if (z>thing->z+(thing->height>>1)) return false;
|
if (checkabove && z > thing->z + (thing->height >> 1)) return false;
|
||||||
if (sec->heightsec == NULL ||
|
if (sec->heightsec == NULL ||
|
||||||
//!sec->heightsec->waterzone ||
|
//!sec->heightsec->waterzone ||
|
||||||
(sec->heightsec->MoreFlags & SECF_IGNOREHEIGHTSEC) ||
|
(sec->heightsec->MoreFlags & SECF_IGNOREHEIGHTSEC) ||
|
||||||
|
@ -4268,14 +4273,14 @@ bool P_HitWater (AActor * thing, sector_t * sec, fixed_t z)
|
||||||
|
|
||||||
if (smallsplash && splash->SmallSplash)
|
if (smallsplash && splash->SmallSplash)
|
||||||
{
|
{
|
||||||
mo = Spawn (splash->SmallSplash, thing->x, thing->y, z, ALLOW_REPLACE);
|
mo = Spawn (splash->SmallSplash, x, y, z, ALLOW_REPLACE);
|
||||||
if (mo) mo->floorclip += splash->SmallSplashClip;
|
if (mo) mo->floorclip += splash->SmallSplashClip;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
if (splash->SplashChunk)
|
if (splash->SplashChunk)
|
||||||
{
|
{
|
||||||
mo = Spawn (splash->SplashChunk, thing->x, thing->y, z, ALLOW_REPLACE);
|
mo = Spawn (splash->SplashChunk, x, y, z, ALLOW_REPLACE);
|
||||||
mo->target = thing;
|
mo->target = thing;
|
||||||
if (splash->ChunkXVelShift != 255)
|
if (splash->ChunkXVelShift != 255)
|
||||||
{
|
{
|
||||||
|
@ -4289,7 +4294,7 @@ bool P_HitWater (AActor * thing, sector_t * sec, fixed_t z)
|
||||||
}
|
}
|
||||||
if (splash->SplashBase)
|
if (splash->SplashBase)
|
||||||
{
|
{
|
||||||
mo = Spawn (splash->SplashBase, thing->x, thing->y, z, ALLOW_REPLACE);
|
mo = Spawn (splash->SplashBase, x, y, z, ALLOW_REPLACE);
|
||||||
}
|
}
|
||||||
if (thing->player && !splash->NoAlert)
|
if (thing->player && !splash->NoAlert)
|
||||||
{
|
{
|
||||||
|
@ -4304,7 +4309,7 @@ bool P_HitWater (AActor * thing, sector_t * sec, fixed_t z)
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
S_Sound (thing->x, thing->y, z, CHAN_ITEM, smallsplash ?
|
S_Sound (x, y, z, CHAN_ITEM, smallsplash ?
|
||||||
splash->SmallSplashSound : splash->NormalSplashSound,
|
splash->SmallSplashSound : splash->NormalSplashSound,
|
||||||
1, ATTN_IDLE);
|
1, ATTN_IDLE);
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue