forked from circlecloud/MiaoChat
feat: 优化代码
Signed-off-by: 502647092 <admin@yumc.pw>
This commit is contained in:
parent
e85f69e03a
commit
938bc2d03a
Binary file not shown.
@ -1,12 +1,13 @@
|
|||||||
package pw.yumc.MiaoChat.config;
|
package pw.yumc.MiaoChat.config;
|
||||||
|
|
||||||
|
import java.util.*;
|
||||||
|
|
||||||
import org.bukkit.entity.Player;
|
import org.bukkit.entity.Player;
|
||||||
|
|
||||||
import pw.yumc.YumCore.bukkit.Log;
|
import pw.yumc.YumCore.bukkit.Log;
|
||||||
import pw.yumc.YumCore.bukkit.P;
|
import pw.yumc.YumCore.bukkit.P;
|
||||||
import pw.yumc.YumCore.config.FileConfig;
|
import pw.yumc.YumCore.config.FileConfig;
|
||||||
|
|
||||||
import java.util.*;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*
|
*
|
||||||
* @since 2016年9月9日 下午4:40:50
|
* @since 2016年9月9日 下午4:40:50
|
||||||
@ -52,8 +53,8 @@ public class ChatConfig {
|
|||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
public ChatMessagePart getFormat(String name) {
|
public Map<String, ChatMessagePart> getFormats() {
|
||||||
return formats.get(name);
|
return formats;
|
||||||
}
|
}
|
||||||
|
|
||||||
public void load() {
|
public void load() {
|
||||||
|
@ -8,8 +8,12 @@ import org.bukkit.ChatColor;
|
|||||||
import org.bukkit.configuration.ConfigurationSection;
|
import org.bukkit.configuration.ConfigurationSection;
|
||||||
import org.bukkit.entity.Player;
|
import org.bukkit.entity.Player;
|
||||||
|
|
||||||
|
import me.clip.placeholderapi.PlaceholderAPI;
|
||||||
|
import pw.yumc.MiaoChat.MiaoChat;
|
||||||
|
import pw.yumc.YumCore.bukkit.P;
|
||||||
import pw.yumc.YumCore.config.annotation.Default;
|
import pw.yumc.YumCore.config.annotation.Default;
|
||||||
import pw.yumc.YumCore.config.inject.InjectConfigurationSection;
|
import pw.yumc.YumCore.config.inject.InjectConfigurationSection;
|
||||||
|
import pw.yumc.YumCore.tellraw.Tellraw;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 聊天规则
|
* 聊天规则
|
||||||
@ -18,6 +22,8 @@ import pw.yumc.YumCore.config.inject.InjectConfigurationSection;
|
|||||||
* @author 喵♂呜
|
* @author 喵♂呜
|
||||||
*/
|
*/
|
||||||
public class ChatRule extends InjectConfigurationSection {
|
public class ChatRule extends InjectConfigurationSection {
|
||||||
|
private transient static MiaoChat plugin = P.getPlugin();
|
||||||
|
private transient static ChatConfig cc = plugin.getChatConfig();
|
||||||
private transient static Pattern FORMAT_PATTERN = Pattern.compile("[\\[]([^\\[\\]]+)[]]");
|
private transient static Pattern FORMAT_PATTERN = Pattern.compile("[\\[]([^\\[\\]]+)[]]");
|
||||||
private transient String name;
|
private transient String name;
|
||||||
@Default("50")
|
@Default("50")
|
||||||
@ -88,6 +94,21 @@ public class ChatRule extends InjectConfigurationSection {
|
|||||||
return item;
|
return item;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public Tellraw create(Player p) {
|
||||||
|
Tellraw tr = Tellraw.create();
|
||||||
|
for (String format : formats) {
|
||||||
|
ChatMessagePart cmp = cc.getFormats().get(format);
|
||||||
|
if (cmp != null) {
|
||||||
|
// Log.d("解析格式: %s", format);
|
||||||
|
cmp.then(tr, p);
|
||||||
|
} else {
|
||||||
|
// Log.d("追加文本: %s", format);
|
||||||
|
tr.then(PlaceholderAPI.setPlaceholders(p, format));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return tr;
|
||||||
|
}
|
||||||
|
|
||||||
private void load() {
|
private void load() {
|
||||||
formats = new LinkedList<>();
|
formats = new LinkedList<>();
|
||||||
Matcher m = FORMAT_PATTERN.matcher(format);
|
Matcher m = FORMAT_PATTERN.matcher(format);
|
||||||
|
@ -15,11 +15,9 @@ import org.bukkit.event.Listener;
|
|||||||
import org.bukkit.event.player.AsyncPlayerChatEvent;
|
import org.bukkit.event.player.AsyncPlayerChatEvent;
|
||||||
import org.bukkit.inventory.ItemStack;
|
import org.bukkit.inventory.ItemStack;
|
||||||
|
|
||||||
import me.clip.placeholderapi.PlaceholderAPI;
|
|
||||||
import pw.yumc.MiaoChat.MiaoChat;
|
import pw.yumc.MiaoChat.MiaoChat;
|
||||||
import pw.yumc.MiaoChat.MiaoMessage;
|
import pw.yumc.MiaoChat.MiaoMessage;
|
||||||
import pw.yumc.MiaoChat.config.ChatConfig;
|
import pw.yumc.MiaoChat.config.ChatConfig;
|
||||||
import pw.yumc.MiaoChat.config.ChatMessagePart;
|
|
||||||
import pw.yumc.MiaoChat.config.ChatRule;
|
import pw.yumc.MiaoChat.config.ChatRule;
|
||||||
import pw.yumc.YumCore.bukkit.Log;
|
import pw.yumc.YumCore.bukkit.Log;
|
||||||
import pw.yumc.YumCore.bukkit.P;
|
import pw.yumc.YumCore.bukkit.P;
|
||||||
@ -53,30 +51,12 @@ public class ChatListener implements Listener {
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
e.setCancelled(true);
|
e.setCancelled(true);
|
||||||
handleChat(p, Tellraw.create(), cr, e.getMessage());
|
handleChat(p, cr, e.getMessage());
|
||||||
}
|
}
|
||||||
|
|
||||||
private void handleChat(Player p, Tellraw tr, ChatRule cr, String message) {
|
private void handleChat(Player p, ChatRule cr, String message) {
|
||||||
// Log.d("玩家: %s 使用 %s 规则 解析 %s", p.getName(), cr.getName(), message);
|
// Log.d("玩家: %s 使用 %s 规则 解析 %s", p.getName(), cr.getName(), message);
|
||||||
handleFormat(p, tr, cr);
|
handleSend(p, handleTellraw(p, cr.create(p), cr, message), cr.getRange());
|
||||||
handleTellraw(p, tr, cr, message);
|
|
||||||
handleSend(p, tr, cr.getRange());
|
|
||||||
}
|
|
||||||
|
|
||||||
private String handleFormat(Player p, Tellraw tr, ChatRule cr) {
|
|
||||||
LinkedList<String> formats = cr.getFormats();
|
|
||||||
// Log.d("处理前缀信息...");
|
|
||||||
for (String format : formats) {
|
|
||||||
ChatMessagePart cmp = cc.getFormat(format);
|
|
||||||
if (cmp != null) {
|
|
||||||
// Log.d("解析格式: %s", format);
|
|
||||||
cmp.then(tr, p);
|
|
||||||
} else {
|
|
||||||
// Log.d("追加文本: %s", format);
|
|
||||||
tr.then(PlaceholderAPI.setPlaceholders(p, format));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return ChatColor.getLastColors(formats.isEmpty() ? "§r" : formats.getLast());
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private LinkedList<String> handleMessage(LinkedList<String> il, String message) {
|
private LinkedList<String> handleMessage(LinkedList<String> il, String message) {
|
||||||
@ -121,12 +101,16 @@ public class ChatListener implements Listener {
|
|||||||
}
|
}
|
||||||
|
|
||||||
private void handleSend(Player p, Tellraw tr, int range) {
|
private void handleSend(Player p, Tellraw tr, int range) {
|
||||||
Collection<? extends Entity> plist;
|
List<Player> plist = new ArrayList<>();
|
||||||
if (range != 0) {
|
if (range != 0) {
|
||||||
plist = p.getNearbyEntities(range, range, range);
|
for (Entity ent : p.getNearbyEntities(range, range, range)) {
|
||||||
tr.send(p);
|
if (ent instanceof Player) {
|
||||||
|
plist.add((Player) ent);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
plist.add(p);
|
||||||
} else {
|
} else {
|
||||||
plist = C.Player.getOnlinePlayers();
|
plist.addAll(C.Player.getOnlinePlayers());
|
||||||
if (cc.isBungeeCord()) {
|
if (cc.isBungeeCord()) {
|
||||||
byte[] mm = MiaoMessage.encode(tr.toJsonString());
|
byte[] mm = MiaoMessage.encode(tr.toJsonString());
|
||||||
if (mm == null) {
|
if (mm == null) {
|
||||||
@ -136,29 +120,28 @@ public class ChatListener implements Listener {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
for (Entity ne : plist) {
|
for (Player player : plist) {
|
||||||
// 此处必须进行强制转换 老版本服务器的Entity没有getName()
|
if (!offList.contains(player.getName())) {
|
||||||
if (ne instanceof Player && !offList.contains(((Player) ne).getName())) {
|
tr.send(player);
|
||||||
tr.send(ne);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
Bukkit.getConsoleSender().sendMessage(tr.toOldMessageFormat());
|
Bukkit.getConsoleSender().sendMessage(tr.toOldMessageFormat());
|
||||||
}
|
}
|
||||||
|
|
||||||
private void handleTellraw(Player player, Tellraw tr, ChatRule cr, String message) {
|
private Tellraw handleTellraw(Player player, Tellraw tr, ChatRule cr, String message) {
|
||||||
if (message.isEmpty()) { return; }
|
if (message.isEmpty()) { return tr; }
|
||||||
if (player.hasPermission("MiaoChat.color")) {
|
if (player.hasPermission("MiaoChat.color")) {
|
||||||
message = ChatColor.translateAlternateColorCodes('&', message);
|
message = ChatColor.translateAlternateColorCodes('&', message);
|
||||||
}
|
}
|
||||||
if (!cr.isItem()) {
|
if (!cr.isItem()) {
|
||||||
tr.then(message);
|
tr.then(message);
|
||||||
return;
|
return tr;
|
||||||
}
|
}
|
||||||
LinkedList<String> il = handlePattern(message);
|
LinkedList<String> il = handlePattern(message);
|
||||||
// 如果返回null说明存在相同的物品
|
// 如果返回null说明存在相同的物品
|
||||||
if (il == null) {
|
if (il == null) {
|
||||||
Log.sender(player, "§c不允许展示相同的物品!");
|
Log.sender(player, "§c不允许展示相同的物品!");
|
||||||
return;
|
return tr;
|
||||||
}
|
}
|
||||||
LinkedList<String> ml = handleMessage(il, message);
|
LinkedList<String> ml = handleMessage(il, message);
|
||||||
// Log.d("处理Tellraw格式...");
|
// Log.d("处理Tellraw格式...");
|
||||||
@ -177,5 +160,6 @@ public class ChatListener implements Listener {
|
|||||||
tr.then(cr.getLastColor() + mm);
|
tr.then(cr.getLastColor() + mm);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
return tr;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user