diff options
author | luksor111@gmail.com <luksor111@gmail.com@0a769ca7-a7f5-676a-18bf-c427514a06d6> | 2012-12-19 10:29:53 +0100 |
---|---|---|
committer | luksor111@gmail.com <luksor111@gmail.com@0a769ca7-a7f5-676a-18bf-c427514a06d6> | 2012-12-19 10:29:53 +0100 |
commit | a10c4774f541028817c2a08dc6860fef252d0200 (patch) | |
tree | 4db3805965552fccc43d14febb9e83148a0a3f5b /source/Blocks/BlockFenceGate.h | |
parent | Fixed time calculation in cWorld::Tick() (diff) | |
download | cuberite-a10c4774f541028817c2a08dc6860fef252d0200.tar cuberite-a10c4774f541028817c2a08dc6860fef252d0200.tar.gz cuberite-a10c4774f541028817c2a08dc6860fef252d0200.tar.bz2 cuberite-a10c4774f541028817c2a08dc6860fef252d0200.tar.lz cuberite-a10c4774f541028817c2a08dc6860fef252d0200.tar.xz cuberite-a10c4774f541028817c2a08dc6860fef252d0200.tar.zst cuberite-a10c4774f541028817c2a08dc6860fef252d0200.zip |
Diffstat (limited to '')
-rw-r--r-- | source/Blocks/BlockFenceGate.h | 56 |
1 files changed, 56 insertions, 0 deletions
diff --git a/source/Blocks/BlockFenceGate.h b/source/Blocks/BlockFenceGate.h new file mode 100644 index 000000000..072eb9c3a --- /dev/null +++ b/source/Blocks/BlockFenceGate.h @@ -0,0 +1,56 @@ +
+#pragma once
+
+#include "BlockHandler.h"
+#include "../Doors.h"
+
+
+
+
+
+class cBlockFenceGateHandler :
+ public cBlockHandler
+{
+public:
+ cBlockFenceGateHandler(BLOCKTYPE a_BlockType)
+ : cBlockHandler(a_BlockType)
+ {
+ }
+
+ void OnPlaced(cWorld * a_World, int a_BlockX, int a_BlockY, int a_BlockZ, int a_Dir)
+ {
+
+ }
+
+ void PlaceBlock(cWorld * a_World, cPlayer * a_Player, NIBBLETYPE a_BlockMeta, int a_BlockX, int a_BlockY, int a_BlockZ, char a_Dir)
+ {
+ a_BlockMeta = cDoors::RotationToMetaData(a_Player->GetRotation() + 270);
+ a_World->SetBlock(a_BlockX, a_BlockY, a_BlockZ, m_BlockType, a_BlockMeta);
+ OnPlacedByPlayer(a_World, a_Player, a_BlockX, a_BlockY, a_BlockZ, a_Dir);
+ }
+
+ void OnUse(cWorld * a_World, cPlayer * a_Player, int a_BlockX, int a_BlockY, int a_BlockZ)
+ {
+ char OldMetaData = a_World->GetBlockMeta(a_BlockX, a_BlockY, a_BlockZ);
+ char NewMetaData = cDoors::RotationToMetaData(a_Player->GetRotation() + 270);
+ OldMetaData ^= 4; //Toggle the gate
+ if((OldMetaData & 1) == (NewMetaData & 1)){
+ //Standing in front of the gate - apply new direction
+ a_World->SetBlockMeta(a_BlockX, a_BlockY, a_BlockZ, (OldMetaData & 4) | (NewMetaData & 3));
+ }
+ else
+ {
+ //Standing aside - use last direction
+ a_World->SetBlockMeta(a_BlockX, a_BlockY, a_BlockZ, OldMetaData);
+ }
+ }
+
+ virtual bool IsUseable() override
+ {
+ return true;
+ }
+} ;
+
+
+
+
|