2013-07-29 07:13:03 -04:00
|
|
|
|
|
|
|
#pragma once
|
|
|
|
|
|
|
|
#include "BlockHandler.h"
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
class cBlockDeadBushHandler :
|
|
|
|
public cBlockHandler
|
|
|
|
{
|
2017-02-26 05:09:06 -05:00
|
|
|
typedef cBlockHandler super;
|
2013-07-29 07:13:03 -04:00
|
|
|
public:
|
|
|
|
cBlockDeadBushHandler(BLOCKTYPE a_BlockType)
|
|
|
|
: cBlockHandler(a_BlockType)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
2017-07-07 10:37:53 -04:00
|
|
|
virtual bool DoesIgnoreBuildCollision(cChunkInterface & a_ChunkInterface, Vector3i a_Pos, cPlayer & a_Player, NIBBLETYPE a_Meta) override
|
2017-03-22 06:04:32 -04:00
|
|
|
{
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
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
|
|
|
{
|
2014-10-07 12:21:39 -04:00
|
|
|
if (a_RelY <= 0)
|
|
|
|
{
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
BLOCKTYPE BelowBlock = a_Chunk.GetBlock(a_RelX, a_RelY - 1, a_RelZ);
|
|
|
|
switch (BelowBlock)
|
|
|
|
{
|
|
|
|
case E_BLOCK_CLAY:
|
|
|
|
case E_BLOCK_HARDENED_CLAY:
|
|
|
|
case E_BLOCK_STAINED_CLAY:
|
|
|
|
case E_BLOCK_SAND:
|
|
|
|
{
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
default: return false;
|
|
|
|
}
|
2013-07-29 07:13:03 -04:00
|
|
|
}
|
2015-06-30 10:50:15 -04:00
|
|
|
|
2017-02-26 05:09:06 -05:00
|
|
|
virtual void ConvertToPickups(cItems & a_Pickups, NIBBLETYPE a_BlockMeta) override
|
|
|
|
{
|
|
|
|
// Drop 0-3 sticks
|
2017-06-13 15:35:30 -04:00
|
|
|
char chance = GetRandomProvider().RandInt<char>(3);
|
2017-02-26 05:09:06 -05:00
|
|
|
if (chance != 0)
|
|
|
|
{
|
2017-06-13 15:35:30 -04:00
|
|
|
a_Pickups.emplace_back(E_ITEM_STICK, chance, 0);
|
2017-02-26 05:09:06 -05:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2015-06-30 10:50:15 -04:00
|
|
|
virtual ColourID GetMapBaseColourID(NIBBLETYPE a_Meta) override
|
|
|
|
{
|
|
|
|
UNUSED(a_Meta);
|
|
|
|
return 0;
|
|
|
|
}
|
2017-02-26 05:09:06 -05:00
|
|
|
|
|
|
|
virtual void DropBlock(cChunkInterface & a_ChunkInterface, cWorldInterface & a_WorldInterface, cBlockPluginInterface & a_BlockPluginInterface, cEntity * a_Digger, int a_BlockX, int a_BlockY, int a_BlockZ, bool a_CanDrop) override
|
|
|
|
{
|
|
|
|
if (a_CanDrop && (a_Digger != nullptr) && (a_Digger->GetEquippedWeapon().m_ItemType == E_ITEM_SHEARS))
|
|
|
|
{
|
2017-11-20 06:13:11 -05:00
|
|
|
NIBBLETYPE Meta = a_ChunkInterface.GetBlockMeta({a_BlockX, a_BlockY, a_BlockZ});
|
2017-02-26 05:09:06 -05:00
|
|
|
cItems Drops;
|
|
|
|
Drops.Add(m_BlockType, 1, Meta);
|
|
|
|
|
|
|
|
// Allow plugins to modify the pickups:
|
|
|
|
a_BlockPluginInterface.CallHookBlockToPickups(a_Digger, a_BlockX, a_BlockY, a_BlockZ, m_BlockType, Meta, Drops);
|
|
|
|
|
|
|
|
// Spawn the pickups:
|
|
|
|
if (!Drops.empty())
|
|
|
|
{
|
2017-06-13 15:35:30 -04:00
|
|
|
auto & r1 = GetRandomProvider();
|
2017-02-26 05:09:06 -05:00
|
|
|
|
|
|
|
// Mid-block position first
|
|
|
|
double MicroX, MicroY, MicroZ;
|
|
|
|
MicroX = a_BlockX + 0.5;
|
|
|
|
MicroY = a_BlockY + 0.5;
|
|
|
|
MicroZ = a_BlockZ + 0.5;
|
|
|
|
|
|
|
|
// Add random offset second
|
2017-06-13 15:35:30 -04:00
|
|
|
MicroX += r1.RandReal<double>(-0.5, 0.5);
|
|
|
|
MicroZ += r1.RandReal<double>(-0.5, 0.5);
|
2017-02-26 05:09:06 -05:00
|
|
|
|
|
|
|
a_WorldInterface.SpawnItemPickups(Drops, MicroX, MicroY, MicroZ);
|
|
|
|
}
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
super::DropBlock(a_ChunkInterface, a_WorldInterface, a_BlockPluginInterface, a_Digger, a_BlockX, a_BlockY, a_BlockZ, a_CanDrop);
|
|
|
|
}
|
2013-07-29 07:13:03 -04:00
|
|
|
} ;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|