aboutsummaryrefslogtreecommitdiff
path: root/Minecraft.World/JukeboxTile.h
diff options
context:
space:
mode:
Diffstat (limited to 'Minecraft.World/JukeboxTile.h')
-rw-r--r--Minecraft.World/JukeboxTile.h55
1 files changed, 55 insertions, 0 deletions
diff --git a/Minecraft.World/JukeboxTile.h b/Minecraft.World/JukeboxTile.h
new file mode 100644
index 00000000..dd592872
--- /dev/null
+++ b/Minecraft.World/JukeboxTile.h
@@ -0,0 +1,55 @@
+#pragma once
+
+#include "BaseEntityTile.h"
+#include "CompoundTag.h"
+#include "TileEntity.h"
+
+class CompoundTag;
+class ChunkRebuildData;
+
+class JukeboxTile : public BaseEntityTile
+{
+ friend class Tile;
+ friend class ChunkRebuildData;
+public:
+ class Entity : public TileEntity
+ {
+ public:
+ eINSTANCEOF GetType() { return eTYPE_RECORDPLAYERTILE; }
+ static TileEntity *create() { return new JukeboxTile::Entity(); }
+
+ private:
+ shared_ptr<ItemInstance> record;
+
+ public:
+ Entity();
+
+ virtual void load(CompoundTag *tag);
+ virtual void save(CompoundTag *tag);
+ virtual shared_ptr<ItemInstance> getRecord();
+ virtual void setRecord(shared_ptr<ItemInstance> record);
+
+ // 4J Added
+ shared_ptr<TileEntity> clone();
+ };
+
+private:
+ Icon *iconTop;
+
+protected:
+ JukeboxTile(int id);
+
+public:
+ virtual Icon *getTexture(int face, int data);
+ virtual bool TestUse(Level *level, int x, int y, int z, shared_ptr<Player> player);
+ 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); // 4J added soundOnly param
+ void setRecord(Level *level, int x, int y, int z, shared_ptr<ItemInstance> record);
+ void dropRecording(Level *level, int x, int y, int z);
+ virtual void onRemove(Level *level, int x, int y, int z, int id, int data);
+ virtual void spawnResources(Level *level, int x, int y, int z, int data, float odds, int playerBonus);
+
+ virtual shared_ptr<TileEntity> newTileEntity(Level *level);
+ virtual void registerIcons(IconRegister *iconRegister);
+ virtual bool hasAnalogOutputSignal();
+ virtual int getAnalogOutputSignal(Level *level, int x, int y, int z, int dir);
+};