2021-06-11 12:02:28 +00:00
|
|
|
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
|
|
|
From: Zach Brown <zach.brown@destroystokyo.com>
|
|
|
|
Date: Tue, 1 Mar 2016 13:09:16 -0600
|
|
|
|
Subject: [PATCH] Configurable baby zombie movement speed
|
|
|
|
|
|
|
|
|
|
|
|
diff --git a/src/main/java/com/destroystokyo/paper/PaperWorldConfig.java b/src/main/java/com/destroystokyo/paper/PaperWorldConfig.java
|
2022-05-07 16:47:28 +00:00
|
|
|
index e8b2ad7b454113c279733fb8f385d0d3f217e0f5..aba9f77878bd5475a63af1fa3f60580674ea63ad 100644
|
2021-06-11 12:02:28 +00:00
|
|
|
--- a/src/main/java/com/destroystokyo/paper/PaperWorldConfig.java
|
|
|
|
+++ b/src/main/java/com/destroystokyo/paper/PaperWorldConfig.java
|
2022-05-07 16:47:28 +00:00
|
|
|
@@ -108,4 +108,15 @@ public class PaperWorldConfig {
|
2021-11-24 17:58:26 +00:00
|
|
|
bambooMinHeight = getInt("max-growth-height.bamboo.min", 11);
|
2021-06-11 12:02:28 +00:00
|
|
|
log("Max height for cactus growth " + cactusMaxHeight + ". Max height for reed growth " + reedMaxHeight + ". Max height for bamboo growth " + bambooMaxHeight + ". Min height for fully-grown bamboo " + bambooMinHeight + ".");
|
|
|
|
}
|
|
|
|
+
|
|
|
|
+ public double babyZombieMovementModifier;
|
|
|
|
+ private void babyZombieMovementModifier() {
|
|
|
|
+ babyZombieMovementModifier = getDouble("baby-zombie-movement-modifier", 0.5D);
|
|
|
|
+ if (PaperConfig.version < 20) {
|
|
|
|
+ babyZombieMovementModifier = getDouble("baby-zombie-movement-speed", 0.5D);
|
|
|
|
+ set("baby-zombie-movement-modifier", babyZombieMovementModifier);
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ log("Baby zombies will move at the speed of " + babyZombieMovementModifier);
|
|
|
|
+ }
|
|
|
|
}
|
|
|
|
diff --git a/src/main/java/net/minecraft/world/entity/monster/Zombie.java b/src/main/java/net/minecraft/world/entity/monster/Zombie.java
|
2022-05-07 16:47:28 +00:00
|
|
|
index 627aeb45342c2804f911572056a63aa1cb0110e7..953f138b6cd48cc94bc23a4321a9684b4214637e 100644
|
2021-06-11 12:02:28 +00:00
|
|
|
--- a/src/main/java/net/minecraft/world/entity/monster/Zombie.java
|
|
|
|
+++ b/src/main/java/net/minecraft/world/entity/monster/Zombie.java
|
2021-11-23 11:27:39 +00:00
|
|
|
@@ -76,7 +76,7 @@ import org.bukkit.event.entity.EntityTransformEvent;
|
2021-06-11 12:02:28 +00:00
|
|
|
public class Zombie extends Monster {
|
|
|
|
|
|
|
|
private static final UUID SPEED_MODIFIER_BABY_UUID = UUID.fromString("B9766B59-9566-4402-BC1F-2EE2A276D836");
|
|
|
|
- private static final AttributeModifier SPEED_MODIFIER_BABY = new AttributeModifier(Zombie.SPEED_MODIFIER_BABY_UUID, "Baby speed boost", 0.5D, AttributeModifier.Operation.MULTIPLY_BASE);
|
|
|
|
+ private final AttributeModifier SPEED_MODIFIER_BABY = new AttributeModifier(Zombie.SPEED_MODIFIER_BABY_UUID, "Baby speed boost", 0.5D, AttributeModifier.Operation.MULTIPLY_BASE); private final AttributeModifier babyModifier = this.SPEED_MODIFIER_BABY; // Paper - remove static - Make baby speed configurable
|
|
|
|
private static final EntityDataAccessor<Boolean> DATA_BABY_ID = SynchedEntityData.defineId(Zombie.class, EntityDataSerializers.BOOLEAN);
|
|
|
|
private static final EntityDataAccessor<Integer> DATA_SPECIAL_TYPE_ID = SynchedEntityData.defineId(Zombie.class, EntityDataSerializers.INT);
|
|
|
|
public static final EntityDataAccessor<Boolean> DATA_DROWNED_CONVERSION_ID = SynchedEntityData.defineId(Zombie.class, EntityDataSerializers.BOOLEAN);
|
2021-11-23 11:27:39 +00:00
|
|
|
@@ -184,9 +184,9 @@ public class Zombie extends Monster {
|
2021-06-11 12:02:28 +00:00
|
|
|
if (this.level != null && !this.level.isClientSide) {
|
|
|
|
AttributeInstance attributemodifiable = this.getAttribute(Attributes.MOVEMENT_SPEED);
|
|
|
|
|
|
|
|
- attributemodifiable.removeModifier(Zombie.SPEED_MODIFIER_BABY);
|
|
|
|
+ attributemodifiable.removeModifier(this.babyModifier); // Paper
|
|
|
|
if (baby) {
|
|
|
|
- attributemodifiable.addTransientModifier(Zombie.SPEED_MODIFIER_BABY);
|
|
|
|
+ attributemodifiable.addTransientModifier(this.babyModifier); // Paper
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|