1
0
mirror of https://e.coding.net/circlecloud/MenuProtect.git synced 2025-11-24 21:46:11 +00:00

初始化项目...

Signed-off-by: 502647092 <jtb1@163.com>
This commit is contained in:
502647092
2015-11-30 16:11:21 +08:00
commit 026cd7a91f
9 changed files with 325 additions and 0 deletions

View File

@@ -0,0 +1,26 @@
package cn.citycraft.MenuProtect;
import org.bukkit.Bukkit;
import org.bukkit.plugin.PluginManager;
import org.bukkit.plugin.java.JavaPlugin;
import cn.citycraft.MenuProtect.listen.ProtectListener;
import cn.citycraft.MenuProtect.utils.MarkUtil;
import cn.citycraft.PluginHelper.config.FileConfig;
public class MenuProtect extends JavaPlugin {
FileConfig config;
@Override
public void onEnable() {
final PluginManager pm = Bukkit.getPluginManager();
pm.registerEvents(new ProtectListener(this), this);
this.getLogger().info("菜单物品保护已开启!");
}
@Override
public void onLoad() {
config = new FileConfig(this);
MarkUtil.marks = config.getStringList("MarkList");
}
}

View File

@@ -0,0 +1,81 @@
package cn.citycraft.MenuProtect.listen;
import org.bukkit.Bukkit;
import org.bukkit.Material;
import org.bukkit.entity.Player;
import org.bukkit.event.EventHandler;
import org.bukkit.event.Listener;
import org.bukkit.event.inventory.InventoryClickEvent;
import org.bukkit.event.inventory.InventoryPickupItemEvent;
import org.bukkit.event.player.PlayerItemHeldEvent;
import org.bukkit.event.player.PlayerPickupItemEvent;
import org.bukkit.inventory.Inventory;
import org.bukkit.inventory.ItemStack;
import org.bukkit.inventory.PlayerInventory;
import cn.citycraft.MenuProtect.MenuProtect;
import cn.citycraft.MenuProtect.utils.MarkUtil;
public class ProtectListener implements Listener {
private final MenuProtect plugin;
public ProtectListener(final MenuProtect plugin) {
this.plugin = plugin;
}
@EventHandler
public void onInvPickup(final InventoryPickupItemEvent e) {
final ItemStack ci = e.getItem().getItemStack();
if (MarkUtil.hasMark(ci)) {
e.setCancelled(true);
}
}
@EventHandler
public void onItemClick(final InventoryClickEvent e) {
final Player p = (Player) e.getWhoClicked();
final ItemStack ci = e.getCurrentItem();
final Inventory inv = e.getInventory();
final int solt = e.getSlot();
try {
if (MarkUtil.hasMark(ci)) {
inv.setItem(solt, new ItemStack(Material.AIR));
p.closeInventory();
}
} catch (final Exception ex) {
}
}
@EventHandler
public void onPlayerHandlerItem(final PlayerItemHeldEvent e) {
Bukkit.getScheduler().runTaskAsynchronously(plugin, new Runnable() {
@Override
public void run() {
final Player p = e.getPlayer();
final PlayerInventory inv = p.getInventory();
final ItemStack[] cis = inv.getArmorContents();
for (int i = 0; i < cis.length; i++) {
final ItemStack itemStack = cis[i];
if (MarkUtil.hasMark(itemStack)) {
cis[i] = new ItemStack(Material.AIR);
}
}
inv.setArmorContents(cis);
final int newslot = e.getNewSlot();
final ItemStack newItem = inv.getItem(newslot);
if (MarkUtil.hasMark(newItem)) {
inv.setItem(newslot, new ItemStack(Material.AIR));
}
}
});
}
@EventHandler
public void onPlayerPickup(final PlayerPickupItemEvent e) {
final ItemStack ci = e.getItem().getItemStack();
if (MarkUtil.hasMark(ci)) {
e.setCancelled(true);
}
}
}

View File

@@ -0,0 +1,22 @@
package cn.citycraft.MenuProtect.utils;
import java.util.List;
import org.bukkit.inventory.ItemStack;
public class MarkUtil {
public static List<String> marks = null;
public static boolean hasMark(final ItemStack ci) {
try {
for (final String mark : marks) {
if (ci.getItemMeta().getDisplayName().startsWith(mark)) {
return true;
}
}
return false;
} catch (final Exception e) {
return false;
}
}
}

View File

@@ -0,0 +1,3 @@
MarkList:
- '§m§p§r'
- '§q§s§6[§b快捷商店§6] §c悬浮物品§r'

View File

@@ -0,0 +1,16 @@
name: ${project.artifactId}
description: ${project.description}
main: ${project.groupId}.${project.artifactId}.${project.artifactId}
version: ${project.version}-Build#${env.BUILD_NUMBER}
author: 喵♂呜
website: ${jenkins.url}/job/${project.artifactId}/
commands:
${project.artifactId}:
description: ${project.artifactId}
usage: §b使用/${project.artifactId} help 查看帮助!
permission: ${project.artifactId}.reload
permission-message: §c你没有 <permission> 的权限来执行此命令!
permissions:
${project.artifactId}.reload:
description: 重新载入插件!
default: op