This commit is contained in:
parent
5cf79f93ac
commit
4135b52516
@ -15,15 +15,20 @@
|
||||
#include "platform\pgeyser.h"
|
||||
#endif
|
||||
|
||||
#ifndef __UTILS_HEADER__
|
||||
#include "utils\utils.h"
|
||||
#endif
|
||||
|
||||
|
||||
////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
|
||||
|
||||
void CNpcGeyserPlatform::postInit()
|
||||
{
|
||||
CNpcPlatform::postInit();
|
||||
|
||||
m_npcPath.setPathType( CNpcPath::SINGLE_USE_PATH );
|
||||
|
||||
m_isFiring = false;
|
||||
|
||||
m_state = GEYSER_READY;
|
||||
}
|
||||
|
||||
////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
|
||||
@ -32,46 +37,86 @@ void CNpcGeyserPlatform::processMovement( int _frames )
|
||||
{
|
||||
if ( m_isFiring )
|
||||
{
|
||||
s32 moveY = 0;
|
||||
s32 distX, distY, heading;
|
||||
bool pathComplete;
|
||||
s32 minY, maxY;
|
||||
m_npcPath.getPathYExtents( &minY, &maxY );
|
||||
|
||||
m_npcPath.thinkVertical( Pos, &pathComplete, &distX, &distY, &heading );
|
||||
|
||||
if ( pathComplete )
|
||||
switch ( m_state )
|
||||
{
|
||||
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 ) )
|
||||
case GEYSER_DROPPING:
|
||||
{
|
||||
s32 multiplier = Pos.vy - minY;
|
||||
|
||||
moveY = ( multiplier * moveY ) >> 6;
|
||||
|
||||
if ( moveY < 1 )
|
||||
if ( maxY - Pos.vy == 0 )
|
||||
{
|
||||
moveY = 1;
|
||||
m_isFiring = false;
|
||||
reinit();
|
||||
m_state = GEYSER_READY;
|
||||
}
|
||||
else
|
||||
{
|
||||
s32 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;
|
||||
}
|
||||
}
|
||||
|
||||
Pos.vy += moveY;
|
||||
|
||||
if ( Pos.vy > maxY )
|
||||
{
|
||||
Pos.vy = maxY;
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
break;
|
||||
}
|
||||
|
||||
if ( heading == 3072 )
|
||||
case GEYSER_RISING:
|
||||
{
|
||||
moveY = -moveY;
|
||||
}
|
||||
if ( minY - Pos.vy == 0 )
|
||||
{
|
||||
m_state = GEYSER_DROPPING;
|
||||
}
|
||||
else
|
||||
{
|
||||
s32 moveY = m_data[m_type].speed * _frames;
|
||||
|
||||
Pos.vy += moveY;
|
||||
if ( Pos.vy < ( minY + 64 ) )
|
||||
{
|
||||
s32 multiplier = Pos.vy - minY;
|
||||
|
||||
moveY = ( multiplier * moveY ) >> 6;
|
||||
|
||||
if ( moveY < 1 )
|
||||
{
|
||||
moveY = 1;
|
||||
}
|
||||
}
|
||||
|
||||
Pos.vy -= moveY;
|
||||
|
||||
if ( Pos.vy < minY )
|
||||
{
|
||||
Pos.vy = minY;
|
||||
}
|
||||
}
|
||||
|
||||
break;
|
||||
}
|
||||
}
|
||||
}
|
||||
else
|
||||
{
|
||||
Pos.vx = m_base.vx + ( -3 + ( getRnd() % 7 ) );
|
||||
Pos.vy = m_base.vy + ( -3 + ( getRnd() % 7 ) );
|
||||
}
|
||||
}
|
||||
|
||||
////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
|
||||
@ -84,6 +129,11 @@ void CNpcGeyserPlatform::processTimer( int _frames )
|
||||
}
|
||||
else
|
||||
{
|
||||
m_isFiring = true;
|
||||
if ( m_state == GEYSER_READY )
|
||||
{
|
||||
m_isFiring = true;
|
||||
Pos = m_base;
|
||||
m_state = GEYSER_RISING;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@ -27,6 +27,13 @@ protected:
|
||||
virtual void processTimer( int _frames );
|
||||
|
||||
bool m_isFiring;
|
||||
|
||||
enum GEYSER_STATE
|
||||
{
|
||||
GEYSER_READY,
|
||||
GEYSER_RISING,
|
||||
GEYSER_DROPPING,
|
||||
};
|
||||
};
|
||||
|
||||
#endif
|
@ -107,6 +107,7 @@ BubbleGeyserGenerator=22
|
||||
BigWheelPlatform=23
|
||||
FixedPathBarrelPlatform=1
|
||||
SteerableBarrelPlatform=24
|
||||
RockGeyser=7
|
||||
|
||||
################################################
|
||||
# Triggers
|
||||
@ -138,5 +139,6 @@ Masher=7
|
||||
Fan=8
|
||||
Spikes=9
|
||||
Wheel=10
|
||||
BarrelHazard=3
|
||||
|
||||
|
||||
|
@ -139,3 +139,13 @@ Collision=0
|
||||
Health=0
|
||||
AttackStrength=0
|
||||
Respawn=2
|
||||
|
||||
[BarrelHazard]
|
||||
Gfx=..\..\graphics\platforms\barrel\barrel.gin
|
||||
WayPoints=16
|
||||
Speed=0
|
||||
TurnRate=0
|
||||
Collision=0
|
||||
Health=0
|
||||
AttackStrength=0
|
||||
Respawn=2
|
||||
|
@ -95,4 +95,7 @@ Gfx=..\..\Graphics\platforms\carriage\carriage.gin
|
||||
Gfx=..\..\Graphics\platforms\barrel\barrel.gin
|
||||
|
||||
[SteerableBarrelPlatform]
|
||||
Gfx=..\..\Graphics\platforms\barrel\barrel.gin
|
||||
Gfx=..\..\Graphics\platforms\barrel\barrel.gin
|
||||
|
||||
[RockGeyser]
|
||||
Gfx=..\..\Graphics\platforms\rockplateau\rockplateau.gin
|
Loading…
Reference in New Issue
Block a user