mirror of
https://github.com/ZDoom/gzdoom.git
synced 2025-01-19 08:01:50 +00:00
Added texture detection for walls and 3D floors; renamed some fields to more intuitive names
This commit is contained in:
parent
a7ff62316d
commit
74b937620e
2 changed files with 30 additions and 6 deletions
|
@ -959,7 +959,7 @@ IMPLEMENT_CLASS(DTracer, false, false)
|
||||||
DEFINE_FIELD_X(Tracer, DTracer, Results)
|
DEFINE_FIELD_X(Tracer, DTracer, Results)
|
||||||
|
|
||||||
// define TraceResults fields
|
// define TraceResults fields
|
||||||
DEFINE_FIELD_NAMED_X(TraceResults, FTraceResults, Sector, Sec)
|
DEFINE_FIELD_NAMED_X(TraceResults, FTraceResults, Sector, HitSector)
|
||||||
DEFINE_FIELD_X(TraceResults, FTraceResults, HitTexture)
|
DEFINE_FIELD_X(TraceResults, FTraceResults, HitTexture)
|
||||||
DEFINE_FIELD_X(TraceResults, FTraceResults, HitPos)
|
DEFINE_FIELD_X(TraceResults, FTraceResults, HitPos)
|
||||||
DEFINE_FIELD_X(TraceResults, FTraceResults, HitVector)
|
DEFINE_FIELD_X(TraceResults, FTraceResults, HitVector)
|
||||||
|
@ -967,8 +967,8 @@ DEFINE_FIELD_X(TraceResults, FTraceResults, SrcFromTarget)
|
||||||
DEFINE_FIELD_X(TraceResults, FTraceResults, SrcAngleFromTarget)
|
DEFINE_FIELD_X(TraceResults, FTraceResults, SrcAngleFromTarget)
|
||||||
DEFINE_FIELD_X(TraceResults, FTraceResults, Distance)
|
DEFINE_FIELD_X(TraceResults, FTraceResults, Distance)
|
||||||
DEFINE_FIELD_X(TraceResults, FTraceResults, Fraction)
|
DEFINE_FIELD_X(TraceResults, FTraceResults, Fraction)
|
||||||
DEFINE_FIELD_NAMED_X(TraceResults, FTraceResults, Actor, Thing)
|
DEFINE_FIELD_NAMED_X(TraceResults, FTraceResults, Actor, HitActor)
|
||||||
DEFINE_FIELD_NAMED_X(TraceResults, FTraceResults, Line, Linedef)
|
DEFINE_FIELD_NAMED_X(TraceResults, FTraceResults, Line, HitLine)
|
||||||
DEFINE_FIELD_X(TraceResults, FTraceResults, Side)
|
DEFINE_FIELD_X(TraceResults, FTraceResults, Side)
|
||||||
DEFINE_FIELD_X(TraceResults, FTraceResults, Tier)
|
DEFINE_FIELD_X(TraceResults, FTraceResults, Tier)
|
||||||
DEFINE_FIELD_X(TraceResults, FTraceResults, unlinked)
|
DEFINE_FIELD_X(TraceResults, FTraceResults, unlinked)
|
||||||
|
@ -1006,6 +1006,30 @@ ETraceStatus DTracer::TraceCallback(FTraceResults& res, void* pthis)
|
||||||
{
|
{
|
||||||
DTracer* self = (DTracer*)pthis;
|
DTracer* self = (DTracer*)pthis;
|
||||||
// "res" here should refer to self->Results anyway.
|
// "res" here should refer to self->Results anyway.
|
||||||
|
|
||||||
|
// patch results a bit. modders don't expect it to work like this most likely.
|
||||||
|
// code by MarisaKirisame
|
||||||
|
if (res.HitType == TRACE_HitWall)
|
||||||
|
{
|
||||||
|
int txpart;
|
||||||
|
switch (res.Tier)
|
||||||
|
{
|
||||||
|
case TIER_Middle:
|
||||||
|
res.HitTexture = res.Line->sidedef[res.Side]->textures[1].texture;
|
||||||
|
break;
|
||||||
|
case TIER_Upper:
|
||||||
|
res.HitTexture = res.Line->sidedef[res.Side]->textures[0].texture;
|
||||||
|
break;
|
||||||
|
case TIER_Lower:
|
||||||
|
res.HitTexture = res.Line->sidedef[res.Side]->textures[2].texture;
|
||||||
|
break;
|
||||||
|
case TIER_FFloor:
|
||||||
|
txpart = (res.ffloor->flags & FF_UPPERTEXTURE) ? 0 : (res.ffloor->flags & FF_LOWERTEXTURE) ? 2 : 1;
|
||||||
|
res.HitTexture = res.ffloor->master->sidedef[0]->textures[txpart].texture;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
return self->CallZScriptCallback();
|
return self->CallZScriptCallback();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -498,7 +498,7 @@ enum ELineTier
|
||||||
|
|
||||||
struct TraceResults native
|
struct TraceResults native
|
||||||
{
|
{
|
||||||
native Sector Sec; // originally called "Sector". cannot be named like this in ZScript.
|
native Sector HitSector; // originally called "Sector". cannot be named like this in ZScript.
|
||||||
native TextureID HitTexture;
|
native TextureID HitTexture;
|
||||||
native vector3 HitPos;
|
native vector3 HitPos;
|
||||||
native vector3 HitVector;
|
native vector3 HitVector;
|
||||||
|
@ -508,9 +508,9 @@ struct TraceResults native
|
||||||
native double Distance;
|
native double Distance;
|
||||||
native double Fraction;
|
native double Fraction;
|
||||||
|
|
||||||
native Actor Thing; // valid if hit an actor. // originally called "Actor".
|
native Actor HitActor; // valid if hit an actor. // originally called "Actor".
|
||||||
|
|
||||||
native Line Linedef; // valid if hit a line // originally called "Line".
|
native Line HitLine; // valid if hit a line // originally called "Line".
|
||||||
native uint8 Side;
|
native uint8 Side;
|
||||||
native uint8 Tier; // see Tracer.ELineTier
|
native uint8 Tier; // see Tracer.ELineTier
|
||||||
native bool unlinked; // passed through a portal without static offset.
|
native bool unlinked; // passed through a portal without static offset.
|
||||||
|
|
Loading…
Reference in a new issue