diff options
| author | daoge_cmd <3523206925@qq.com> | 2026-03-01 12:16:08 +0800 |
|---|---|---|
| committer | daoge_cmd <3523206925@qq.com> | 2026-03-01 12:16:08 +0800 |
| commit | b691c43c44ff180d10e7d4a9afc83b98551ff586 (patch) | |
| tree | 3e9849222cbc6ba49f2f1fc6e5fe7179632c7390 /Minecraft.Client/PS3/SPU_Tasks/ChunkUpdate/RailTile_SPU.h | |
| parent | def8cb415354ac390b7e89052a50605285f1aca9 (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.h | 58 |
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 |
