mirror of
https://github.com/PaperMC/Paper.git
synced 2025-01-20 23:31:33 +01:00
Bees get gravity in void. Fixes MC-167279
This commit is contained in:
parent
c7b38e2bc7
commit
e4290a3697
@ -12,7 +12,31 @@
|
|||||||
|
|
||||||
public class Bee extends Animal implements NeutralMob, FlyingAnimal {
|
public class Bee extends Animal implements NeutralMob, FlyingAnimal {
|
||||||
|
|
||||||
@@ -198,21 +203,28 @@
|
@@ -149,7 +154,22 @@
|
||||||
|
public Bee(EntityType<? extends Bee> type, Level world) {
|
||||||
|
super(type, world);
|
||||||
|
this.remainingCooldownBeforeLocatingNewFlower = Mth.nextInt(this.random, 20, 60);
|
||||||
|
- this.moveControl = new FlyingMoveControl(this, 20, true);
|
||||||
|
+ // Paper start - Fix MC-167279
|
||||||
|
+ class BeeFlyingMoveControl extends FlyingMoveControl {
|
||||||
|
+ public BeeFlyingMoveControl(final Mob entity, final int maxPitchChange, final boolean noGravity) {
|
||||||
|
+ super(entity, maxPitchChange, noGravity);
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ @Override
|
||||||
|
+ public void tick() {
|
||||||
|
+ if (this.mob.getY() <= Bee.this.level().getMinY()) {
|
||||||
|
+ this.mob.setNoGravity(false);
|
||||||
|
+ }
|
||||||
|
+ super.tick();
|
||||||
|
+ }
|
||||||
|
+ }
|
||||||
|
+ this.moveControl = new BeeFlyingMoveControl(this, 20, true);
|
||||||
|
+ // Paper end - Fix MC-167279
|
||||||
|
this.lookControl = new Bee.BeeLookControl(this);
|
||||||
|
this.setPathfindingMalus(PathType.DANGER_FIRE, -1.0F);
|
||||||
|
this.setPathfindingMalus(PathType.WATER, -1.0F);
|
||||||
|
@@ -198,21 +218,28 @@
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void addAdditionalSaveData(CompoundTag nbt) {
|
public void addAdditionalSaveData(CompoundTag nbt) {
|
||||||
@ -52,7 +76,7 @@
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@@ -223,8 +235,8 @@
|
@@ -223,8 +250,8 @@
|
||||||
this.ticksWithoutNectarSinceExitingHive = nbt.getInt("TicksSincePollination");
|
this.ticksWithoutNectarSinceExitingHive = nbt.getInt("TicksSincePollination");
|
||||||
this.stayOutOfHiveCountdown = nbt.getInt("CannotEnterHiveTicks");
|
this.stayOutOfHiveCountdown = nbt.getInt("CannotEnterHiveTicks");
|
||||||
this.numCropsGrownSincePollination = nbt.getInt("CropsGrownSincePollination");
|
this.numCropsGrownSincePollination = nbt.getInt("CropsGrownSincePollination");
|
||||||
@ -63,7 +87,7 @@
|
|||||||
this.readPersistentAngerSaveData(this.level(), nbt);
|
this.readPersistentAngerSaveData(this.level(), nbt);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -248,7 +260,7 @@
|
@@ -248,7 +275,7 @@
|
||||||
}
|
}
|
||||||
|
|
||||||
if (b0 > 0) {
|
if (b0 > 0) {
|
||||||
@ -72,7 +96,7 @@
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -506,7 +518,12 @@
|
@@ -506,7 +533,12 @@
|
||||||
|
|
||||||
@Nullable
|
@Nullable
|
||||||
BeehiveBlockEntity getBeehiveBlockEntity() {
|
BeehiveBlockEntity getBeehiveBlockEntity() {
|
||||||
@ -86,7 +110,7 @@
|
|||||||
}
|
}
|
||||||
|
|
||||||
boolean isHiveValid() {
|
boolean isHiveValid() {
|
||||||
@@ -671,8 +688,14 @@
|
@@ -671,8 +703,14 @@
|
||||||
if (this.isInvulnerableTo(world, source)) {
|
if (this.isInvulnerableTo(world, source)) {
|
||||||
return false;
|
return false;
|
||||||
} else {
|
} else {
|
||||||
@ -102,7 +126,7 @@
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -1082,7 +1105,7 @@
|
@@ -1082,7 +1120,7 @@
|
||||||
|
|
||||||
BeeGoToHiveGoal() {
|
BeeGoToHiveGoal() {
|
||||||
super();
|
super();
|
||||||
@ -111,7 +135,7 @@
|
|||||||
this.blacklistedTargets = Lists.newArrayList();
|
this.blacklistedTargets = Lists.newArrayList();
|
||||||
this.setFlags(EnumSet.of(Goal.Flag.MOVE));
|
this.setFlags(EnumSet.of(Goal.Flag.MOVE));
|
||||||
}
|
}
|
||||||
@@ -1196,7 +1219,7 @@
|
@@ -1196,7 +1234,7 @@
|
||||||
|
|
||||||
BeeGoToKnownFlowerGoal() {
|
BeeGoToKnownFlowerGoal() {
|
||||||
super();
|
super();
|
||||||
@ -120,7 +144,7 @@
|
|||||||
this.setFlags(EnumSet.of(Goal.Flag.MOVE));
|
this.setFlags(EnumSet.of(Goal.Flag.MOVE));
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -1301,7 +1324,7 @@
|
@@ -1301,7 +1339,7 @@
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -129,7 +153,7 @@
|
|||||||
Bee.this.level().levelEvent(2011, blockposition, 15);
|
Bee.this.level().levelEvent(2011, blockposition, 15);
|
||||||
Bee.this.level().setBlockAndUpdate(blockposition, iblockdata1);
|
Bee.this.level().setBlockAndUpdate(blockposition, iblockdata1);
|
||||||
Bee.this.incrementNumCropsGrownSincePollination();
|
Bee.this.incrementNumCropsGrownSincePollination();
|
||||||
@@ -1378,7 +1401,7 @@
|
@@ -1378,7 +1416,7 @@
|
||||||
@Override
|
@Override
|
||||||
protected void alertOther(Mob mob, LivingEntity target) {
|
protected void alertOther(Mob mob, LivingEntity target) {
|
||||||
if (mob instanceof Bee && this.mob.hasLineOfSight(target)) {
|
if (mob instanceof Bee && this.mob.hasLineOfSight(target)) {
|
||||||
@ -138,7 +162,7 @@
|
|||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
@@ -1387,7 +1410,7 @@
|
@@ -1387,7 +1425,7 @@
|
||||||
private static class BeeBecomeAngryTargetGoal extends NearestAttackableTargetGoal<Player> {
|
private static class BeeBecomeAngryTargetGoal extends NearestAttackableTargetGoal<Player> {
|
||||||
|
|
||||||
BeeBecomeAngryTargetGoal(Bee bee) {
|
BeeBecomeAngryTargetGoal(Bee bee) {
|
||||||
|
Loading…
Reference in New Issue
Block a user