aboutsummaryrefslogtreecommitdiff
path: root/Minecraft.World/NetherWartTile.cpp
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/NetherWartTile.cpp
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/NetherWartTile.cpp')
-rw-r--r--Minecraft.World/NetherWartTile.cpp112
1 files changed, 112 insertions, 0 deletions
diff --git a/Minecraft.World/NetherWartTile.cpp b/Minecraft.World/NetherWartTile.cpp
new file mode 100644
index 00000000..1faa57ca
--- /dev/null
+++ b/Minecraft.World/NetherWartTile.cpp
@@ -0,0 +1,112 @@
+#include "stdafx.h"
+#include "NetherWartTile.h"
+#include "net.minecraft.world.level.h"
+#include "net.minecraft.world.level.biome.h"
+#include "net.minecraft.world.item.h"
+#include "net.minecraft.world.h"
+
+NetherWartTile::NetherWartTile(int id) : Bush(id)
+{
+ setTicking(true);
+ updateDefaultShape();
+}
+
+// 4J Added override
+void NetherWartTile::updateDefaultShape()
+{
+ float ss = 0.5f;
+ setShape(0.5f - ss, 0, 0.5f - ss, 0.5f + ss, 0.25f, 0.5f + ss);
+}
+
+bool NetherWartTile::mayPlaceOn(int tile)
+{
+ return tile == Tile::soulsand_Id;
+}
+
+// Brought forward to fix #60073 - TU7: Content: Gameplay: Nether Warts cannot be placed next to each other in the Nether
+bool NetherWartTile::canSurvive(Level *level, int x, int y, int z)
+{
+ return mayPlaceOn(level->getTile(x, y - 1, z));
+}
+
+void NetherWartTile::tick(Level *level, int x, int y, int z, Random *random)
+{
+ int age = level->getData(x, y, z);
+ if (age < MAX_AGE)
+ {
+ if (random->nextInt(10) == 0)
+ {
+ age++;
+ level->setData(x, y, z, age, Tile::UPDATE_CLIENTS);
+ }
+ }
+
+ Bush::tick(level, x, y, z, random);
+}
+
+void NetherWartTile::growCropsToMax(Level *level, int x, int y, int z)
+{
+ level->setData(x, y, z, MAX_AGE, Tile::UPDATE_CLIENTS);
+}
+
+Icon *NetherWartTile::getTexture(int face, int data)
+{
+ if (data >= MAX_AGE)
+ {
+ return icons[2];
+ }
+ if (data > 0)
+ {
+ return icons[1];
+ }
+ return icons[0];
+}
+
+int NetherWartTile::getRenderShape()
+{
+ return Tile::SHAPE_ROWS;
+}
+
+void NetherWartTile::spawnResources(Level *level, int x, int y, int z, int data, float odds, int playerBonus)
+{
+ if (level->isClientSide)
+ {
+ return;
+ }
+ int count = 1;
+ if (data >= MAX_AGE)
+ {
+ count = 2 + level->random->nextInt(3);
+ if (playerBonus > 0)
+ {
+ count += level->random->nextInt(playerBonus + 1);
+ }
+ }
+ for (int i = 0; i < count; i++)
+ {
+ popResource(level, x, y, z, shared_ptr<ItemInstance>(new ItemInstance(Item::netherwart_seeds)));
+ }
+}
+
+int NetherWartTile::getResource(int data, Random *random, int playerBonusLevel)
+{
+ return 0;
+}
+
+int NetherWartTile::getResourceCount(Random *random)
+{
+ return 0;
+}
+
+int NetherWartTile::cloneTileId(Level *level, int x, int y, int z)
+{
+ return Item::netherwart_seeds_Id;
+}
+
+void NetherWartTile::registerIcons(IconRegister *iconRegister)
+{
+ for (int i = 0; i < NETHER_STALK_TEXTURE_COUNT; i++)
+ {
+ icons[i] = iconRegister->registerIcon(getIconName() + L"_stage_" + _toString<int>(i) );
+ }
+}