This commit is contained in:
parent
990c698c80
commit
bce429efdb
7 changed files with 178 additions and 43 deletions
|
@ -10,15 +10,27 @@
|
|||
#include <sprites.h>
|
||||
#include "level\level.h"
|
||||
#include "game\game.h"
|
||||
#include "level\layercollision.h"
|
||||
#include "FX\FXBaseAnim.h"
|
||||
|
||||
|
||||
/*****************************************************************************/
|
||||
void CFXBaseAnim::init(DVECTOR const &_Pos)
|
||||
{
|
||||
CFX::init(_Pos);
|
||||
CurrentFrame=0;
|
||||
CurrentScale=DataPtr->Scale;
|
||||
Life=((DataPtr->EndFrame-DataPtr->StartFrame)<<DataPtr->FrameShift)-1;
|
||||
MaxFrame=((DataPtr->EndFrame-DataPtr->StartFrame)<<DataPtr->FrameShift)-1;
|
||||
if (DataPtr->Flags & FXANIM_FLAG_LOOP)
|
||||
{ // Looping Anim, so let it live forever!
|
||||
Life=-1;
|
||||
}
|
||||
else
|
||||
{
|
||||
Life=MaxFrame;
|
||||
}
|
||||
|
||||
Gravity=0;
|
||||
}
|
||||
|
||||
/*****************************************************************************/
|
||||
|
@ -34,9 +46,44 @@ void CFXBaseAnim::think(int _frames)
|
|||
{
|
||||
CFX::think(_frames);
|
||||
CurrentFrame+=_frames;
|
||||
Pos.vy-=4;
|
||||
|
||||
if (CurrentFrame>=MaxFrame)
|
||||
{
|
||||
CurrentFrame=0;
|
||||
}
|
||||
Pos.vx+=DataPtr->Velocity.vx;
|
||||
Pos.vy+=DataPtr->Velocity.vy+Gravity;
|
||||
|
||||
if (DataPtr->Flags & FXANIM_FLAG_HAS_GRAVITY)
|
||||
{
|
||||
Gravity++;
|
||||
}
|
||||
|
||||
if (DataPtr->Flags & FXANIM_FLAG_COLLIDE_KILL)
|
||||
{
|
||||
CLayerCollision *ColLayer=CGameScene::getCollision();
|
||||
int DistY = ColLayer->getHeightFromGround( Pos.vx, Pos.vy, 16 );
|
||||
|
||||
if (DistY<=0)
|
||||
{
|
||||
Pos.vy-=DistY;
|
||||
killFX();
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
/*****************************************************************************/
|
||||
void CFXBaseAnim::killFX()
|
||||
{
|
||||
setToShutdown();
|
||||
// If has follow on effect, create it now
|
||||
if (DataPtr->EndFX)
|
||||
{
|
||||
CFX::Create((CFX::FX_TYPE)DataPtr->EndFX,getPos());
|
||||
}
|
||||
}
|
||||
|
||||
/*****************************************************************************/
|
||||
/*****************************************************************************/
|
||||
/*** Render ******************************************************************/
|
||||
/*****************************************************************************/
|
||||
|
@ -51,7 +98,7 @@ SpriteBank *SprBank=CGameScene::getSpriteBank();
|
|||
|
||||
int ThisFrame=CurrentFrame>>DataPtr->FrameShift;
|
||||
|
||||
POLY_FT4 *Ft4=SprBank->printFT4Scaled(DataPtr->StartFrame+ThisFrame,RenderPos.vx,RenderPos.vy,0,0,OtPos,CurrentScale>>4);
|
||||
POLY_FT4 *Ft4=SprBank->printFT4Scaled(DataPtr->StartFrame+ThisFrame,RenderPos.vx,RenderPos.vy,0,0,OtPos*0,CurrentScale>>4);
|
||||
Ft4->u1--; Ft4->u3--;
|
||||
Ft4->v2--; Ft4->v3--;
|
||||
setShadeTex(Ft4,0);
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue