aboutsummaryrefslogtreecommitdiff
path: root/Minecraft.World/BiomeOverrideLayer.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/BiomeOverrideLayer.cpp
parentdef8cb415354ac390b7e89052a50605285f1aca9 (diff)
Initial commit
Diffstat (limited to 'Minecraft.World/BiomeOverrideLayer.cpp')
-rw-r--r--Minecraft.World/BiomeOverrideLayer.cpp81
1 files changed, 81 insertions, 0 deletions
diff --git a/Minecraft.World/BiomeOverrideLayer.cpp b/Minecraft.World/BiomeOverrideLayer.cpp
new file mode 100644
index 00000000..a44295dc
--- /dev/null
+++ b/Minecraft.World/BiomeOverrideLayer.cpp
@@ -0,0 +1,81 @@
+#include "stdafx.h"
+#include "net.minecraft.world.level.biome.h"
+#include "net.minecraft.world.level.newbiome.layer.h"
+#include "net.minecraft.world.level.h"
+#include "BiomeOverrideLayer.h"
+
+
+BiomeOverrideLayer::BiomeOverrideLayer(int seedMixup) : Layer(seedMixup)
+{
+ m_biomeOverride = byteArray( width * height );
+
+#ifdef _UNICODE
+ wstring path = L"GAME:\\GameRules\\biomemap.bin";
+ HANDLE file = CreateFile(path.c_str(), GENERIC_READ, 0, NULL, OPEN_EXISTING, FILE_ATTRIBUTE_NORMAL, NULL);
+#else
+#ifdef _WINDOWS64
+ string path = "GameRules\\biomemap.bin";
+#else
+ string path = "GAME:\\GameRules\\biomemap.bin";
+#endif
+ HANDLE file = CreateFile(path.c_str(), GENERIC_READ, 0, NULL, OPEN_EXISTING, FILE_ATTRIBUTE_NORMAL, NULL);
+#endif
+ if( file == INVALID_HANDLE_VALUE )
+ {
+ DWORD error = GetLastError();
+ //assert(false);
+ app.DebugPrintf("Biome override not found, using plains as default\n");
+
+ memset(m_biomeOverride.data,Biome::plains->id,m_biomeOverride.length);
+ }
+ else
+ {
+
+#ifdef _DURANGO
+ __debugbreak(); // TODO
+ DWORD bytesRead,dwFileSize = 0;
+#else
+ DWORD bytesRead,dwFileSize = GetFileSize(file,NULL);
+#endif
+ if(dwFileSize > m_biomeOverride.length)
+ {
+ app.DebugPrintf("Biomemap binary is too large!!\n");
+ __debugbreak();
+ }
+ BOOL bSuccess = ReadFile(file,m_biomeOverride.data,dwFileSize,&bytesRead,NULL);
+
+ if(bSuccess==FALSE)
+ {
+ app.FatalLoadError();
+ }
+
+ CloseHandle(file);
+ }
+}
+
+intArray BiomeOverrideLayer::getArea(int xo, int yo, int w, int h)
+{
+ intArray result = IntCache::allocate(w * h);
+
+ int xOrigin = xo + width/2;
+ int yOrigin = yo + height/2;
+ if(xOrigin < 0 ) xOrigin = 0;
+ if(xOrigin >= width) xOrigin = width - 1;
+ if(yOrigin < 0 ) yOrigin = 0;
+ if(yOrigin >= height) yOrigin = height - 1;
+ for (int y = 0; y < h; y++)
+ {
+ for (int x = 0; x < w; x++)
+ {
+ int curX = xOrigin + x;
+ int curY = yOrigin + y;
+ if(curX >= width) curX = width - 1;
+ if(curY >= height) curY = height - 1;
+ int index = curX + curY * width;
+
+ unsigned char headerValue = m_biomeOverride[index];
+ result[x + y * w] = headerValue;
+ }
+ }
+ return result;
+} \ No newline at end of file