Mirror von
https://github.com/PaperMC/Paper.git
synchronisiert 2024-12-20 21:40:06 +01:00
c100e20d60
This reverts commits: - d2d03afc8854394aeefb40ea5ebf224c8032b19f - 6245746e91123dd8ef70e5f15b7cdfc7e36d8e8c - 41fae5c613e9e69a8f6bdf33b23bb09d7f407433 - c34bdecab42cf4098054a5ea43e1c2958d44ae92 - d7445084ac9a90fa0b66d8b050b8d0d2a062eaf3 - 6a6ed2e6ae2328a8a791bcc6857c44dc6c6a7030 - a783bc4dc95da8e26c673abe48fad96b550aba28 - cb50fd68766df8e07631ba5be85759f8257e8068 - 34dfff2ad5c407c712b2783f02960aac5e8649f2 - f33b513820de987b49a4338e85df80968217a601 - 5fd9fdfde055e6eb6a83db246d009b69377b7c94 - 2795b116f40d06551fbb7b96d1963c0ddbeac384
120 Zeilen
3.5 KiB
Java
120 Zeilen
3.5 KiB
Java
package net.minecraft.server;
|
|
|
|
import java.util.Random;
|
|
|
|
public class BlockCrops extends BlockFlower {
|
|
|
|
protected BlockCrops(int i, int j) {
|
|
super(i, j);
|
|
this.textureId = j;
|
|
this.a(true);
|
|
float f = 0.5F;
|
|
|
|
this.a(0.5F - f, 0.0F, 0.5F - f, 0.5F + f, 0.25F, 0.5F + f);
|
|
}
|
|
|
|
protected boolean d(int i) {
|
|
return i == Block.SOIL.id;
|
|
}
|
|
|
|
public void a(World world, int i, int j, int k, Random random) {
|
|
super.a(world, i, j, k, random);
|
|
if (world.getLightLevel(i, j + 1, k) >= 9) {
|
|
int l = world.getData(i, j, k);
|
|
|
|
if (l < 7) {
|
|
float f = this.i(world, i, j, k);
|
|
|
|
if (random.nextInt((int) (25.0F / f) + 1) == 0) {
|
|
org.bukkit.craftbukkit.event.CraftEventFactory.handleBlockGrowEvent(world, i, j, k, this.id, ++l); // CraftBukkit
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
public void g(World world, int i, int j, int k) {
|
|
world.setData(i, j, k, 7);
|
|
}
|
|
|
|
private float i(World world, int i, int j, int k) {
|
|
float f = 1.0F;
|
|
int l = world.getTypeId(i, j, k - 1);
|
|
int i1 = world.getTypeId(i, j, k + 1);
|
|
int j1 = world.getTypeId(i - 1, j, k);
|
|
int k1 = world.getTypeId(i + 1, j, k);
|
|
int l1 = world.getTypeId(i - 1, j, k - 1);
|
|
int i2 = world.getTypeId(i + 1, j, k - 1);
|
|
int j2 = world.getTypeId(i + 1, j, k + 1);
|
|
int k2 = world.getTypeId(i - 1, j, k + 1);
|
|
boolean flag = j1 == this.id || k1 == this.id;
|
|
boolean flag1 = l == this.id || i1 == this.id;
|
|
boolean flag2 = l1 == this.id || i2 == this.id || j2 == this.id || k2 == this.id;
|
|
|
|
for (int l2 = i - 1; l2 <= i + 1; ++l2) {
|
|
for (int i3 = k - 1; i3 <= k + 1; ++i3) {
|
|
int j3 = world.getTypeId(l2, j - 1, i3);
|
|
float f1 = 0.0F;
|
|
|
|
if (j3 == Block.SOIL.id) {
|
|
f1 = 1.0F;
|
|
if (world.getData(l2, j - 1, i3) > 0) {
|
|
f1 = 3.0F;
|
|
}
|
|
}
|
|
|
|
if (l2 != i || i3 != k) {
|
|
f1 /= 4.0F;
|
|
}
|
|
|
|
f += f1;
|
|
}
|
|
}
|
|
|
|
if (flag2 || flag && flag1) {
|
|
f /= 2.0F;
|
|
}
|
|
|
|
return f;
|
|
}
|
|
|
|
public int a(int i, int j) {
|
|
if (j < 0) {
|
|
j = 7;
|
|
}
|
|
|
|
return this.textureId + j;
|
|
}
|
|
|
|
public int c() {
|
|
return 6;
|
|
}
|
|
|
|
public void dropNaturally(World world, int i, int j, int k, int l, float f, int i1) {
|
|
super.dropNaturally(world, i, j, k, l, f, 0);
|
|
if (!world.isStatic) {
|
|
int j1 = 3 + i1;
|
|
|
|
for (int k1 = 0; k1 < j1; ++k1) {
|
|
if (world.random.nextInt(15) <= l) {
|
|
float f1 = 0.7F;
|
|
float f2 = world.random.nextFloat() * f1 + (1.0F - f1) * 0.5F;
|
|
float f3 = world.random.nextFloat() * f1 + (1.0F - f1) * 0.5F;
|
|
float f4 = world.random.nextFloat() * f1 + (1.0F - f1) * 0.5F;
|
|
EntityItem entityitem = new EntityItem(world, (double) ((float) i + f2), (double) ((float) j + f3), (double) ((float) k + f4), new ItemStack(Item.SEEDS));
|
|
|
|
entityitem.pickupDelay = 10;
|
|
world.addEntity(entityitem);
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
public int getDropType(int i, Random random, int j) {
|
|
return i == 7 ? Item.WHEAT.id : -1;
|
|
}
|
|
|
|
public int a(Random random) {
|
|
return 1;
|
|
}
|
|
}
|