2022-03-15 19:38:36 +01:00
|
|
|
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
|
|
|
From: Jason Penilla <11360596+jpenilla@users.noreply.github.com>
|
|
|
|
Date: Mon, 14 Mar 2022 22:45:32 -0700
|
|
|
|
Subject: [PATCH] Add getComputedBiome API
|
|
|
|
|
|
|
|
|
|
|
|
diff --git a/src/main/java/org/bukkit/RegionAccessor.java b/src/main/java/org/bukkit/RegionAccessor.java
|
2023-06-07 18:24:39 +02:00
|
|
|
index cd83348de3f82b3fddcf2d4bb9187ec8173b0e40..8f50eb9b902236f5e039f5d26f3ca9a044b01a75 100644
|
2022-03-15 19:38:36 +01:00
|
|
|
--- a/src/main/java/org/bukkit/RegionAccessor.java
|
|
|
|
+++ b/src/main/java/org/bukkit/RegionAccessor.java
|
2022-06-05 22:51:44 +02:00
|
|
|
@@ -26,6 +26,7 @@ public interface RegionAccessor extends Keyed { // Paper
|
2022-03-15 19:38:36 +01:00
|
|
|
*
|
|
|
|
* @param location the location of the biome
|
|
|
|
* @return Biome at the given location
|
|
|
|
+ * @see #getComputedBiome(int, int, int)
|
|
|
|
*/
|
|
|
|
@NotNull
|
|
|
|
Biome getBiome(@NotNull Location location);
|
2022-06-05 22:51:44 +02:00
|
|
|
@@ -37,10 +38,33 @@ public interface RegionAccessor extends Keyed { // Paper
|
2022-03-15 19:38:36 +01:00
|
|
|
* @param y Y-coordinate of the block
|
|
|
|
* @param z Z-coordinate of the block
|
|
|
|
* @return Biome at the given coordinates
|
|
|
|
+ * @see #getComputedBiome(int, int, int)
|
|
|
|
*/
|
|
|
|
@NotNull
|
|
|
|
Biome getBiome(int x, int y, int z);
|
|
|
|
|
|
|
|
+ // Paper start
|
|
|
|
+ /**
|
|
|
|
+ * Gets the computed {@link Biome} at the given coordinates.
|
|
|
|
+ *
|
|
|
|
+ * <p>The computed Biome is the Biome as seen by clients for rendering
|
|
|
|
+ * purposes and in the "F3" debug menu. This is computed by looking at the noise biome
|
|
|
|
+ * at this and surrounding quarts and applying complex math operations.</p>
|
|
|
|
+ *
|
|
|
|
+ * <p>Most other Biome-related methods named getBiome, setBiome, and similar
|
|
|
|
+ * operate on the "noise biome", which is stored per-quart, or in other words,
|
|
|
|
+ * 1 Biome per 4x4x4 block region. This is how Biomes are currently generated and
|
|
|
|
+ * stored on disk.</p>
|
|
|
|
+ *
|
|
|
|
+ * @param x X-coordinate of the block
|
|
|
|
+ * @param y Y-coordinate of the block
|
|
|
|
+ * @param z Z-coordinate of the block
|
|
|
|
+ * @return Biome at the given coordinates
|
|
|
|
+ */
|
|
|
|
+ @NotNull
|
|
|
|
+ Biome getComputedBiome(int x, int y, int z);
|
|
|
|
+ // Paper end
|
|
|
|
+
|
|
|
|
/**
|
|
|
|
* Sets the {@link Biome} at the given {@link Location}.
|
|
|
|
*
|
|
|
|
diff --git a/src/main/java/org/bukkit/block/Block.java b/src/main/java/org/bukkit/block/Block.java
|
2023-05-12 13:10:08 +02:00
|
|
|
index cb0dcbbfb77158c3b17bd7994a9bbcef8060941a..921864e748407291b7fa153381e7d9701e1c4608 100644
|
2022-03-15 19:38:36 +01:00
|
|
|
--- a/src/main/java/org/bukkit/block/Block.java
|
|
|
|
+++ b/src/main/java/org/bukkit/block/Block.java
|
2023-02-15 23:10:14 +01:00
|
|
|
@@ -371,10 +371,22 @@ public interface Block extends Metadatable, Translatable, net.kyori.adventure.tr
|
2022-03-15 19:38:36 +01:00
|
|
|
* Returns the biome that this block resides in
|
|
|
|
*
|
|
|
|
* @return Biome type containing this block
|
|
|
|
+ * @see #getComputedBiome()
|
|
|
|
*/
|
|
|
|
@NotNull
|
|
|
|
Biome getBiome();
|
|
|
|
|
|
|
|
+ // Paper start
|
|
|
|
+ /**
|
|
|
|
+ * Gets the computed biome at the location of this Block.
|
|
|
|
+ *
|
|
|
|
+ * @return computed biome at the location of this Block.
|
|
|
|
+ * @see org.bukkit.RegionAccessor#getComputedBiome(int, int, int)
|
|
|
|
+ */
|
|
|
|
+ @NotNull
|
|
|
|
+ Biome getComputedBiome();
|
|
|
|
+ // Paper end
|
|
|
|
+
|
|
|
|
/**
|
|
|
|
* Sets the biome that this block resides in
|
|
|
|
*
|