This commit is contained in:
parent
9e6fae82c4
commit
5298e61a8a
2 changed files with 313 additions and 0 deletions
278
source/hazard/hrrock.cpp
Normal file
278
source/hazard/hrrock.cpp
Normal file
|
@ -0,0 +1,278 @@
|
||||||
|
/*=========================================================================
|
||||||
|
|
||||||
|
hrrock.cpp
|
||||||
|
|
||||||
|
Author: CRB
|
||||||
|
Created:
|
||||||
|
Project: Spongebob
|
||||||
|
Purpose:
|
||||||
|
|
||||||
|
Copyright (c) 2001 Climax Development Ltd
|
||||||
|
|
||||||
|
===========================================================================*/
|
||||||
|
|
||||||
|
#ifndef __HAZARD_HRROCK_H__
|
||||||
|
#include "hazard\hrrock.h"
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifndef __LAYER_COLLISION_H__
|
||||||
|
#include "level\layercollision.h"
|
||||||
|
#endif
|
||||||
|
|
||||||
|
////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
|
||||||
|
|
||||||
|
void CNpcRollingRockHazard::init()
|
||||||
|
{
|
||||||
|
CNpcHazard::init();
|
||||||
|
|
||||||
|
m_npcPath.setPathType( CNpcPath::SINGLE_USE_PATH );
|
||||||
|
m_rotation = 0;
|
||||||
|
m_jump = false;
|
||||||
|
}
|
||||||
|
|
||||||
|
////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
|
||||||
|
|
||||||
|
void CNpcRollingRockHazard::processMovement( int _frames )
|
||||||
|
{
|
||||||
|
s32 maxHeight = 20;
|
||||||
|
s32 distX, distY;
|
||||||
|
s32 fallSpeed = 3;
|
||||||
|
s8 yMovement = fallSpeed * _frames;
|
||||||
|
s32 groundHeight;
|
||||||
|
|
||||||
|
s32 moveX = 0;
|
||||||
|
s32 moveY = 0;
|
||||||
|
|
||||||
|
// ignore y component of waypoint, since we are stuck to the ground
|
||||||
|
|
||||||
|
bool pathComplete;
|
||||||
|
bool waypointChange;
|
||||||
|
|
||||||
|
m_npcPath.think( Pos, &pathComplete, &waypointChange, &distX, &distY );
|
||||||
|
|
||||||
|
if ( pathComplete )
|
||||||
|
{
|
||||||
|
// reset
|
||||||
|
|
||||||
|
Pos = m_base;
|
||||||
|
m_npcPath.resetPath();
|
||||||
|
m_jump = false;
|
||||||
|
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
if ( distX )
|
||||||
|
{
|
||||||
|
// move along ground
|
||||||
|
|
||||||
|
s32 groundSpeed = 3 * _frames;
|
||||||
|
|
||||||
|
moveX = distX;
|
||||||
|
|
||||||
|
if ( moveX > groundSpeed )
|
||||||
|
{
|
||||||
|
moveX = groundSpeed;
|
||||||
|
}
|
||||||
|
else if ( moveX < -groundSpeed )
|
||||||
|
{
|
||||||
|
moveX = -groundSpeed;
|
||||||
|
}
|
||||||
|
|
||||||
|
if ( m_jump )
|
||||||
|
{
|
||||||
|
// process jump movement
|
||||||
|
|
||||||
|
if ( m_jumpVel < ( 16 << 8 ) )
|
||||||
|
{
|
||||||
|
m_jumpVel += 128 * _frames;
|
||||||
|
}
|
||||||
|
|
||||||
|
moveY += m_jumpVel >> 8;
|
||||||
|
|
||||||
|
groundHeight = m_layerCollision->getHeightFromGround( Pos.vx + moveX, Pos.vy + moveY, 16 );
|
||||||
|
|
||||||
|
if ( groundHeight < 16 )
|
||||||
|
{
|
||||||
|
// have hit ground
|
||||||
|
|
||||||
|
m_jump = false;
|
||||||
|
moveY += groundHeight;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
// check for vertical movement
|
||||||
|
|
||||||
|
groundHeight = m_layerCollision->getHeightFromGround( Pos.vx + moveX, Pos.vy, 64 );
|
||||||
|
|
||||||
|
if ( groundHeight < 64 )
|
||||||
|
{
|
||||||
|
// groundHeight <= yMovement indicates either just above ground or on or below ground
|
||||||
|
|
||||||
|
moveY = groundHeight;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
// cannot find ground immediately below
|
||||||
|
|
||||||
|
m_jump = true;
|
||||||
|
|
||||||
|
m_jumpVel = 0;
|
||||||
|
moveY = 0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
// drop vertically
|
||||||
|
|
||||||
|
// check for vertical movement
|
||||||
|
|
||||||
|
groundHeight = m_layerCollision->getHeightFromGround( Pos.vx, Pos.vy, yMovement + 16 );
|
||||||
|
|
||||||
|
if ( groundHeight <= yMovement )
|
||||||
|
{
|
||||||
|
// groundHeight <= yMovement indicates either just above ground or on or below ground
|
||||||
|
|
||||||
|
moveY = groundHeight;
|
||||||
|
|
||||||
|
// increment path if we hit the ground at this stage
|
||||||
|
|
||||||
|
m_npcPath.incPath();
|
||||||
|
m_jump = false;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
// fall
|
||||||
|
|
||||||
|
moveY = yMovement;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
/*if ( m_npcPath.thinkFlat( Pos, &pathComplete, &distX, &distY, &m_heading ) )
|
||||||
|
{
|
||||||
|
if ( pathComplete )
|
||||||
|
{
|
||||||
|
// reset
|
||||||
|
|
||||||
|
Pos = m_base;
|
||||||
|
m_npcPath.resetPath();
|
||||||
|
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
// check for vertical movement
|
||||||
|
|
||||||
|
groundHeight = m_layerCollision->getHeightFromGround( Pos.vx, Pos.vy, yMovement + 16 );
|
||||||
|
|
||||||
|
if ( groundHeight <= yMovement )
|
||||||
|
{
|
||||||
|
// groundHeight <= yMovement indicates either just above ground or on or below ground
|
||||||
|
|
||||||
|
moveY = groundHeight;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
// fall
|
||||||
|
|
||||||
|
moveY = yMovement;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
// check for collision
|
||||||
|
|
||||||
|
distX = distX / abs( distX );
|
||||||
|
|
||||||
|
if ( m_layerCollision->getHeightFromGround( Pos.vx + ( distX * 3 * _frames ), Pos.vy ) < -maxHeight )
|
||||||
|
{
|
||||||
|
// there is an obstacle in the way, increment the path point (hopefully this will resolve the problem)
|
||||||
|
|
||||||
|
m_npcPath.incPath();
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
// check for vertical movement
|
||||||
|
|
||||||
|
groundHeight = m_layerCollision->getHeightFromGround( Pos.vx, Pos.vy, yMovement + 16 );
|
||||||
|
|
||||||
|
moveX = distX * 3 * _frames;
|
||||||
|
|
||||||
|
if ( groundHeight <= yMovement )
|
||||||
|
{
|
||||||
|
// groundHeight <= yMovement indicates either just above ground or on or below ground
|
||||||
|
|
||||||
|
moveY = groundHeight;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
// fall
|
||||||
|
|
||||||
|
moveY = yMovement;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}*/
|
||||||
|
|
||||||
|
if ( moveX < 0 )
|
||||||
|
{
|
||||||
|
m_rotation -= 64 * _frames;
|
||||||
|
m_rotation &= 4095;
|
||||||
|
}
|
||||||
|
else if ( moveX > 0 )
|
||||||
|
{
|
||||||
|
m_rotation += 64 * _frames;
|
||||||
|
m_rotation &= 4095;
|
||||||
|
}
|
||||||
|
|
||||||
|
Pos.vx += moveX;
|
||||||
|
Pos.vy += moveY;
|
||||||
|
}
|
||||||
|
|
||||||
|
////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
|
||||||
|
|
||||||
|
void CNpcRollingRockHazard::render()
|
||||||
|
{
|
||||||
|
CHazardThing::render();
|
||||||
|
|
||||||
|
if (canRender())
|
||||||
|
{
|
||||||
|
DVECTOR &renderPos=getRenderPos();
|
||||||
|
|
||||||
|
SVECTOR rotation;
|
||||||
|
rotation.vx = 0;
|
||||||
|
rotation.vy = 0;
|
||||||
|
rotation.vz = m_rotation;
|
||||||
|
|
||||||
|
VECTOR scale;
|
||||||
|
scale.vx = ONE;
|
||||||
|
scale.vy = ONE;
|
||||||
|
scale.vz = ONE;
|
||||||
|
|
||||||
|
m_modelGfx->Render(renderPos,&rotation,&scale);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
|
||||||
|
|
||||||
|
const CRECT *CNpcRollingRockHazard::getThinkBBox()
|
||||||
|
{
|
||||||
|
CRECT objThinkBox = getCollisionArea();
|
||||||
|
|
||||||
|
sBBox &thinkBBox = CThingManager::getThinkBBox();
|
||||||
|
objThinkBox.x1 = thinkBBox.XMin;
|
||||||
|
objThinkBox.x2 = thinkBBox.XMax;
|
||||||
|
objThinkBox.y1 = thinkBBox.YMin;
|
||||||
|
objThinkBox.y2 = thinkBBox.YMax;
|
||||||
|
|
||||||
|
return &objThinkBox;
|
||||||
|
}
|
35
source/hazard/hrrock.h
Normal file
35
source/hazard/hrrock.h
Normal file
|
@ -0,0 +1,35 @@
|
||||||
|
/*=========================================================================
|
||||||
|
|
||||||
|
hrrock.h
|
||||||
|
|
||||||
|
Author: CRB
|
||||||
|
Created:
|
||||||
|
Project: Spongebob
|
||||||
|
Purpose:
|
||||||
|
|
||||||
|
Copyright (c) 2001 Climax Development Ltd
|
||||||
|
|
||||||
|
===========================================================================*/
|
||||||
|
|
||||||
|
#ifndef __HAZARD_HRROCK_H__
|
||||||
|
#define __HAZARD_HRROCK_H__
|
||||||
|
|
||||||
|
#ifndef __HAZARD_HAZARD_H__
|
||||||
|
#include "hazard\hazard.h"
|
||||||
|
#endif
|
||||||
|
|
||||||
|
class CNpcRollingRockHazard : public CNpcHazard
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
void init();
|
||||||
|
void render();
|
||||||
|
virtual CRECT const *getThinkBBox();
|
||||||
|
protected:
|
||||||
|
void processMovement( int _frames );
|
||||||
|
|
||||||
|
s16 m_rotation;
|
||||||
|
u8 m_jump;
|
||||||
|
s32 m_jumpVel;
|
||||||
|
};
|
||||||
|
|
||||||
|
#endif
|
Loading…
Add table
Reference in a new issue