mirror of
https://github.com/PaperMC/Paper.git
synced 2025-08-15 20:23:53 -07:00
Added PathfinderGoalTarget, PathfinderGoalArrowAttack, PathfinderGoalMeleeAttack for diff visibility.
This commit is contained in:
@@ -0,0 +1,87 @@
|
||||
package net.minecraft.server;
|
||||
|
||||
public class PathfinderGoalArrowAttack extends PathfinderGoal {
|
||||
|
||||
World a;
|
||||
EntityLiving b;
|
||||
EntityLiving c;
|
||||
int d = 0;
|
||||
float e;
|
||||
int f = 0;
|
||||
int g;
|
||||
int h;
|
||||
|
||||
public PathfinderGoalArrowAttack(EntityLiving entityliving, float f, int i, int j) {
|
||||
this.b = entityliving;
|
||||
this.a = entityliving.world;
|
||||
this.e = f;
|
||||
this.g = i;
|
||||
this.h = j;
|
||||
this.a(3);
|
||||
}
|
||||
|
||||
public boolean a() {
|
||||
EntityLiving entityliving = this.b.as();
|
||||
|
||||
if (entityliving == null) {
|
||||
return false;
|
||||
} else {
|
||||
this.c = entityliving;
|
||||
return true;
|
||||
}
|
||||
}
|
||||
|
||||
public boolean b() {
|
||||
return this.a() || !this.b.ak().e();
|
||||
}
|
||||
|
||||
public void d() {
|
||||
this.c = null;
|
||||
}
|
||||
|
||||
public void e() {
|
||||
double d0 = 100.0D;
|
||||
double d1 = this.b.e(this.c.locX, this.c.boundingBox.b, this.c.locZ);
|
||||
boolean flag = this.b.al().canSee(this.c);
|
||||
|
||||
if (flag) {
|
||||
++this.f;
|
||||
} else {
|
||||
this.f = 0;
|
||||
}
|
||||
|
||||
if (d1 <= d0 && this.f >= 20) {
|
||||
this.b.ak().f();
|
||||
} else {
|
||||
this.b.ak().a(this.c, this.e);
|
||||
}
|
||||
|
||||
this.b.getControllerLook().a(this.c, 30.0F, 30.0F);
|
||||
this.d = Math.max(this.d - 1, 0);
|
||||
if (this.d <= 0) {
|
||||
if (d1 <= d0 && flag) {
|
||||
this.f();
|
||||
this.d = this.h;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
private void f() {
|
||||
if (this.g == 1) {
|
||||
EntityArrow entityarrow = new EntityArrow(this.a, this.b, this.c, 1.6F, 12.0F);
|
||||
|
||||
this.a.makeSound(this.b, "random.bow", 1.0F, 1.0F / (this.b.am().nextFloat() * 0.4F + 0.8F));
|
||||
this.a.addEntity(entityarrow);
|
||||
} else if (this.g == 2) {
|
||||
EntitySnowball entitysnowball = new EntitySnowball(this.a, this.b);
|
||||
double d0 = this.c.locX - this.b.locX;
|
||||
double d1 = this.c.locY + (double) this.c.getHeadHeight() - 1.100000023841858D - entitysnowball.locY;
|
||||
double d2 = this.c.locZ - this.b.locZ;
|
||||
float f = MathHelper.sqrt(d0 * d0 + d2 * d2) * 0.2F;
|
||||
|
||||
entitysnowball.a(d0, d1 + (double) f, d2, 1.6F, 12.0F);
|
||||
this.a.makeSound(this.b, "random.bow", 1.0F, 1.0F / (this.b.am().nextFloat() * 0.4F + 0.8F));
|
||||
this.a.addEntity(entitysnowball);
|
||||
}
|
||||
}
|
||||
}
|
Reference in New Issue
Block a user