This commit is contained in:
parent
ceb6672c0f
commit
9ad7e14f55
17 changed files with 467 additions and 857 deletions
|
@ -20,48 +20,68 @@
|
|||
void CNpcGeyserPlatform::postInit()
|
||||
{
|
||||
m_npcPath.setPathType( CNpcPath::SINGLE_USE_PATH );
|
||||
|
||||
m_isFiring = false;
|
||||
}
|
||||
|
||||
////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
|
||||
|
||||
void CNpcGeyserPlatform::processMovement( int _frames )
|
||||
{
|
||||
s32 moveY = 0;
|
||||
s32 distX, distY, heading;
|
||||
bool pathComplete;
|
||||
|
||||
m_npcPath.thinkVertical( Pos, &pathComplete, &distX, &distY, &heading );
|
||||
|
||||
if ( pathComplete )
|
||||
if ( m_isFiring )
|
||||
{
|
||||
m_npcPath.resetPath();
|
||||
reinit();
|
||||
s32 moveY = 0;
|
||||
s32 distX, distY, heading;
|
||||
bool pathComplete;
|
||||
|
||||
m_npcPath.thinkVertical( Pos, &pathComplete, &distX, &distY, &heading );
|
||||
|
||||
if ( pathComplete )
|
||||
{
|
||||
m_npcPath.resetPath();
|
||||
reinit();
|
||||
m_isFiring = false;
|
||||
}
|
||||
else
|
||||
{
|
||||
s32 minY, maxY;
|
||||
|
||||
m_npcPath.getPathYExtents( &minY, &maxY );
|
||||
|
||||
moveY = m_data[m_type].speed * _frames;
|
||||
|
||||
if ( Pos.vy < ( minY + 64 ) )
|
||||
{
|
||||
s32 multiplier = Pos.vy - minY;
|
||||
|
||||
moveY = ( multiplier * moveY ) >> 6;
|
||||
|
||||
if ( moveY < 1 )
|
||||
{
|
||||
moveY = 1;
|
||||
}
|
||||
}
|
||||
|
||||
if ( heading == 3072 )
|
||||
{
|
||||
moveY = -moveY;
|
||||
}
|
||||
|
||||
Pos.vy += moveY;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
|
||||
|
||||
void CNpcGeyserPlatform::processTimer( int _frames )
|
||||
{
|
||||
if ( m_timer > 0 )
|
||||
{
|
||||
m_timer -= _frames;
|
||||
}
|
||||
else
|
||||
{
|
||||
s32 minY, maxY;
|
||||
|
||||
m_npcPath.getPathYExtents( &minY, &maxY );
|
||||
|
||||
moveY = m_data[m_type].speed * _frames;
|
||||
|
||||
if ( Pos.vy < ( minY + 64 ) )
|
||||
{
|
||||
s32 multiplier = Pos.vy - minY;
|
||||
|
||||
moveY = ( multiplier * moveY ) >> 6;
|
||||
|
||||
if ( moveY < 1 )
|
||||
{
|
||||
moveY = 1;
|
||||
}
|
||||
}
|
||||
|
||||
if ( heading == 3072 )
|
||||
{
|
||||
moveY = -moveY;
|
||||
}
|
||||
|
||||
Pos.vy += moveY;
|
||||
m_isFiring = true;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue