mirror of
https://github.com/ZDoom/qzdoom-gpl.git
synced 2025-01-18 21:21:36 +00:00
- Make CheckActorFloorTexture and CheckActorCeilingTexture aware of 3D-floors.
SVN r3454 (trunk)
This commit is contained in:
parent
b4d3870ce6
commit
e93029a42a
2 changed files with 61 additions and 18 deletions
|
@ -3175,6 +3175,64 @@ int DLevelScript::CheckActorProperty (int tid, int property, int value)
|
||||||
return (!stricmp(string, FBehavior::StaticLookupString(value)));
|
return (!stricmp(string, FBehavior::StaticLookupString(value)));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool DLevelScript::DoCheckActorTexture(int tid, AActor *activator, int string, bool floor)
|
||||||
|
{
|
||||||
|
AActor *actor = SingleActorFromTID(tid, activator);
|
||||||
|
if (actor == NULL)
|
||||||
|
{
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
FTexture *tex = TexMan.FindTexture(FBehavior::StaticLookupString(string));
|
||||||
|
if (tex == NULL)
|
||||||
|
{ // If the texture we want to check against doesn't exist, then
|
||||||
|
// they're obviously not the same.
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
int i, numff;
|
||||||
|
FTextureID secpic;
|
||||||
|
sector_t *sec = actor->Sector;
|
||||||
|
numff = sec->e->XFloor.ffloors.Size();
|
||||||
|
|
||||||
|
if (floor)
|
||||||
|
{
|
||||||
|
// Looking through planes from top to bottom
|
||||||
|
for (i = 0; i < numff; ++i)
|
||||||
|
{
|
||||||
|
F3DFloor *ff = sec->e->XFloor.ffloors[i];
|
||||||
|
|
||||||
|
if (actor->z >= ff->top.plane->ZatPoint(actor->x, actor->y))
|
||||||
|
{ // This floor is beneath our feet.
|
||||||
|
secpic = *ff->top.texture;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (i == numff)
|
||||||
|
{ // Use sector's floor
|
||||||
|
secpic = sec->GetTexture(sector_t::floor);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
fixed_t z = actor->z + actor->height;
|
||||||
|
// Looking through planes from bottom to top
|
||||||
|
for (i = numff-1; i >= 0; --i)
|
||||||
|
{
|
||||||
|
F3DFloor *ff = sec->e->XFloor.ffloors[i];
|
||||||
|
|
||||||
|
if (z <= ff->bottom.plane->ZatPoint(actor->x, actor->y))
|
||||||
|
{ // This floor is above our eyes.
|
||||||
|
secpic = *ff->bottom.texture;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (i < 0)
|
||||||
|
{ // Use sector's ceiling
|
||||||
|
secpic = sec->GetTexture(sector_t::ceiling);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return tex == TexMan[secpic];
|
||||||
|
}
|
||||||
|
|
||||||
enum
|
enum
|
||||||
{
|
{
|
||||||
// These are the original inputs sent by the player.
|
// These are the original inputs sent by the player.
|
||||||
|
@ -6966,30 +7024,14 @@ int DLevelScript::RunScript ()
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case PCD_CHECKACTORCEILINGTEXTURE:
|
case PCD_CHECKACTORCEILINGTEXTURE:
|
||||||
{
|
STACK(2) = DoCheckActorTexture(STACK(2), activator, STACK(1), false);
|
||||||
AActor *actor = SingleActorFromTID(STACK(2), activator);
|
|
||||||
if (actor != NULL)
|
|
||||||
{
|
|
||||||
FTexture *tex = TexMan.FindTexture(FBehavior::StaticLookupString(STACK(1)));
|
|
||||||
STACK(2) = (tex == TexMan[actor->Sector->GetTexture(sector_t::ceiling)]);
|
|
||||||
}
|
|
||||||
else STACK(2)=0;
|
|
||||||
sp--;
|
sp--;
|
||||||
break;
|
break;
|
||||||
}
|
|
||||||
|
|
||||||
case PCD_CHECKACTORFLOORTEXTURE:
|
case PCD_CHECKACTORFLOORTEXTURE:
|
||||||
{
|
STACK(2) = DoCheckActorTexture(STACK(2), activator, STACK(1), true);
|
||||||
AActor *actor = SingleActorFromTID(STACK(2), activator);
|
|
||||||
if (actor != NULL)
|
|
||||||
{
|
|
||||||
FTexture *tex = TexMan.FindTexture(FBehavior::StaticLookupString(STACK(1)));
|
|
||||||
STACK(2) = (tex == TexMan[actor->Sector->GetTexture(sector_t::floor)]);
|
|
||||||
}
|
|
||||||
else STACK(2)=0;
|
|
||||||
sp--;
|
sp--;
|
||||||
break;
|
break;
|
||||||
}
|
|
||||||
|
|
||||||
case PCD_GETACTORLIGHTLEVEL:
|
case PCD_GETACTORLIGHTLEVEL:
|
||||||
{
|
{
|
||||||
|
|
|
@ -714,6 +714,7 @@ protected:
|
||||||
static void SetLineTexture (int lineid, int side, int position, int name);
|
static void SetLineTexture (int lineid, int side, int position, int name);
|
||||||
static void ReplaceTextures (int fromname, int toname, int flags);
|
static void ReplaceTextures (int fromname, int toname, int flags);
|
||||||
static int DoSpawn (int type, fixed_t x, fixed_t y, fixed_t z, int tid, int angle, bool force);
|
static int DoSpawn (int type, fixed_t x, fixed_t y, fixed_t z, int tid, int angle, bool force);
|
||||||
|
static bool DoCheckActorTexture(int tid, AActor *activator, int string, bool floor);
|
||||||
int DoSpawnSpot (int type, int spot, int tid, int angle, bool forced);
|
int DoSpawnSpot (int type, int spot, int tid, int angle, bool forced);
|
||||||
int DoSpawnSpotFacing (int type, int spot, int tid, bool forced);
|
int DoSpawnSpotFacing (int type, int spot, int tid, bool forced);
|
||||||
int DoClassifyActor (int tid);
|
int DoClassifyActor (int tid);
|
||||||
|
|
Loading…
Reference in a new issue