aboutsummaryrefslogtreecommitdiff
path: root/Minecraft.World/ComparatorTile.h
diff options
context:
space:
mode:
authordaoge <3523206925@qq.com>2026-03-03 03:04:10 +0800
committerGitHub <noreply@github.com>2026-03-03 03:04:10 +0800
commitb3feddfef372618c8a9d7a0abcaf18cfad866c18 (patch)
tree267761c3bb39241ba5c347bfbe2254d06686e287 /Minecraft.World/ComparatorTile.h
parent84c31a2331f7a0ec85b9d438992e244f60e5020f (diff)
feat: TU19 (Dec 2014) Features & Content (#155)
* try to resolve merge conflict * feat: TU19 (Dec 2014) Features & Content (#32) * December 2014 files * Working release build * Fix compilation issues * Add sound to Windows64Media * Add DLC content and force Tutorial DLC * Revert "Add DLC content and force Tutorial DLC" This reverts commit 97a43994725008e35fceb984d5549df9c8cea470. * Disable broken light packing * Disable breakpoint during DLC texture map load Allows DLC loading but the DLC textures are still broken * Fix post build not working * ... * fix vs2022 build * fix cmake build --------- Co-authored-by: Loki <lokirautio@gmail.com>
Diffstat (limited to 'Minecraft.World/ComparatorTile.h')
-rw-r--r--Minecraft.World/ComparatorTile.h60
1 files changed, 60 insertions, 0 deletions
diff --git a/Minecraft.World/ComparatorTile.h b/Minecraft.World/ComparatorTile.h
new file mode 100644
index 00000000..3358d3ab
--- /dev/null
+++ b/Minecraft.World/ComparatorTile.h
@@ -0,0 +1,60 @@
+#pragma once
+
+#include "DiodeTile.h"
+#include "EntityTile.h"
+
+class ComparatorTileEntity;
+
+class ComparatorTile : public DiodeTile, public EntityTile
+{
+private:
+ static const int BIT_OUTPUT_SUBTRACT = 0x4;
+ static const int BIT_IS_LIT = 0x8;
+
+public:
+ ComparatorTile(int id, bool on);
+
+ virtual int getResource(int data, Random *random, int playerBonusLevel);
+ virtual int cloneTileId(Level *level, int x, int y, int z);
+
+protected:
+ virtual int getTurnOnDelay(int data);
+ virtual DiodeTile *getOnTile();
+ virtual DiodeTile *getOffTile();
+
+public:
+ virtual int getRenderShape();
+ virtual Icon *getTexture(int face, int data);
+
+protected:
+ virtual bool isOn(int data);
+ virtual int getOutputSignal(LevelSource *levelSource, int x, int y, int z, int data);
+
+private:
+ virtual int calculateOutputSignal(Level *level, int x, int y, int z, int data);
+
+public:
+ virtual bool isReversedOutputSignal(int data);
+
+protected:
+ virtual bool shouldTurnOn(Level *level, int x, int y, int z, int data);
+ virtual int getInputSignal(Level *level, int x, int y, int z, int data);
+ virtual shared_ptr<ComparatorTileEntity> getComparator(LevelSource *level, int x, int y, int z);
+
+public:
+ virtual bool use(Level *level, int x, int y, int z, shared_ptr<Player> player, int clickedFace, float clickX, float clickY, float clickZ, bool soundOnly = false);
+
+protected:
+ virtual void checkTickOnNeighbor(Level *level, int x, int y, int z, int type);
+
+private:
+ virtual void refreshOutputState(Level *level, int x, int y, int z, Random *random);
+
+public:
+ virtual void tick(Level *level, int x, int y, int z, Random *random);
+ virtual void onPlace(Level *level, int x, int y, int z);
+ virtual void onRemove(Level *level, int x, int y, int z, int id, int data);
+ virtual bool triggerEvent(Level *level, int x, int y, int z, int b0, int b1);
+ virtual shared_ptr<TileEntity> newTileEntity(Level *level);
+ virtual bool TestUse();
+}; \ No newline at end of file