2013-07-29 07:13:03 -04:00
|
|
|
|
|
|
|
#pragma once
|
|
|
|
|
|
|
|
#include "BlockHandler.h"
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
class cBlockCauldronHandler :
|
|
|
|
public cBlockHandler
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
cBlockCauldronHandler(BLOCKTYPE a_BlockType)
|
|
|
|
: cBlockHandler(a_BlockType)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
virtual void ConvertToPickups(cItems & a_Pickups, NIBBLETYPE a_BlockMeta) override
|
|
|
|
{
|
|
|
|
a_Pickups.push_back(cItem(E_ITEM_CAULDRON, 1, 0));
|
|
|
|
}
|
|
|
|
|
2015-12-01 17:12:44 -05:00
|
|
|
virtual bool OnUse(cChunkInterface & a_ChunkInterface, cWorldInterface & a_WorldInterface, cPlayer * a_Player, int a_BlockX, int a_BlockY, int a_BlockZ, eBlockFace a_BlockFace, int a_CursorX, int a_CursorY, int a_CursorZ) override
|
2013-07-29 07:13:03 -04:00
|
|
|
{
|
2014-03-30 17:13:13 -04:00
|
|
|
NIBBLETYPE Meta = a_ChunkInterface.GetBlockMeta(a_BlockX, a_BlockY, a_BlockZ);
|
2014-02-20 14:58:23 -05:00
|
|
|
switch (a_Player->GetEquippedItem().m_ItemType)
|
2013-07-29 07:13:03 -04:00
|
|
|
{
|
|
|
|
case E_ITEM_WATER_BUCKET:
|
|
|
|
{
|
2014-02-20 11:45:18 -05:00
|
|
|
if (Meta < 3)
|
|
|
|
{
|
2014-02-20 14:58:23 -05:00
|
|
|
a_ChunkInterface.SetBlockMeta(a_BlockX, a_BlockY, a_BlockZ, 3);
|
|
|
|
if (!a_Player->IsGameModeCreative())
|
|
|
|
{
|
|
|
|
a_Player->GetInventory().RemoveOneEquippedItem();
|
|
|
|
cItem NewItem(E_ITEM_BUCKET, 1);
|
|
|
|
a_Player->GetInventory().AddItem(NewItem);
|
|
|
|
}
|
2014-02-20 11:45:18 -05:00
|
|
|
}
|
2013-07-29 07:13:03 -04:00
|
|
|
break;
|
|
|
|
}
|
|
|
|
case E_ITEM_GLASS_BOTTLE:
|
|
|
|
{
|
2014-02-20 11:45:18 -05:00
|
|
|
if (Meta > 0)
|
2013-07-29 07:13:03 -04:00
|
|
|
{
|
2014-02-20 14:58:23 -05:00
|
|
|
a_ChunkInterface.SetBlockMeta(a_BlockX, a_BlockY, a_BlockZ, --Meta);
|
2013-07-29 07:13:03 -04:00
|
|
|
a_Player->GetInventory().RemoveOneEquippedItem();
|
|
|
|
cItem NewItem(E_ITEM_POTIONS, 1, 0);
|
|
|
|
a_Player->GetInventory().AddItem(NewItem);
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
2015-12-01 17:12:44 -05:00
|
|
|
return true;
|
2013-07-29 07:13:03 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
virtual bool IsUseable() override
|
|
|
|
{
|
|
|
|
return true;
|
|
|
|
}
|
2014-05-29 11:58:40 -04:00
|
|
|
|
|
|
|
virtual void OnUpdate(cChunkInterface & a_ChunkInterface, cWorldInterface & a_WorldInterface, cBlockPluginInterface & a_PluginInterface, cChunk & a_Chunk, int a_RelX, int a_RelY, int a_RelZ) override
|
|
|
|
{
|
2014-06-14 05:14:04 -04:00
|
|
|
int BlockX = a_RelX + a_Chunk.GetPosX() * cChunkDef::Width;
|
|
|
|
int BlockZ = a_RelZ + a_Chunk.GetPosZ() * cChunkDef::Width;
|
|
|
|
if (!a_WorldInterface.IsWeatherWetAt(BlockX, BlockZ) || (a_RelY != a_WorldInterface.GetHeight(BlockX, BlockZ)))
|
2014-05-29 11:58:40 -04:00
|
|
|
{
|
2014-06-14 05:14:04 -04:00
|
|
|
// It's not raining at our current location or we do not have a direct view of the sky
|
|
|
|
// We cannot eat the rain :(
|
2014-05-29 11:58:40 -04:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
NIBBLETYPE Meta = a_Chunk.GetMeta(a_RelX, a_RelY, a_RelZ);
|
|
|
|
if (Meta < 3)
|
|
|
|
{
|
|
|
|
a_Chunk.SetMeta(a_RelX, a_RelY, a_RelZ, Meta + 1);
|
|
|
|
}
|
|
|
|
}
|
2015-06-30 10:50:15 -04:00
|
|
|
|
|
|
|
virtual ColourID GetMapBaseColourID(NIBBLETYPE a_Meta) override
|
|
|
|
{
|
|
|
|
UNUSED(a_Meta);
|
|
|
|
return 21;
|
|
|
|
}
|
2013-07-29 07:13:03 -04:00
|
|
|
} ;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|