aboutsummaryrefslogtreecommitdiff
path: root/Minecraft.World/HellFlatLevelSource.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.World/HellFlatLevelSource.h
parentdef8cb415354ac390b7e89052a50605285f1aca9 (diff)
Initial commit
Diffstat (limited to 'Minecraft.World/HellFlatLevelSource.h')
-rw-r--r--Minecraft.World/HellFlatLevelSource.h51
1 files changed, 51 insertions, 0 deletions
diff --git a/Minecraft.World/HellFlatLevelSource.h b/Minecraft.World/HellFlatLevelSource.h
new file mode 100644
index 00000000..b756d9a6
--- /dev/null
+++ b/Minecraft.World/HellFlatLevelSource.h
@@ -0,0 +1,51 @@
+#pragma once
+#include "ChunkSource.h"
+#include "PerlinNoise.h"
+#include "LargeFeature.h"
+#include "LargeHellCaveFeature.h"
+#include "LevelChunk.h"
+#include "HellFireFeature.h"
+#include "LightGemFeature.h"
+#include "HellPortalFeature.h"
+#include "FlowerFeature.h"
+#include "HellSpringFeature.h"
+
+class ProgressListener;
+
+class HellFlatLevelSource : public ChunkSource
+{
+public:
+ static const int CHUNK_HEIGHT = 8;
+ static const int CHUNK_WIDTH = 4;
+
+private:
+ Random *random;
+ Random *pprandom;
+
+private:
+ Level *level;
+
+public:
+ HellFlatLevelSource(Level *level, __int64 seed);
+ ~HellFlatLevelSource();
+
+private:
+ void prepareHeights(int xOffs, int zOffs, byteArray blocks);
+
+public:
+ void buildSurfaces(int xOffs, int zOffs, byteArray blocks);
+
+ LevelChunk *create(int x, int z);
+ LevelChunk *getChunk(int xOffs, int zOffs);
+ virtual void lightChunk(LevelChunk *lc); // 4J added
+
+public:
+ virtual bool hasChunk(int x, int y);
+ void postProcess(ChunkSource *parent, int xt, int zt);
+ bool save(bool force, ProgressListener *progressListener);
+ bool tick();
+ bool shouldSave();
+ wstring gatherStats();
+ virtual vector<Biome::MobSpawnerData *> *getMobsAt(MobCategory *mobCategory, int x, int y, int z);
+ virtual TilePos *findNearestMapFeature(Level *level, const wstring& featureName, int x, int y, int z);
+};