因此,我需要使用InventoryClickEvent事件获取自定义库存中自定义项目的名称。我试图获取Item Meta,但它返回NullPointerException。所以,我做了一点if语句来处理点击没有Meta和If语句的项目。因此,即使项目具有传说和显示名称,该项目也没有项目元素。请注意,我没有多少处理库存,所以我对它有点新意。另外,我在另一个班级中设置了带有显示名称和传说的项目元素,但我认为这不会影响任何事情。这是我的InventoryClickEvent类的代码。
public class clickEvent implements Listener
{
private Files files = new Files();
private KitPvP kit = KitPvP.getInstance();
private Kit kits = new Kit();
private InvUtils invUtils = new InvUtils();
@EventHandler
public void onInventoryClick(InventoryClickEvent e)
{
HumanEntity player = e.getWhoClicked();
Inventory inv = e.getClickedInventory();
ItemStack item = e.getCurrentItem();
if (player instanceof Player)
{
if (inv != null && inv.getContents() != null && !inv.getContents().equals(Material.AIR) && inv.getName() != null && !inv.getName().equalsIgnoreCase(""))
{
String name = ChatColor.stripColor(inv.getName());
if (name.equalsIgnoreCase("Kits: ") || name.equalsIgnoreCase("Kits:"))
{
try
{
if (!kit.getDataFolder().exists())
{
kit.getDataFolder().mkdirs();
}
File kFolder = files.getFolder("Kits");
if (!kFolder.exists())
{
files.createFolder("Kits");
}
File menu = files.getFolder("GUI Menu");
if (!menu.exists())
{
files.createFolder("GUI Menu");
}
if (!e.getCursor().hasItemMeta())
{
Logger.log("Clicked Item does not have Item Meta!");
return;
}
if (!e.getCursor().getItemMeta().hasDisplayName())
{
Logger.log("Clicked Item does not have Display Name!");
return;
}
String check1Name = ChatColor.stripColor(e.getCursor().getItemMeta().getDisplayName());
String check2Name = check1Name.replace(" Kit", "");
File gItem = files.getGuiItem(check2Name);
if (!gItem.exists())
{
Logger.log("Cannot find required Files!");
return;
}
String itemName = gItem.getName();
if (itemName.equalsIgnoreCase(check2Name))
{
kits.equipKit(player, itemName);
e.setCancelled(true);
}
} catch (Exception ex)
{
ex.printStackTrace();
}
}
}
}
}
}
答案 0 :(得分:0)
由于需要信息,因此有点难以理解您的问题,但现在就去了。
1)我认为你使用你的事件来携带物品等,因此e.getCursor()
解析为Item
。您确定检索到的对象在创建时包含元,在事件中捆绑并传递吗?我的第一个问题是检查事件的发射器是否正在创建正确的信息。
2)在第一个if子句之前,你做e.getCurrentItem();
。这有点令人困惑,因为返回对象似乎是ItemStack
。应重新审视您的命名约定。其余代码也是如此。什么是ItemStack
对象持有,为什么不能从那里检索有问题的项目?
3)如#1中所述,检查事件的发射器正在做什么。很可能由于此而未发送ItemMeta
。
同样快速提示。避免像这样的长方法体。尝试将您的问题分解为较小的问题。这将使调试和维护过程变得更加容易。最后,避免按照您的方式对常量进行String
等式检查。而不是someVar.equals(" someConstant")到期" someConstant" .equals(someVar)。这是避免NPE的一个非常好的技巧。
答案 1 :(得分:0)
请使用此
if(e.getCurrentItem() != null && e.getCurrentItem().getType() == Material.INK_SACK){
String name = e.getCurrentItem().getItemMeta().getDisplayName();
}
将Material.INK_SACK替换为目标项
答案 2 :(得分:0)
像@Starmixcraft所说,用这个:
if(e.getCurrentItem() != null && e.getCurrentItem().getType() == Material.INK_SACK){
String name = e.getCurrentItem().getItemMeta().getDisplayName();
}
但是替换
e.getCurrentItem().getType() == Material.INK_SACK
与
e.getCurrentItem().getType().equals(Material.INK_SACK)