aboutsummaryrefslogtreecommitdiff
path: root/Minecraft.World/TheEndPortal.cpp
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.World/TheEndPortal.cpp
parentdef8cb415354ac390b7e89052a50605285f1aca9 (diff)
Initial commit
Diffstat (limited to 'Minecraft.World/TheEndPortal.cpp')
-rw-r--r--Minecraft.World/TheEndPortal.cpp126
1 files changed, 126 insertions, 0 deletions
diff --git a/Minecraft.World/TheEndPortal.cpp b/Minecraft.World/TheEndPortal.cpp
new file mode 100644
index 00000000..19d95b1f
--- /dev/null
+++ b/Minecraft.World/TheEndPortal.cpp
@@ -0,0 +1,126 @@
+#include "stdafx.h"
+#include "TheEndPortal.h"
+#include "TheEndPortalTileEntity.h"
+#include "net.minecraft.world.level.h"
+#include "net.minecraft.world.level.dimension.h"
+#include "net.minecraft.world.level.storage.h"
+#include "net.minecraft.world.entity.h"
+#include "net.minecraft.world.entity.player.h"
+#include "net.minecraft.world.h"
+
+DWORD TheEndPortal::tlsIdx = TlsAlloc();
+
+// 4J - allowAnywhere is a static in java, implementing as TLS here to make thread safe
+bool TheEndPortal::allowAnywhere()
+{
+ return (TlsGetValue(tlsIdx) != NULL);
+}
+
+void TheEndPortal::allowAnywhere(bool set)
+{
+ TlsSetValue(tlsIdx,(LPVOID)(set?1:0));
+}
+
+TheEndPortal::TheEndPortal(int id, Material *material) : EntityTile(id, material, isSolidRender())
+{
+ this->setLightEmission(1.0f);
+}
+
+shared_ptr<TileEntity> TheEndPortal::newTileEntity(Level *level)
+{
+ return shared_ptr<TileEntity>(new TheEndPortalTileEntity());
+}
+
+void TheEndPortal::updateShape(LevelSource *level, int x, int y, int z, int forceData, shared_ptr<TileEntity> forceEntity) // 4J added forceData, forceEntity param
+{
+ float r = 1 / 16.0f;
+ this->setShape(0, 0, 0, 1, r, 1);
+}
+
+bool TheEndPortal::shouldRenderFace(LevelSource *level, int x, int y, int z, int face)
+{
+ if (face != 0) return false;
+ return EntityTile::shouldRenderFace(level, x, y, z, face);
+}
+
+void TheEndPortal::addAABBs(Level *level, int x, int y, int z, AABB *box, AABBList *boxes, shared_ptr<Entity> source)
+{
+}
+
+bool TheEndPortal::isSolidRender(bool isServerLevel)
+{
+ return false;
+}
+
+bool TheEndPortal::isCubeShaped()
+{
+ return false;
+}
+
+int TheEndPortal::getResourceCount(Random *random)
+{
+ return 0;
+}
+
+void TheEndPortal::entityInside(Level *level, int x, int y, int z, shared_ptr<Entity> entity)
+{
+ if (entity->riding == NULL && entity->rider.lock() == NULL)
+ {
+ if (dynamic_pointer_cast<Player>(entity) != NULL)
+ {
+ if (!level->isClientSide)
+ {
+ // 4J Stu - Update the level data position so that the stronghold portal can be shown on the maps
+ int x,z;
+ x = z = 0;
+ if(level->dimension == 0 && !level->getLevelData()->getHasStrongholdEndPortal() && app.GetTerrainFeaturePosition( eTerrainFeature_StrongholdEndPortal, &x, &z) )
+ {
+ level->getLevelData()->setXStrongholdEndPortal(x);
+ level->getLevelData()->setZStrongholdEndPortal(z);
+ level->getLevelData()->setHasStrongholdEndPortal();
+ }
+
+ (dynamic_pointer_cast<Player>(entity))->changeDimension(1);
+ }
+ }
+ }
+}
+
+void TheEndPortal::animateTick(Level *level, int xt, int yt, int zt, Random *random)
+{
+ double x = xt + random->nextFloat();
+ double y = yt + 0.8f;
+ double z = zt + random->nextFloat();
+ double xa = 0;
+ double ya = 0;
+ double za = 0;
+
+ level->addParticle(eParticleType_endportal, x, y, z, xa, ya, za);
+}
+
+int TheEndPortal::getRenderShape()
+{
+ return SHAPE_INVISIBLE;
+}
+
+void TheEndPortal::onPlace(Level *level, int x, int y, int z)
+{
+ if (allowAnywhere()) return;
+
+ if (level->dimension->id != 0)
+ {
+ level->setTile(x, y, z, 0);
+ return;
+ }
+}
+
+int TheEndPortal::cloneTileId(Level *level, int x, int y, int z)
+{
+ return 0;
+}
+
+void TheEndPortal::registerIcons(IconRegister *iconRegister)
+{
+ // don't register null, because of particles
+ icon = iconRegister->registerIcon(L"portal");
+}