mirror of
https://github.com/Minestom/Minestom.git
synced 2025-01-04 07:28:19 +01:00
commit
5b48a4f4cd
@ -7,6 +7,7 @@ import net.minestom.server.item.rule.VanillaStackingRule;
|
|||||||
import net.minestom.server.tag.Tag;
|
import net.minestom.server.tag.Tag;
|
||||||
import net.minestom.server.tag.TagReadable;
|
import net.minestom.server.tag.TagReadable;
|
||||||
import net.minestom.server.utils.NBTUtils;
|
import net.minestom.server.utils.NBTUtils;
|
||||||
|
import net.minestom.server.utils.validate.Check;
|
||||||
import org.jetbrains.annotations.ApiStatus;
|
import org.jetbrains.annotations.ApiStatus;
|
||||||
import org.jetbrains.annotations.Contract;
|
import org.jetbrains.annotations.Contract;
|
||||||
import org.jetbrains.annotations.NotNull;
|
import org.jetbrains.annotations.NotNull;
|
||||||
@ -79,6 +80,24 @@ public final class ItemStack implements TagReadable, HoverEventSource<HoverEvent
|
|||||||
return fromNBT(material, nbtCompound, 1);
|
return fromNBT(material, nbtCompound, 1);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Converts this item to an NBT tag containing the id (material), count (amount), and tag (meta).
|
||||||
|
*
|
||||||
|
* @param nbtCompound The nbt representation of the item
|
||||||
|
*/
|
||||||
|
@ApiStatus.Experimental
|
||||||
|
public static @NotNull ItemStack fromItemNBT(@NotNull NBTCompound nbtCompound) {
|
||||||
|
String id = nbtCompound.getString("id");
|
||||||
|
Check.notNull(id, "Item NBT must contain an id field.");
|
||||||
|
Material material = Material.fromNamespaceId(id);
|
||||||
|
Check.notNull(material, "Unknown material: {0}", id);
|
||||||
|
|
||||||
|
Byte amount = nbtCompound.getByte("Count");
|
||||||
|
return fromNBT(material,
|
||||||
|
nbtCompound.getCompound("tag"),
|
||||||
|
amount == null ? 1 : amount);
|
||||||
|
}
|
||||||
|
|
||||||
@Contract(pure = true)
|
@Contract(pure = true)
|
||||||
public @NotNull Material getMaterial() {
|
public @NotNull Material getMaterial() {
|
||||||
return material;
|
return material;
|
||||||
@ -228,6 +247,20 @@ public final class ItemStack implements TagReadable, HoverEventSource<HoverEvent
|
|||||||
NBTUtils.asBinaryTagHolder(this.meta.toNBT().getCompound("tag")))));
|
NBTUtils.asBinaryTagHolder(this.meta.toNBT().getCompound("tag")))));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Converts this item to an NBT tag containing the id (material), count (amount), and tag (meta)
|
||||||
|
*
|
||||||
|
* @return The nbt representation of the item
|
||||||
|
*/
|
||||||
|
@ApiStatus.Experimental
|
||||||
|
public @NotNull NBTCompound toItemNBT() {
|
||||||
|
final NBTCompound nbtCompound = new NBTCompound();
|
||||||
|
nbtCompound.setString("id", getMaterial().name());
|
||||||
|
nbtCompound.setByte("Count", (byte) getAmount());
|
||||||
|
nbtCompound.set("tag", getMeta().toNBT());
|
||||||
|
return nbtCompound;
|
||||||
|
}
|
||||||
|
|
||||||
@Contract(value = "-> new", pure = true)
|
@Contract(value = "-> new", pure = true)
|
||||||
private @NotNull ItemStackBuilder builder() {
|
private @NotNull ItemStackBuilder builder() {
|
||||||
return new ItemStackBuilder(material, meta.builder())
|
return new ItemStackBuilder(material, meta.builder())
|
||||||
|
@ -46,6 +46,7 @@ public class ItemStackBuilder {
|
|||||||
MATERIAL_SUPPLIER_MAP.put(Material.FIREWORK_STAR, FireworkEffectMeta.Builder::new);
|
MATERIAL_SUPPLIER_MAP.put(Material.FIREWORK_STAR, FireworkEffectMeta.Builder::new);
|
||||||
MATERIAL_SUPPLIER_MAP.put(Material.FIREWORK_ROCKET, FireworkMeta.Builder::new);
|
MATERIAL_SUPPLIER_MAP.put(Material.FIREWORK_ROCKET, FireworkMeta.Builder::new);
|
||||||
MATERIAL_SUPPLIER_MAP.put(Material.PLAYER_HEAD, PlayerHeadMeta.Builder::new);
|
MATERIAL_SUPPLIER_MAP.put(Material.PLAYER_HEAD, PlayerHeadMeta.Builder::new);
|
||||||
|
MATERIAL_SUPPLIER_MAP.put(Material.BUNDLE, BundleMeta.Builder::new);
|
||||||
|
|
||||||
MATERIAL_SUPPLIER_MAP.put(Material.LEATHER_HELMET, LeatherArmorMeta.Builder::new);
|
MATERIAL_SUPPLIER_MAP.put(Material.LEATHER_HELMET, LeatherArmorMeta.Builder::new);
|
||||||
MATERIAL_SUPPLIER_MAP.put(Material.LEATHER_CHESTPLATE, LeatherArmorMeta.Builder::new);
|
MATERIAL_SUPPLIER_MAP.put(Material.LEATHER_CHESTPLATE, LeatherArmorMeta.Builder::new);
|
||||||
|
@ -0,0 +1,84 @@
|
|||||||
|
package net.minestom.server.item.metadata;
|
||||||
|
|
||||||
|
import net.minestom.server.item.ItemMeta;
|
||||||
|
import net.minestom.server.item.ItemMetaBuilder;
|
||||||
|
import net.minestom.server.item.ItemStack;
|
||||||
|
import org.jetbrains.annotations.ApiStatus;
|
||||||
|
import org.jetbrains.annotations.NotNull;
|
||||||
|
import org.jglrxavpok.hephaistos.nbt.NBTCompound;
|
||||||
|
import org.jglrxavpok.hephaistos.nbt.NBTList;
|
||||||
|
import org.jglrxavpok.hephaistos.nbt.NBTTypes;
|
||||||
|
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.function.Supplier;
|
||||||
|
|
||||||
|
@ApiStatus.Experimental
|
||||||
|
public class BundleMeta extends ItemMeta implements ItemMetaBuilder.Provider<BundleMeta.Builder> {
|
||||||
|
|
||||||
|
private final List<ItemStack> items;
|
||||||
|
|
||||||
|
protected BundleMeta(ItemMetaBuilder metaBuilder,
|
||||||
|
@NotNull List<ItemStack> items) {
|
||||||
|
super(metaBuilder);
|
||||||
|
this.items = List.copyOf(items);
|
||||||
|
}
|
||||||
|
|
||||||
|
public @NotNull List<ItemStack> getItems() {
|
||||||
|
return items;
|
||||||
|
}
|
||||||
|
|
||||||
|
public static class Builder extends ItemMetaBuilder {
|
||||||
|
private List<ItemStack> items = new ArrayList<>();
|
||||||
|
|
||||||
|
public Builder items(@NotNull List<ItemStack> items) {
|
||||||
|
this.items = new ArrayList<>(items); // defensive copy
|
||||||
|
updateItems();
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
@ApiStatus.Experimental
|
||||||
|
public Builder addItem(@NotNull ItemStack item) {
|
||||||
|
items.add(item);
|
||||||
|
updateItems();
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
@ApiStatus.Experimental
|
||||||
|
public Builder removeItem(@NotNull ItemStack item) {
|
||||||
|
items.remove(item);
|
||||||
|
updateItems();
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public @NotNull BundleMeta build() {
|
||||||
|
return new BundleMeta(this, items);
|
||||||
|
}
|
||||||
|
|
||||||
|
private void updateItems() {
|
||||||
|
mutateNbt(compound -> {
|
||||||
|
NBTList<NBTCompound> itemList = new NBTList<>(NBTTypes.TAG_Compound);
|
||||||
|
for (ItemStack item : items) {
|
||||||
|
itemList.add(item.toItemNBT());
|
||||||
|
}
|
||||||
|
compound.set("Items", itemList);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void read(@NotNull NBTCompound nbtCompound) {
|
||||||
|
if (nbtCompound.containsKey("Items")) {
|
||||||
|
final NBTList<NBTCompound> items = nbtCompound.getList("Items");
|
||||||
|
for (NBTCompound item : items) {
|
||||||
|
this.items.add(ItemStack.fromItemNBT(item));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected @NotNull Supplier<@NotNull ItemMetaBuilder> getSupplier() {
|
||||||
|
return Builder::new;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
@ -29,6 +29,7 @@ import net.minestom.server.inventory.Inventory;
|
|||||||
import net.minestom.server.inventory.InventoryType;
|
import net.minestom.server.inventory.InventoryType;
|
||||||
import net.minestom.server.item.ItemStack;
|
import net.minestom.server.item.ItemStack;
|
||||||
import net.minestom.server.item.Material;
|
import net.minestom.server.item.Material;
|
||||||
|
import net.minestom.server.item.metadata.BundleMeta;
|
||||||
import net.minestom.server.monitoring.BenchmarkManager;
|
import net.minestom.server.monitoring.BenchmarkManager;
|
||||||
import net.minestom.server.monitoring.TickMonitor;
|
import net.minestom.server.monitoring.TickMonitor;
|
||||||
import net.minestom.server.utils.MathUtils;
|
import net.minestom.server.utils.MathUtils;
|
||||||
@ -104,6 +105,14 @@ public class PlayerInit {
|
|||||||
.canDestroy(Set.of(Block.DIAMOND_ORE)))
|
.canDestroy(Set.of(Block.DIAMOND_ORE)))
|
||||||
.build();
|
.build();
|
||||||
player.getInventory().addItemStack(itemStack);
|
player.getInventory().addItemStack(itemStack);
|
||||||
|
|
||||||
|
ItemStack bundle = ItemStack.builder(Material.BUNDLE)
|
||||||
|
.meta(BundleMeta.class, bundleMetaBuilder -> {
|
||||||
|
bundleMetaBuilder.addItem(ItemStack.of(Material.DIAMOND, 5));
|
||||||
|
bundleMetaBuilder.addItem(ItemStack.of(Material.RABBIT_FOOT, 5));
|
||||||
|
})
|
||||||
|
.build();
|
||||||
|
player.getInventory().addItemStack(bundle);
|
||||||
});
|
});
|
||||||
|
|
||||||
static {
|
static {
|
||||||
|
Loading…
Reference in New Issue
Block a user