2013-07-29 07:13:03 -04:00
|
|
|
|
|
|
|
#pragma once
|
|
|
|
|
2015-08-19 12:45:53 -04:00
|
|
|
#include "BlockPlant.h"
|
2013-07-29 07:13:03 -04:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
class cBlockSugarcaneHandler :
|
2015-08-19 12:45:53 -04:00
|
|
|
public cBlockPlant
|
2013-07-29 07:13:03 -04:00
|
|
|
{
|
2015-08-19 12:45:53 -04:00
|
|
|
typedef cBlockPlant Super;
|
2013-07-29 07:13:03 -04:00
|
|
|
public:
|
|
|
|
cBlockSugarcaneHandler(BLOCKTYPE a_BlockType)
|
2015-08-19 12:45:53 -04:00
|
|
|
: Super(a_BlockType, false)
|
2013-07-29 07:13:03 -04:00
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
virtual void ConvertToPickups(cItems & a_Pickups, NIBBLETYPE a_BlockMeta) override
|
|
|
|
{
|
|
|
|
a_Pickups.push_back(cItem(E_ITEM_SUGARCANE, 1, 0));
|
|
|
|
}
|
|
|
|
|
2014-02-01 08:06:32 -05:00
|
|
|
virtual bool CanBeAt(cChunkInterface & a_ChunkInterface, int a_RelX, int a_RelY, int a_RelZ, const cChunk & a_Chunk) override
|
2013-07-29 07:13:03 -04:00
|
|
|
{
|
|
|
|
if (a_RelY <= 0)
|
|
|
|
{
|
|
|
|
return false;
|
|
|
|
}
|
2014-08-19 16:14:37 -04:00
|
|
|
|
2013-07-29 07:13:03 -04:00
|
|
|
switch (a_Chunk.GetBlock(a_RelX, a_RelY - 1, a_RelZ))
|
|
|
|
{
|
|
|
|
case E_BLOCK_DIRT:
|
|
|
|
case E_BLOCK_GRASS:
|
|
|
|
case E_BLOCK_FARMLAND:
|
|
|
|
case E_BLOCK_SAND:
|
|
|
|
{
|
|
|
|
static const struct
|
|
|
|
{
|
|
|
|
int x, z;
|
|
|
|
} Coords[] =
|
|
|
|
{
|
|
|
|
{-1, 0},
|
|
|
|
{ 1, 0},
|
|
|
|
{ 0, -1},
|
|
|
|
{ 0, 1},
|
|
|
|
} ;
|
|
|
|
a_RelY -= 1;
|
2013-12-20 10:01:34 -05:00
|
|
|
for (size_t i = 0; i < ARRAYCOUNT(Coords); i++)
|
2013-07-29 07:13:03 -04:00
|
|
|
{
|
|
|
|
BLOCKTYPE BlockType;
|
|
|
|
NIBBLETYPE BlockMeta;
|
|
|
|
if (!a_Chunk.UnboundedRelGetBlock(a_RelX + Coords[i].x, a_RelY, a_RelZ + Coords[i].z, BlockType, BlockMeta))
|
|
|
|
{
|
|
|
|
// Too close to the edge, cannot simulate
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
if (IsBlockWater(BlockType))
|
|
|
|
{
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
} // for i - Coords[]
|
|
|
|
// Not directly neighboring a water block
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
case E_BLOCK_SUGARCANE:
|
|
|
|
{
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return false;
|
|
|
|
}
|
2016-02-05 16:45:45 -05:00
|
|
|
|
2014-02-02 09:49:37 -05:00
|
|
|
virtual void OnUpdate(cChunkInterface & cChunkInterface, cWorldInterface & a_WorldInterface, cBlockPluginInterface & a_PluginInterface, cChunk & a_Chunk, int a_RelX, int a_RelY, int a_RelZ) override
|
2013-07-29 07:13:03 -04:00
|
|
|
{
|
2015-08-19 12:45:53 -04:00
|
|
|
if (CanGrow(a_Chunk, a_RelX, a_RelY, a_RelZ) == paGrowth)
|
|
|
|
{
|
|
|
|
a_Chunk.GetWorld()->GrowSugarcane(a_RelX + a_Chunk.GetPosX() * cChunkDef::Width, a_RelY, a_RelZ + a_Chunk.GetPosZ() * cChunkDef::Width, 1);
|
|
|
|
}
|
2013-07-29 07:13:03 -04:00
|
|
|
}
|
2015-06-30 10:50:15 -04:00
|
|
|
|
|
|
|
virtual ColourID GetMapBaseColourID(NIBBLETYPE a_Meta) override
|
|
|
|
{
|
|
|
|
UNUSED(a_Meta);
|
|
|
|
return 7;
|
|
|
|
}
|
2015-08-19 12:45:53 -04:00
|
|
|
|
|
|
|
protected:
|
|
|
|
|
|
|
|
virtual PlantAction CanGrow(cChunk & a_Chunk, int a_RelX, int a_RelY, int a_RelZ) override
|
|
|
|
{
|
|
|
|
auto Action = paStay;
|
|
|
|
if (((a_RelY + 1) < cChunkDef::Height) && (a_Chunk.GetBlock(a_RelX, a_RelY + 1, a_RelZ) == E_BLOCK_AIR))
|
|
|
|
{
|
|
|
|
Action = Super::CanGrow(a_Chunk, a_RelX, a_RelY, a_RelZ);
|
|
|
|
}
|
|
|
|
|
|
|
|
return Action;
|
|
|
|
}
|
2013-07-29 07:13:03 -04:00
|
|
|
} ;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|