This commit is contained in:
Charles 2001-07-05 18:21:45 +00:00
parent 09988b65e3
commit 9de1206cc2
4 changed files with 99 additions and 50 deletions

View file

@ -1,2 +1,2 @@
Idle Idle
Move

View file

@ -29,6 +29,35 @@
void CNpcDustDevilEnemy::postInit() void CNpcDustDevilEnemy::postInit()
{ {
m_npcPath.setPathType( CNpcPath::SINGLE_USE_PATH ); m_npcPath.setPathType( CNpcPath::SINGLE_USE_PATH );
m_fadeVal = 128;
m_fadeOut = false;
}
////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
void CNpcDustDevilEnemy::render()
{
SprFrame = NULL;
if ( m_isActive )
{
CEnemyThing::render();
if (canRender())
{
DVECTOR &renderPos=getRenderPos();
SprFrame = m_actorGfx->Render(renderPos,m_animNo,( m_frame >> 8 ),m_reversed);
setSemiTrans( SprFrame, true );
m_actorGfx->RotateScale( SprFrame, renderPos, m_drawRotation, 4096, 4096 );
setRGB0( SprFrame, m_fadeVal, m_fadeVal, m_fadeVal );
sBBox boundingBox = m_actorGfx->GetBBox();
setCollisionSize( ( boundingBox.XMax - boundingBox.XMin ), ( boundingBox.YMax - boundingBox.YMin ) );
setCollisionCentreOffset( ( boundingBox.XMax + boundingBox.XMin ) >> 1, ( boundingBox.YMax + boundingBox.YMin ) >> 1 );
}
}
} }
//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// ////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
@ -57,6 +86,22 @@ void CNpcDustDevilEnemy::processMovement( int _frames )
m_animNo = m_data[m_type].moveAnim; m_animNo = m_data[m_type].moveAnim;
} }
if ( m_fadeOut )
{
m_fadeVal -= _frames * 12;
if ( m_fadeVal < 0 )
{
m_npcPath.resetPath();
Pos = m_base;
m_fadeOut = false;
m_fadeVal = 128;
}
}
else
{
// ignore y component of waypoint, since we are stuck to the ground // ignore y component of waypoint, since we are stuck to the ground
if ( m_npcPath.thinkFlat( Pos, &pathComplete, &distX, &distY, &m_heading ) ) if ( m_npcPath.thinkFlat( Pos, &pathComplete, &distX, &distY, &m_heading ) )
@ -65,9 +110,7 @@ void CNpcDustDevilEnemy::processMovement( int _frames )
if ( pathComplete ) if ( pathComplete )
{ {
m_npcPath.resetPath(); m_fadeOut = true;
Pos = m_base;
} }
else else
{ {
@ -125,6 +168,7 @@ void CNpcDustDevilEnemy::processMovement( int _frames )
processMovementModifier( _frames, moveX, moveY, moveVel, moveDist ); processMovementModifier( _frames, moveX, moveY, moveVel, moveDist );
} }
}
//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// ////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////

View file

@ -18,10 +18,15 @@ class CNpcDustDevilEnemy : public CNpcEnemy
{ {
public: public:
void postInit(); void postInit();
void render();
u8 canCollideWithEnemy() {return( false );}
protected: protected:
s32 getFrameShift( int _frames ); s32 getFrameShift( int _frames );
void processMovement( int _frames ); void processMovement( int _frames );
void processMovementModifier( int _frames, s32 distX, s32 distY, s32 dist, s16 headingChange ); void processMovementModifier( int _frames, s32 distX, s32 distY, s32 dist, s16 headingChange );
s16 m_fadeVal;
u8 m_fadeOut;
}; };
#endif #endif

View file

@ -123,8 +123,8 @@ CNpcEnemy::NPC_DATA CNpcEnemy::m_data[NPC_UNIT_TYPE_MAX] =
false, false,
3, 3,
2048, 2048,
DETECT_NO_COLLISION, DETECT_ALL_COLLISION,
DAMAGE__NONE, DAMAGE__HIT_ENEMY,
1, 1,
ANIM_DUSTDEVIL_TWIST, ANIM_DUSTDEVIL_TWIST,
NPC_SHOT_GENERIC, NPC_SHOT_GENERIC,
@ -133,7 +133,7 @@ CNpcEnemy::NPC_DATA CNpcEnemy::m_data[NPC_UNIT_TYPE_MAX] =
false, false,
false, false,
false, false,
true, false,
CSoundMediator::NUM_SFXIDS, CSoundMediator::NUM_SFXIDS,
CSoundMediator::NUM_SFXIDS, CSoundMediator::NUM_SFXIDS,
false, false,
@ -699,7 +699,7 @@ CNpcEnemy::NPC_DATA CNpcEnemy::m_data[NPC_UNIT_TYPE_MAX] =
DETECT_ALL_COLLISION, DETECT_ALL_COLLISION,
DAMAGE__HIT_ENEMY, DAMAGE__HIT_ENEMY,
1, 1,
ANIM_GHOST_MOVE, ANIM_GHOST_IDLE,
NPC_SHOT_GENERIC, NPC_SHOT_GENERIC,
0, 0,
0, 0,