2021-06-11 15:00:00 +10:00
From accffd8b9c52629594bbedafe3e2308596005920 Mon Sep 17 00:00:00 2001
2013-03-23 09:48:22 +11:00
From: md_5 <md_5@live.com.au>
Date: Sat, 23 Mar 2013 09:46:33 +1100
Subject: [PATCH] Merge tweaks and configuration
This allows the merging of Experience orbs, as well as the configuration of the merge radius of items. Additionally it refactors the merge algorithm to be a better experience for players.
2021-06-11 15:00:00 +10:00
diff --git a/src/main/java/net/minecraft/world/entity/EntityExperienceOrb.java b/src/main/java/net/minecraft/world/entity/EntityExperienceOrb.java
index a4248a168..b16ff216e 100644
--- a/src/main/java/net/minecraft/world/entity/EntityExperienceOrb.java
+++ b/src/main/java/net/minecraft/world/entity/EntityExperienceOrb.java
@@ -167,7 +167,10 @@ public class EntityExperienceOrb extends Entity {
}
private static boolean b(WorldServer worldserver, Vec3D vec3d, int i) {
- AxisAlignedBB axisalignedbb = AxisAlignedBB.a(vec3d, 1.0D, 1.0D, 1.0D);
+ // Spigot start
+ double radius = worldserver.spigotConfig.expMerge;
+ AxisAlignedBB axisalignedbb = AxisAlignedBB.a(vec3d, radius, radius, radius);
+ // Spigot end
int j = worldserver.getRandom().nextInt(40);
List<EntityExperienceOrb> list = worldserver.a(EntityTypeTest.a(EntityExperienceOrb.class), axisalignedbb, (entityexperienceorb) -> {
return a(entityexperienceorb, j, i);
2021-03-16 09:00:00 +11:00
diff --git a/src/main/java/net/minecraft/world/entity/item/EntityItem.java b/src/main/java/net/minecraft/world/entity/item/EntityItem.java
2021-06-11 15:00:00 +10:00
index ff3cf5bee..bb9f81eeb 100644
2021-03-16 09:00:00 +11:00
--- a/src/main/java/net/minecraft/world/entity/item/EntityItem.java
+++ b/src/main/java/net/minecraft/world/entity/item/EntityItem.java
2021-06-11 15:00:00 +10:00
@@ -200,7 +200,10 @@ public class EntityItem extends Entity {
2013-03-23 09:48:22 +11:00
2019-04-23 12:00:00 +10:00
private void mergeNearby() {
2021-06-11 15:00:00 +10:00
if (this.A()) {
- List<EntityItem> list = this.level.a(EntityItem.class, this.getBoundingBox().grow(0.5D, 0.0D, 0.5D), (entityitem) -> {
2019-12-11 09:00:00 +11:00
+ // Spigot start
2021-06-11 15:00:00 +10:00
+ double radius = level.spigotConfig.itemMerge;
+ List<EntityItem> list = this.level.a(EntityItem.class, this.getBoundingBox().grow(radius, radius, radius), (entityitem) -> {
2019-12-11 09:00:00 +11:00
+ // Spigot end
2021-06-11 15:00:00 +10:00
return entityitem != this && entityitem.A();
2019-12-11 09:00:00 +11:00
});
Iterator iterator = list.iterator();
2021-06-11 15:00:00 +10:00
@@ -230,7 +233,7 @@ public class EntityItem extends Entity {
2019-12-11 09:00:00 +11:00
ItemStack itemstack1 = entityitem.getItemStack();
2013-03-23 09:48:22 +11:00
2019-12-11 09:00:00 +11:00
if (Objects.equals(this.getOwner(), entityitem.getOwner()) && a(itemstack, itemstack1)) {
- if (itemstack1.getCount() < itemstack.getCount()) {
+ if (true || itemstack1.getCount() < itemstack.getCount()) { // Spigot
a(this, itemstack, entityitem, itemstack1);
} else {
a(entityitem, itemstack1, this, itemstack);
2013-06-20 18:41:59 +10:00
diff --git a/src/main/java/org/spigotmc/SpigotWorldConfig.java b/src/main/java/org/spigotmc/SpigotWorldConfig.java
2021-01-31 10:08:46 +11:00
index fb9c4fc78..8c855cf9b 100644
2013-06-20 18:41:59 +10:00
--- a/src/main/java/org/spigotmc/SpigotWorldConfig.java
+++ b/src/main/java/org/spigotmc/SpigotWorldConfig.java
2019-08-08 20:48:47 +10:00
@@ -128,4 +128,18 @@ public class SpigotWorldConfig
2019-06-29 16:45:44 +10:00
sweetBerryModifier = getAndValidateGrowth( "SweetBerry" );
kelpModifier = getAndValidateGrowth( "Kelp" );
2013-06-20 18:41:59 +10:00
}
+
2013-06-21 17:00:01 +10:00
+ public double itemMerge;
2013-06-20 18:41:59 +10:00
+ private void itemMerge()
+ {
2013-06-21 17:00:01 +10:00
+ itemMerge = getDouble("merge-radius.item", 2.5 );
2013-06-20 18:41:59 +10:00
+ log( "Item Merge Radius: " + itemMerge );
+ }
+
2013-06-21 17:00:01 +10:00
+ public double expMerge;
2013-06-20 18:41:59 +10:00
+ private void expMerge()
+ {
2013-06-21 17:00:01 +10:00
+ expMerge = getDouble("merge-radius.exp", 3.0 );
2013-06-20 18:41:59 +10:00
+ log( "Experience Merge Radius: " + expMerge );
+ }
}
2013-03-23 09:48:22 +11:00
--
2020-05-09 18:48:11 +10:00
2.25.1
2013-03-23 09:48:22 +11:00