diff options
author | Tiger Wang <ziwei.tiger@hotmail.co.uk> | 2013-09-22 20:34:42 +0200 |
---|---|---|
committer | Tiger Wang <ziwei.tiger@hotmail.co.uk> | 2013-09-22 20:34:42 +0200 |
commit | a8a45a4afc615926a705eee482c27ef166f2f9ec (patch) | |
tree | 24a63888a42312d8641cc7eaa1d28972d25fdebe /source/Blocks/BlockButton.h | |
parent | Removed OnDigging for Redstone devices (diff) | |
download | cuberite-a8a45a4afc615926a705eee482c27ef166f2f9ec.tar cuberite-a8a45a4afc615926a705eee482c27ef166f2f9ec.tar.gz cuberite-a8a45a4afc615926a705eee482c27ef166f2f9ec.tar.bz2 cuberite-a8a45a4afc615926a705eee482c27ef166f2f9ec.tar.lz cuberite-a8a45a4afc615926a705eee482c27ef166f2f9ec.tar.xz cuberite-a8a45a4afc615926a705eee482c27ef166f2f9ec.tar.zst cuberite-a8a45a4afc615926a705eee482c27ef166f2f9ec.zip |
Diffstat (limited to 'source/Blocks/BlockButton.h')
-rw-r--r-- | source/Blocks/BlockButton.h | 69 |
1 files changed, 69 insertions, 0 deletions
diff --git a/source/Blocks/BlockButton.h b/source/Blocks/BlockButton.h new file mode 100644 index 000000000..e3f655bfa --- /dev/null +++ b/source/Blocks/BlockButton.h @@ -0,0 +1,69 @@ +#pragma once + +#include "BlockHandler.h" + + + + + +class cBlockButtonHandler : + public cBlockHandler +{ +public: + cBlockButtonHandler(BLOCKTYPE a_BlockType); + + virtual void OnUse(cWorld * a_World, cPlayer * a_Player, int a_BlockX, int a_BlockY, int a_BlockZ, char a_BlockFace, int a_CursorX, int a_CursorY, int a_CursorZ) override; + + + virtual void ConvertToPickups(cItems & a_Pickups, NIBBLETYPE a_BlockMeta) override + { + // Reset meta to 0 + a_Pickups.push_back(cItem(m_BlockType == E_BLOCK_WOODEN_BUTTON ? E_BLOCK_WOODEN_BUTTON : E_BLOCK_STONE_BUTTON, 1, 0)); + } + + + virtual bool IsUseable(void) override + { + return true; + } + + + virtual bool GetPlacementBlockTypeMeta( + cWorld * a_World, cPlayer * a_Player, + int a_BlockX, int a_BlockY, int a_BlockZ, char a_BlockFace, + int a_CursorX, int a_CursorY, int a_CursorZ, + BLOCKTYPE & a_BlockType, NIBBLETYPE & a_BlockMeta + ) override + { + a_BlockType = m_BlockType; + a_BlockMeta = BlockFaceToMetaData(a_BlockFace); + return true; + } + + + virtual const char * GetStepSound(void) override + { + return m_BlockType == E_BLOCK_WOODEN_BUTTON ? "step.wood" : "step.stone"; + } + + + inline static NIBBLETYPE BlockFaceToMetaData(char a_BlockFace) + { + switch (a_BlockFace) + { + case BLOCK_FACE_ZP: { return 0x4; } + case BLOCK_FACE_ZM: { return 0x3; } + case BLOCK_FACE_XP: { return 0x2; } + case BLOCK_FACE_XM: { return 0x1; } + default: + { + ASSERT(!"Unhandled block face!"); + return 0x0; // No idea, give a special meta (button in centre of block) + } + } + } +} ; + + + + |