This commit is contained in:
Charles 2001-05-14 14:21:04 +00:00
parent 5ebc73e91c
commit a816643c57
6 changed files with 185 additions and 7 deletions

View File

@ -87,6 +87,11 @@ bool CNpcSpiderCrabEnemy::processSensor()
m_attackDist = abs( playerXDist );
if ( abs( m_attackDist ) < 1 )
{
m_attackDist = 1;
}
m_controlFunc = NPC_CONTROL_CLOSE;
m_extension = 0;
m_velocity = 5;

View File

@ -27,6 +27,161 @@
#include "utils\utils.h"
#endif
#ifndef __GAME_GAME_H__
#include "game\game.h"
#endif
////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
void CNpcJellyfishPlatform::postInit()
{
CNpcLinearPlatform::postInit();
m_vertScale = 0;
m_dipCount = 0;
}
////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
void CNpcJellyfishPlatform::collidedWith( CThing *_thisThing )
{
switch(_thisThing->getThingType())
{
case TYPE_PLAYER:
{
if ( m_detectCollision && m_isActive )
{
CPlayer *player;
DVECTOR playerPos;
CRECT collisionArea;
CRECT playerArea;
// Only interested in SBs feet colliding with the box (pkg)
player=(CPlayer*)_thisThing;
playerPos=player->getPos();
playerArea=player->getCollisionArea();
collisionArea=getCollisionArea();
s32 height = getHeightFromPlatformAtPosition(playerPos.vx,playerPos.vy);
if(playerPos.vx>=collisionArea.x1&&playerPos.vx<=collisionArea.x2&&
playerPos.vy>=collisionArea.y1&&playerPos.vy<=collisionArea.y2)
//if(((playerArea.x1>=collisionArea.x1&&playerArea.x1<=collisionArea.x2)||(playerArea.x2>=collisionArea.x1&&playerArea.x2<=collisionArea.x2)||(playerArea.x1<=collisionArea.x1&&playerArea.x2>=collisionArea.x2))&&
//((playerArea.y1>=thatRect.y1&&playerArea.y1<=thatRect.y2)||(playerArea.y2>=thatRect.y1&&playerArea.y2<=thatRect.y2)||(playerArea.y1<=thatRect.y1&&playerArea.y2>=thatRect.y2)))
{
player->setPlatform( this );
if( height == 0 )
{
m_contact = true;
}
}
if ( height < -30 )
{
// shock player
player->takeDamage( DAMAGE__SHOCK_ENEMY, REACT__GET_DIRECTION_FROM_THING, _thisThing );
}
}
break;
}
default:
break;
}
}
////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
void CNpcJellyfishPlatform::think( int _frames )
{
/*if ( m_contact )
{
if ( m_vertScale > -2048 )
{
m_vertScale -= 10;
}
Pos.vy += 3;
}
else if ( m_vertScale < 0 )
{
m_vertScale += 10;
}*/
if ( m_contact )
{
if ( m_dipCount < GameState::getOneSecondInFrames() )
{
s16 sineVal = ( m_dipCount << 10 ) / GameState::getOneSecondInFrames();
Pos.vy += ( 3 * rcos( sineVal ) ) >> 12;
m_dipCount += _frames;
}
}
else
{
m_dipCount = 0;
}
CNpcLinearPlatform::think( _frames );
}
////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
void CNpcJellyfishPlatform::render()
{
if ( m_isActive )
{
CPlatformThing::render();
if (canRender())
{
DVECTOR &renderPos=getRenderPos();
SVECTOR rotation;
rotation.vx = 0;
rotation.vy = 0;
rotation.vz = 0;
VECTOR scale;
scale.vx = ONE;
//scale.vy = ONE + m_vertScale;
scale.vy = ONE;
scale.vz = ONE;
m_modelGfx->Render(renderPos,&rotation,&scale);
#if defined (__USER_paul__) || defined (__USER_charles__)
DVECTOR offset = CLevel::getCameraPos();
DVECTOR centre;
DVECTOR size;
int halfLength;
int x1,y1,x2,y2;
centre=getCollisionCentre();
size=getCollisionSize();
halfLength=size.vx>>1;
x1=-halfLength*mcos(getCollisionAngle()&4095)>>12;
y1=-halfLength*msin(getCollisionAngle()&4095)>>12;
x2=+halfLength*mcos(getCollisionAngle()&4095)>>12;
y2=+halfLength*msin(getCollisionAngle()&4095)>>12;
centre.vx-=offset.vx;
centre.vy-=offset.vy;
x1+=centre.vx;
y1+=centre.vy;
x2+=centre.vx;
y2+=centre.vy;
DrawLine(x1,y1,x2,y2,0,255,0,0);
#endif
}
}
}

View File

@ -14,14 +14,21 @@
#ifndef __PLATFORM_PJELLFSH_H__
#define __PLATFORM_PLANTERN_H__
#ifndef __PLATFORM_PLATFORM_H__
#include "platform\platform.h"
#ifndef __PLATFORM_PLINEAR_H__
#include "platform\plinear.h"
#endif
class CNpcJellyfishPlatform : public CNpcPlatform
class CNpcJellyfishPlatform : public CNpcLinearPlatform
{
public:
virtual void render();
virtual void postInit();
virtual void think( int _frames );
protected:
virtual void collidedWith(CThing *_thisThing);
s32 m_vertScale;
u8 m_dipCount;
};
#endif

View File

@ -399,5 +399,6 @@ CNpcPlatform::NPC_PLATFORM_UNIT_TYPE CNpcPlatform::mapEditConvertTable[NPC_PLATF
NPC_BUBBLE_GEYSER_GENERATOR,
NPC_BIG_WHEEL_PLATFORM,
NPC_STEERABLE_BARREL_PLATFORM,
NPC_JELLYFISH_PLATFORM,
NPC_PLAYER_BUBBLE_PLATFORM,
};

View File

@ -139,6 +139,10 @@
#include "platform\psbarrel.h"
#endif
#ifndef __PLATFORM_PJELLFSH_H__
#include "platform\pjellfsh.h"
#endif
#include "fx\fx.h"
#include "fx\fxjfish.h"
@ -324,6 +328,12 @@ CNpcPlatform *CNpcPlatform::Create(sThingPlatform *ThisPlatform)
break;
}
case NPC_JELLYFISH_PLATFORM:
{
platform = new ("jellyfish platform") CNpcJellyfishPlatform;
break;
}
default:
{
ASSERT( 0 );
@ -482,7 +492,7 @@ void CNpcPlatform::postInit()
setCollisionSize( ( boundingBox.XMax - boundingBox.XMin ), PLATFORMCOLLISIONHEIGHT);
setCollisionCentreOffset( ( boundingBox.XMax + boundingBox.XMin ) >> 1, boundingBox.YMin );
if ( m_type == NPC_LINEAR_PLATFORM )
/*if ( m_type == NPC_LINEAR_PLATFORM )
{
switch( CLevel::getCurrentChapter() )
{
@ -509,7 +519,7 @@ void CNpcPlatform::postInit()
// CFXJellyFishLegs *T=(CFXJellyFishLegs*)CFX::Create(CFX::FX_TYPE_JELLYFISH_LEGS,this);
// T->SetUp(64,4,8,8);
}
}*/
}
////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////

View File

@ -79,7 +79,7 @@ Jelly_Launcher=16
# Platforms
[PLATFORM]
Bubble=4
Jellyfish=1
Jellyfish=25
Industrial=1
Leaf=2
FishHook1=5