diff options
author | Feildmaster <admin@feildmaster.com> | 2012-02-11 20:03:54 -0600 |
---|---|---|
committer | EvilSeph <evilseph@gmail.com> | 2012-02-22 21:46:44 -0500 |
commit | 847e1c62c5b6d5f40d0be8a465140e8255e82ec9 (patch) | |
tree | 08464ac4a3c9034059b2ca91f536ff0fe6bafdb8 /src/main/java/net/minecraft/server/BlockCrops.java | |
parent | 326091c130657294157d137895663ad2924c0b95 (diff) | |
download | craftbukkit-847e1c62c5b6d5f40d0be8a465140e8255e82ec9.tar craftbukkit-847e1c62c5b6d5f40d0be8a465140e8255e82ec9.tar.gz craftbukkit-847e1c62c5b6d5f40d0be8a465140e8255e82ec9.tar.lz craftbukkit-847e1c62c5b6d5f40d0be8a465140e8255e82ec9.tar.xz craftbukkit-847e1c62c5b6d5f40d0be8a465140e8255e82ec9.zip |
[Bleeding] Added BlockCrops, BlockReed, BlockStem, BlockNetherWart for diff visibility.
Diffstat (limited to 'src/main/java/net/minecraft/server/BlockCrops.java')
-rw-r--r-- | src/main/java/net/minecraft/server/BlockCrops.java | 120 |
1 files changed, 120 insertions, 0 deletions
diff --git a/src/main/java/net/minecraft/server/BlockCrops.java b/src/main/java/net/minecraft/server/BlockCrops.java new file mode 100644 index 00000000..818d2efd --- /dev/null +++ b/src/main/java/net/minecraft/server/BlockCrops.java @@ -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; + } +} |