aboutsummaryrefslogtreecommitdiff
path: root/Minecraft.Client/PS3/SPU_Tasks/ChunkUpdate/RailTile_SPU.h
diff options
context:
space:
mode:
authordaoge_cmd <3523206925@qq.com>2026-03-01 12:16:08 +0800
committerdaoge_cmd <3523206925@qq.com>2026-03-01 12:16:08 +0800
commitb691c43c44ff180d10e7d4a9afc83b98551ff586 (patch)
tree3e9849222cbc6ba49f2f1fc6e5fe7179632c7390 /Minecraft.Client/PS3/SPU_Tasks/ChunkUpdate/RailTile_SPU.h
parentdef8cb415354ac390b7e89052a50605285f1aca9 (diff)
Initial commit
Diffstat (limited to 'Minecraft.Client/PS3/SPU_Tasks/ChunkUpdate/RailTile_SPU.h')
-rw-r--r--Minecraft.Client/PS3/SPU_Tasks/ChunkUpdate/RailTile_SPU.h58
1 files changed, 58 insertions, 0 deletions
diff --git a/Minecraft.Client/PS3/SPU_Tasks/ChunkUpdate/RailTile_SPU.h b/Minecraft.Client/PS3/SPU_Tasks/ChunkUpdate/RailTile_SPU.h
new file mode 100644
index 00000000..615ebec9
--- /dev/null
+++ b/Minecraft.Client/PS3/SPU_Tasks/ChunkUpdate/RailTile_SPU.h
@@ -0,0 +1,58 @@
+#pragma once
+#include "Tile_SPU.h"
+
+class RailTile_SPU : public Tile_SPU
+{
+
+public:
+ static const int RAIL_DATA_BIT = 8;
+ static const int RAIL_DIRECTION_MASK = 7;
+
+ RailTile_SPU(int id) : Tile_SPU(id) {}
+ virtual bool isSolidRender(bool isServerLevel = false) { return false; }
+ virtual void updateShape(ChunkRebuildData *level, int x, int y, int z, int forceData = -1, TileEntity* forceEntity = NULL) // 4J added forceData, forceEntity param
+ {
+ int data = level->getData(x, y, z);
+ if (data >= 2 && data <= 5)
+ {
+ setShape(0, 0, 0, 1, 2 / 16.0f + 0.5f, 1);
+ } else
+ {
+ setShape(0, 0, 0, 1, 2 / 16.0f, 1);
+ }
+ }
+ virtual Icon_SPU *getTexture(int face, int data)
+ {
+ bool usesDataBit = false;
+ Icon_SPU* iconTurn = &ms_pTileData->railTile_iconTurn;
+ if(id == goldenRail_Id)
+ {
+ usesDataBit = true;
+ iconTurn = &ms_pTileData->railTile_iconTurnGolden;
+ }
+
+ if (usesDataBit)
+ {
+// if (id == Tile::goldenRail_Id)
+// {
+ if ((data & RAIL_DATA_BIT) == 0)
+ {
+ return icon();
+ }
+ else
+ {
+ return iconTurn; // Actually the powered rail on version
+ }
+// }
+ } else if (data >= 6) return iconTurn;
+ return icon();
+
+ }
+ virtual int getRenderShape() { return Tile_SPU::SHAPE_RAIL; }
+ bool isUsesDataBit()
+ {
+ if(id == goldenRail_Id || id == detectorRail_Id)
+ return true;
+ return false;
+ }
+}; \ No newline at end of file