Fixed & enhanced GUI API (blame @IamBlueSlime for bugs).

* NEW: Added another onClick signature with the full event as the last parameter.
* NEW: Added a new method triggered when an item is dropped in the inventory GUI (`onItemDeposit`), with various signatures.
* BUG: Click triggered on click on a slot with the same raw number on the player inventory (out of the GUI).
* BUG: Fixed items ate by the GUI when dragged on it by cancelling all drags on managed inventories.
This commit is contained in:
Amaury Carrade 2015-07-10 12:12:13 +02:00
parent 26d28787be
commit 0a79eee89b
2 changed files with 56 additions and 9 deletions

View File

@ -28,7 +28,7 @@ import java.util.*;
/** /**
* @author IamBlueSlime * @author IamBlueSlime, Amaury Carrade
*/ */
public abstract class AbstractGui { public abstract class AbstractGui {
protected TreeMap<Integer, String> actions = new TreeMap<>(); protected TreeMap<Integer, String> actions = new TreeMap<>();
@ -40,6 +40,11 @@ public abstract class AbstractGui {
public void onClose(Player player) {} public void onClose(Player player) {}
public void onClick(Player player, ItemStack stack, String action, ClickType clickType, InventoryClickEvent event)
{
this.onClick(player, stack, action, clickType);
}
public void onClick(Player player, ItemStack stack, String action, ClickType clickType) public void onClick(Player player, ItemStack stack, String action, ClickType clickType)
{ {
this.onClick(player, stack, action); this.onClick(player, stack, action);
@ -47,7 +52,22 @@ public abstract class AbstractGui {
public void onClick(Player player, ItemStack stack, String action) {} public void onClick(Player player, ItemStack stack, String action) {}
public void setSlotData(Inventory inv, String name, Material material, int slot, String[] description, String action) {
public void onItemDeposit(Player player, ItemStack stack, ClickType clickType, InventoryClickEvent event)
{
onItemDeposit(player, stack, clickType);
}
public void onItemDeposit(Player player, ItemStack stack, ClickType clickType)
{
onItemDeposit(player, stack);
}
public void onItemDeposit(Player player, ItemStack stack) {}
public void setSlotData(Inventory inv, String name, Material material, int slot, String[] description, String action)
{
this.setSlotData(inv, name, new ItemStack(material, 1), slot, description, action); this.setSlotData(inv, name, new ItemStack(material, 1), slot, description, action);
} }

View File

@ -19,6 +19,7 @@
package fr.moribus.imageonmap.gui.core; package fr.moribus.imageonmap.gui.core;
import fr.moribus.imageonmap.*; import fr.moribus.imageonmap.*;
import org.bukkit.*;
import org.bukkit.entity.*; import org.bukkit.entity.*;
import org.bukkit.event.*; import org.bukkit.event.*;
import org.bukkit.event.inventory.*; import org.bukkit.event.inventory.*;
@ -26,7 +27,7 @@ import org.bukkit.inventory.*;
/** /**
* @author IamBlueSlime * @author IamBlueSlime, Amaury Carrade
* *
* Changes by Amaury Carrade to use statics (beh, code style, these things). * Changes by Amaury Carrade to use statics (beh, code style, these things).
*/ */
@ -40,24 +41,50 @@ public class GuiListener implements Listener {
@EventHandler @EventHandler
public void onInventoryClick(InventoryClickEvent event) public void onInventoryClick(InventoryClickEvent event)
{ {
if (event.getWhoClicked() instanceof Player) { if (event.getWhoClicked() instanceof Player)
{
Player player = (Player) event.getWhoClicked(); Player player = (Player) event.getWhoClicked();
AbstractGui gui = GuiManager.getPlayerGui(player); AbstractGui gui = GuiManager.getPlayerGui(player);
if (gui != null) { if (gui != null)
{
if (event.getInventory() instanceof PlayerInventory) if (event.getInventory() instanceof PlayerInventory)
return; return;
String action = gui.getAction(event.getSlot()); if(event.getRawSlot() == event.getSlot()) // Chest inventory, not player one
{
if (action != null) if(event.getCursor() != null && event.getCursor().getType() != Material.AIR)
gui.onClick(player, event.getCurrentItem(), action, event.getClick()); {
gui.onItemDeposit(player, event.getCursor(), event.getClick(), event);
}
event.setCancelled(true); else
{
String action = gui.getAction(event.getSlot());
if (action != null)
gui.onClick(player, event.getCurrentItem(), action, event.getClick(), event);
}
event.setCancelled(true);
}
} }
} }
} }
@EventHandler
public void onInventoryDrag(InventoryDragEvent event)
{
Player player = (Player) event.getWhoClicked();
AbstractGui gui = GuiManager.getPlayerGui(player);
if (gui != null)
{
event.setCancelled(true);
}
}
@EventHandler @EventHandler
public void onInventoryClose(InventoryCloseEvent event) public void onInventoryClose(InventoryCloseEvent event)
{ {