Mirror von
https://github.com/PaperMC/Paper.git
synchronisiert 2024-11-16 21:10:17 +01:00
Fix dispenser event handling
Dieser Commit ist enthalten in:
Ursprung
d18972eca2
Commit
8dc52123bf
@ -104,45 +104,72 @@ public class BlockDispenser extends BlockContainer {
|
|||||||
double d1 = (double) j + 0.5D;
|
double d1 = (double) j + 0.5D;
|
||||||
double d2 = (double) k + (double) b1 * 0.6D + 0.5D;
|
double d2 = (double) k + (double) b1 * 0.6D + 0.5D;
|
||||||
ItemStack itemstack = tileentitydispenser.getItem(i1);
|
ItemStack itemstack = tileentitydispenser.getItem(i1);
|
||||||
|
|
||||||
|
// CraftBukkit start
|
||||||
|
// Copy item stack, because we want it to have 1 item
|
||||||
|
itemstack = new ItemStack(itemstack.id, 1, itemstack.getData(), itemstack.getEnchantments());
|
||||||
|
|
||||||
|
double d3 = random.nextDouble() * 0.1D + 0.2D;
|
||||||
|
double motX = (double) b0 * d3;
|
||||||
|
double motY = 0.20000000298023224D;
|
||||||
|
double motZ = (double) b1 * d3;
|
||||||
|
motX += random.nextGaussian() * 0.007499999832361937D * 6.0D;
|
||||||
|
motY += random.nextGaussian() * 0.007499999832361937D * 6.0D;
|
||||||
|
motZ += random.nextGaussian() * 0.007499999832361937D * 6.0D;
|
||||||
|
|
||||||
|
org.bukkit.block.Block block = world.getWorld().getBlockAt(i, j, k);
|
||||||
|
org.bukkit.inventory.ItemStack bukkitItem = new CraftItemStack(itemstack).clone();
|
||||||
|
|
||||||
|
BlockDispenseEvent event = new BlockDispenseEvent(block, bukkitItem, new org.bukkit.util.Vector(motX, motY, motZ));
|
||||||
|
world.getServer().getPluginManager().callEvent(event);
|
||||||
|
|
||||||
|
if (event.isCancelled()) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
itemstack = CraftItemStack.createNMSItemStack(event.getItem());
|
||||||
|
// CraftBukkit end
|
||||||
|
|
||||||
int j1 = a(tileentitydispenser, world, itemstack, random, i, j, k, b0, b1, d0, d1, d2);
|
int j1 = a(tileentitydispenser, world, itemstack, random, i, j, k, b0, b1, d0, d1, d2);
|
||||||
|
|
||||||
if (j1 == 1) {
|
if (j1 == 1) {
|
||||||
tileentitydispenser.splitStack(i1, 1);
|
// CraftBukkit start
|
||||||
|
if (event.getItem().equals(bukkitItem)) {
|
||||||
|
// Actually remove the item
|
||||||
|
tileentitydispenser.splitStack(i1, 1);
|
||||||
|
}
|
||||||
|
// CraftBukkit end
|
||||||
} else if (j1 == 0) {
|
} else if (j1 == 0) {
|
||||||
// CraftBukkit start
|
// CraftBukkit start
|
||||||
double d3 = random.nextDouble() * 0.1D + 0.2D;
|
motX = event.getVelocity().getX();
|
||||||
double motX = (double) b0 * d3;
|
motY = event.getVelocity().getY();
|
||||||
double motY = 0.20000000298023224D;
|
motZ = event.getVelocity().getZ();
|
||||||
double motZ = (double) b1 * d3;
|
|
||||||
motX += random.nextGaussian() * 0.007499999832361937D * 6.0D;
|
|
||||||
motY += random.nextGaussian() * 0.007499999832361937D * 6.0D;
|
|
||||||
motZ += random.nextGaussian() * 0.007499999832361937D * 6.0D;
|
|
||||||
|
|
||||||
org.bukkit.block.Block block = world.getWorld().getBlockAt(i, j, k);
|
|
||||||
org.bukkit.inventory.ItemStack bukkitItem = new CraftItemStack(itemstack).clone();
|
|
||||||
|
|
||||||
BlockDispenseEvent event = new BlockDispenseEvent(block, bukkitItem, new org.bukkit.util.Vector(motX, motY, motZ));
|
|
||||||
world.getServer().getPluginManager().callEvent(event);
|
|
||||||
|
|
||||||
if (event.isCancelled()) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (event.getItem().equals(bukkitItem)) {
|
if (event.getItem().equals(bukkitItem)) {
|
||||||
// Actually remove the item
|
// Actually remove the item
|
||||||
tileentitydispenser.splitStack(i1, 1);
|
tileentitydispenser.splitStack(i1, 1);
|
||||||
}
|
}
|
||||||
|
|
||||||
motX = event.getVelocity().getX();
|
EntityItem entityitem = new EntityItem(world, d0, d1 - 0.3D, d2, itemstack);
|
||||||
motY = event.getVelocity().getY();
|
entityitem.motX = event.getVelocity().getX();
|
||||||
motZ = event.getVelocity().getZ();
|
entityitem.motY = event.getVelocity().getY();
|
||||||
|
entityitem.motZ = event.getVelocity().getZ();
|
||||||
itemstack = CraftItemStack.createNMSItemStack(event.getItem());
|
world.addEntity(entityitem);
|
||||||
|
|
||||||
a(world, itemstack, random, motX, motY, motZ, d0, d1, d2);
|
|
||||||
// CraftBukkit end
|
// CraftBukkit end
|
||||||
|
|
||||||
world.triggerEffect(1000, i, j, k, 0);
|
world.triggerEffect(1000, i, j, k, 0);
|
||||||
|
// CraftBukkit start - new condition
|
||||||
|
} else if (j1 == 2) {
|
||||||
|
ItemStack old = tileentitydispenser.getItem(i1);
|
||||||
|
if (old.id == Item.BUCKET.id && old.count > 1) {
|
||||||
|
old.count--;
|
||||||
|
if (tileentitydispenser.a(itemstack) < 0) {
|
||||||
|
a(world, itemstack, random, 6, l, i1, d0, d1, d2);
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
tileentitydispenser.setItem(i1, itemstack);
|
||||||
|
}
|
||||||
|
// CraftBukkit end
|
||||||
}
|
}
|
||||||
|
|
||||||
world.triggerEffect(2000, i, j, k, b0 + 1 + (b1 + 1) * 3);
|
world.triggerEffect(2000, i, j, k, b0 + 1 + (b1 + 1) * 3);
|
||||||
@ -230,17 +257,18 @@ public class BlockDispenser extends BlockContainer {
|
|||||||
super.remove(world, i, j, k, l, i1);
|
super.remove(world, i, j, k, l, i1);
|
||||||
}
|
}
|
||||||
|
|
||||||
// CraftBukkit start - change of method signature!
|
private static void a(World world, ItemStack itemstack, Random random, int i, int j, int k, double d0, double d1, double d2) {
|
||||||
private static void a(World world, ItemStack itemstack, Random random, double motX, double motY, double motZ, double d0, double d1, double d2) {
|
|
||||||
EntityItem entityitem = new EntityItem(world, d0, d1 - 0.3D, d2, itemstack);
|
EntityItem entityitem = new EntityItem(world, d0, d1 - 0.3D, d2, itemstack);
|
||||||
// double d3 = random.nextDouble() * 0.1D + 0.2D; // Moved up
|
double d3 = random.nextDouble() * 0.1D + 0.2D;
|
||||||
|
|
||||||
entityitem.motX = motX;
|
entityitem.motX = (double) j * d3;
|
||||||
entityitem.motY = motY;
|
entityitem.motY = 0.20000000298023224D;
|
||||||
entityitem.motZ = motZ;
|
entityitem.motZ = (double) k * d3;
|
||||||
|
entityitem.motX += random.nextGaussian() * 0.007499999832361937D * (double) i;
|
||||||
|
entityitem.motY += random.nextGaussian() * 0.007499999832361937D * (double) i;
|
||||||
|
entityitem.motZ += random.nextGaussian() * 0.007499999832361937D * (double) i;
|
||||||
world.addEntity(entityitem);
|
world.addEntity(entityitem);
|
||||||
}
|
}
|
||||||
// CraftBukkit end
|
|
||||||
|
|
||||||
private static int a(TileEntityDispenser tileentitydispenser, World world, ItemStack itemstack, Random random, int i, int j, int k, int l, int i1, double d0, double d1, double d2) {
|
private static int a(TileEntityDispenser tileentitydispenser, World world, ItemStack itemstack, Random random, int i, int j, int k, int l, int i1, double d0, double d1, double d2) {
|
||||||
float f = 1.1F;
|
float f = 1.1F;
|
||||||
|
Laden…
In neuem Issue referenzieren
Einen Benutzer sperren