2012-09-30 12:37:44 -04:00
|
|
|
#include "Globals.h"
|
|
|
|
|
|
|
|
#include "FallingBlock.h"
|
|
|
|
#include "World.h"
|
|
|
|
#include "ClientHandle.h"
|
2013-03-02 14:57:09 -05:00
|
|
|
#include "Simulator/SandSimulator.h"
|
2012-09-30 12:37:44 -04:00
|
|
|
|
|
|
|
|
2012-12-21 07:21:20 -05:00
|
|
|
|
2012-09-30 12:37:44 -04:00
|
|
|
|
|
|
|
|
2013-03-02 14:57:09 -05:00
|
|
|
cFallingBlock::cFallingBlock(const Vector3i & a_BlockPosition, BLOCKTYPE a_BlockType, NIBBLETYPE a_BlockMeta) :
|
|
|
|
super(etFallingBlock, a_BlockPosition.x + 0.5f, a_BlockPosition.y + 0.5f, a_BlockPosition.z + 0.5f),
|
|
|
|
m_BlockType(a_BlockType),
|
|
|
|
m_BlockMeta(a_BlockMeta),
|
|
|
|
m_OriginalPosition(a_BlockPosition)
|
2012-09-30 12:37:44 -04:00
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
void cFallingBlock::Initialize(cWorld * a_World)
|
|
|
|
{
|
2013-03-02 14:57:09 -05:00
|
|
|
super::Initialize(a_World);
|
2012-09-30 12:37:44 -04:00
|
|
|
a_World->BroadcastSpawn(*this);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
void cFallingBlock::SpawnOn(cClientHandle & a_ClientHandle)
|
|
|
|
{
|
2012-12-26 04:12:00 -05:00
|
|
|
a_ClientHandle.SendSpawnFallingBlock(*this);
|
2012-09-30 12:37:44 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
2012-12-22 05:15:53 -05:00
|
|
|
void cFallingBlock::Tick(float a_Dt, MTRand & a_TickRandom)
|
2012-09-30 12:37:44 -04:00
|
|
|
{
|
|
|
|
float MilliDt = a_Dt * 0.001f;
|
2013-03-23 00:33:47 -04:00
|
|
|
AddSpeedY(MilliDt * -9.8f);
|
|
|
|
AddPosY(GetSpeedY() * MilliDt);
|
2012-09-30 12:37:44 -04:00
|
|
|
|
2013-03-02 14:57:09 -05:00
|
|
|
// GetWorld()->BroadcastTeleportEntity(*this); // Test position
|
|
|
|
|
|
|
|
int BlockX = (int)m_OriginalPosition.x;
|
2013-03-22 02:33:10 -04:00
|
|
|
int BlockY = (int)(GetPosY() - 0.5);
|
2013-03-02 14:57:09 -05:00
|
|
|
int BlockZ = (int)m_OriginalPosition.z;
|
|
|
|
|
|
|
|
if (BlockY < 0)
|
|
|
|
{
|
|
|
|
// Fallen out of this world, just continue falling until out of sight, then destroy:
|
|
|
|
if (BlockY < 100)
|
|
|
|
{
|
|
|
|
Destroy();
|
|
|
|
}
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (BlockY < cChunkDef::Height - 1)
|
2012-09-30 12:37:44 -04:00
|
|
|
{
|
2013-03-03 03:40:37 -05:00
|
|
|
BLOCKTYPE BlockBelow;
|
|
|
|
NIBBLETYPE BelowMeta;
|
|
|
|
GetWorld()->GetBlockTypeMeta(BlockX, BlockY, BlockZ, BlockBelow, BelowMeta);
|
|
|
|
if (cSandSimulator::DoesBreakFallingThrough(BlockBelow, BelowMeta))
|
2013-03-02 14:57:09 -05:00
|
|
|
{
|
2013-03-03 03:40:37 -05:00
|
|
|
// Fallen onto a block that breaks this into pickups (e. g. half-slab)
|
|
|
|
// Must finish the fall with coords one below the block:
|
|
|
|
cSandSimulator::FinishFalling(m_World, BlockX, BlockY, BlockZ, m_BlockType, m_BlockMeta);
|
|
|
|
Destroy();
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
else if (!cSandSimulator::CanContinueFallThrough(BlockBelow))
|
|
|
|
{
|
|
|
|
// Fallen onto a solid block
|
2013-03-02 14:57:09 -05:00
|
|
|
cSandSimulator::FinishFalling(m_World, BlockX, BlockY + 1, BlockZ, m_BlockType, m_BlockMeta);
|
|
|
|
Destroy();
|
|
|
|
return;
|
|
|
|
}
|
2012-09-30 12:37:44 -04:00
|
|
|
}
|
2012-12-21 07:21:20 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|