13
0
geforkt von Mirrors/Paper

SPIGOT-7960: Improve natural item drop methods

By: md_5 <git@md-5.net>
Dieser Commit ist enthalten in:
CraftBukkit/Spigot 2024-11-19 20:16:47 +11:00
Ursprung c7707ece4c
Commit b3b4fd1c4b
2 geänderte Dateien mit 9 neuen und 4 gelöschten Zeilen

Datei anzeigen

@ -49,6 +49,7 @@ import net.minecraft.sounds.SoundCategory;
import net.minecraft.sounds.SoundEffect; import net.minecraft.sounds.SoundEffect;
import net.minecraft.sounds.SoundEffects; import net.minecraft.sounds.SoundEffects;
import net.minecraft.util.ArraySetSorted; import net.minecraft.util.ArraySetSorted;
import net.minecraft.util.MathHelper;
import net.minecraft.util.Unit; import net.minecraft.util.Unit;
import net.minecraft.world.EnumDifficulty; import net.minecraft.world.EnumDifficulty;
import net.minecraft.world.entity.EntityLightning; import net.minecraft.world.entity.EntityLightning;
@ -568,9 +569,9 @@ public class CraftWorld extends CraftRegionAccessor implements World {
Preconditions.checkArgument(loc != null, "Location cannot be null"); Preconditions.checkArgument(loc != null, "Location cannot be null");
Preconditions.checkArgument(item != null, "ItemStack cannot be null"); Preconditions.checkArgument(item != null, "ItemStack cannot be null");
double xs = (world.random.nextFloat() * 0.5F) + 0.25D; double xs = 0.5D + MathHelper.nextDouble(world.random, -0.25D, 0.25D);
double ys = (world.random.nextFloat() * 0.5F) + 0.25D; double ys = 0.5D + MathHelper.nextDouble(world.random, -0.25D, 0.25D) - ((double) EntityTypes.ITEM.getHeight() / 2.0D);
double zs = (world.random.nextFloat() * 0.5F) + 0.25D; double zs = MathHelper.nextDouble(world.random, -0.25D, 0.25D);
loc = loc.clone().add(xs, ys, zs); loc = loc.clone().add(xs, ys, zs);
return dropItem(loc, item, function); return dropItem(loc, item, function);
} }

Datei anzeigen

@ -1,6 +1,9 @@
package org.bukkit.craftbukkit.inventory; package org.bukkit.craftbukkit.inventory;
import com.google.common.base.Preconditions; import com.google.common.base.Preconditions;
import net.minecraft.world.InventoryUtils;
import net.minecraft.world.entity.player.EntityHuman;
import org.bukkit.craftbukkit.entity.CraftHumanEntity;
import org.bukkit.event.inventory.InventoryType; import org.bukkit.event.inventory.InventoryType;
import org.bukkit.inventory.Inventory; import org.bukkit.inventory.Inventory;
import org.bukkit.inventory.InventoryView; import org.bukkit.inventory.InventoryView;
@ -16,7 +19,8 @@ public abstract class CraftAbstractInventoryView implements InventoryView {
if (inventory != null) { if (inventory != null) {
inventory.setItem(convertSlot(slot), item); inventory.setItem(convertSlot(slot), item);
} else if (item != null) { } else if (item != null) {
getPlayer().getWorld().dropItemNaturally(getPlayer().getLocation(), item); EntityHuman handle = ((CraftHumanEntity) getPlayer()).getHandle();
InventoryUtils.dropItemStack(handle.level(), handle.getX(), handle.getY(), handle.getZ(), CraftItemStack.asNMSCopy(item));
} }
} }