mirror of
https://github.com/PaperMC/Paper.git
synced 2025-08-16 04:33:56 -07:00
[Bleeding] Added BlockCrops, BlockReed, BlockStem, BlockNetherWart for diff visibility.
This commit is contained in:
120
src/main/java/net/minecraft/server/BlockCrops.java
Normal file
120
src/main/java/net/minecraft/server/BlockCrops.java
Normal file
@@ -0,0 +1,120 @@
|
||||
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) {
|
||||
++l;
|
||||
world.setData(i, j, k, l);
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
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;
|
||||
}
|
||||
}
|
Reference in New Issue
Block a user