command handler optimizations
This commit is contained in:
@@ -128,11 +128,13 @@ public class Bot extends EntityPlayer {
|
||||
groundTicks = 0;
|
||||
}
|
||||
|
||||
Player botPlayer = getBukkitEntity();
|
||||
if (botPlayer.isDead()) return;
|
||||
Player player = getBukkitEntity();
|
||||
if (player.isDead()) return;
|
||||
|
||||
double health = botPlayer.getHealth();
|
||||
double maxHealth = botPlayer.getHealthScale();
|
||||
updateLocation();
|
||||
|
||||
double health = player.getHealth();
|
||||
double maxHealth = player.getHealthScale();
|
||||
double amount;
|
||||
|
||||
if (health < maxHealth - regenAmount) {
|
||||
@@ -141,9 +143,7 @@ public class Bot extends EntityPlayer {
|
||||
amount = maxHealth;
|
||||
}
|
||||
|
||||
botPlayer.setHealth(amount);
|
||||
|
||||
updateLocation();
|
||||
player.setHealth(amount);
|
||||
}
|
||||
|
||||
private void updateLocation() {
|
||||
@@ -182,10 +182,7 @@ public class Bot extends EntityPlayer {
|
||||
}
|
||||
|
||||
public void punch() {
|
||||
PacketPlayOutAnimation packet = new PacketPlayOutAnimation(this, 0);
|
||||
for (Player player : Bukkit.getOnlinePlayers()) {
|
||||
((CraftPlayer) player).getHandle().playerConnection.sendPacket(packet);
|
||||
}
|
||||
swingHand(EnumHand.MAIN_HAND);
|
||||
}
|
||||
|
||||
@Override
|
||||
@@ -293,8 +290,10 @@ public class Bot extends EntityPlayer {
|
||||
}
|
||||
|
||||
private void kb(Location loc1, Location loc2) {
|
||||
Vector diff = loc1.toVector().subtract(loc2.toVector()).normalize().setY(kbUp);
|
||||
Vector vel = velocity.clone().add(diff).multiply(0.5);
|
||||
double f = 4;
|
||||
|
||||
Vector diff = loc1.toVector().subtract(loc2.toVector()).setY(0).normalize().multiply(f).setY(kbUp);
|
||||
Vector vel = velocity.clone().add(diff).multiply(0.3 / f);
|
||||
|
||||
if (vel.length() > 1) vel.normalize();
|
||||
if (groundTicks != 0) vel.multiply(0.8).setY(0.4);
|
||||
|
||||
@@ -3,6 +3,7 @@ package net.nuggetmc.ai.bot.agent;
|
||||
import net.nuggetmc.ai.PlayerAI;
|
||||
import net.nuggetmc.ai.bot.Bot;
|
||||
import net.nuggetmc.ai.bot.BotManager;
|
||||
import net.nuggetmc.ai.utils.MathUtils;
|
||||
import net.nuggetmc.ai.utils.PlayerUtils;
|
||||
import org.bukkit.Bukkit;
|
||||
import org.bukkit.Location;
|
||||
@@ -91,7 +92,7 @@ public class BotAgent {
|
||||
vel.checkFinite();
|
||||
vel.add(bot.velocity);
|
||||
} catch (IllegalArgumentException e) {
|
||||
vel = new Vector(0, 0.5, 0);
|
||||
return;
|
||||
}
|
||||
|
||||
if (vel.length() > 1) vel.normalize();
|
||||
|
||||
@@ -9,7 +9,10 @@ import net.nuggetmc.ai.command.commands.PlayerAICommand;
|
||||
import org.bukkit.ChatColor;
|
||||
|
||||
import java.lang.reflect.Method;
|
||||
import java.util.*;
|
||||
import java.util.Arrays;
|
||||
import java.util.HashMap;
|
||||
import java.util.List;
|
||||
import java.util.Map;
|
||||
import java.util.stream.Collectors;
|
||||
|
||||
public class CommandHandler {
|
||||
@@ -19,7 +22,7 @@ public class CommandHandler {
|
||||
|
||||
public CommandHandler(PlayerAI plugin) {
|
||||
drink = (DrinkCommandService) Drink.get(plugin);
|
||||
drink.register(new PlayerAICommand(this), "bot", "playerai", "pai", "ai", "npc");
|
||||
drink.register(new PlayerAICommand(this), "playerai.manage", "bot", "playerai", "pai", "ai", "npc");
|
||||
drink.registerCommands();
|
||||
|
||||
help = new HashMap<>();
|
||||
|
||||
@@ -26,42 +26,56 @@ public class PlayerAICommand extends CommandInstance {
|
||||
this.manager = plugin.getManager();
|
||||
}
|
||||
|
||||
@Command(name = "", desc = "The PlayerAI main command.")
|
||||
@Require("playerai.manage")
|
||||
public void rootCommand(@Sender Player sender) {
|
||||
@Command(
|
||||
desc = "The PlayerAI main command."
|
||||
)
|
||||
public void root(@Sender Player sender) {
|
||||
sender.sendMessage(ChatUtils.LINE);
|
||||
sender.sendMessage(ChatColor.GOLD + "PlayerAI" + ChatColor.GRAY + " [" + ChatColor.RED + "v" + PlayerAI.VERSION + ChatColor.GRAY + "]");
|
||||
commandHandler.getHelp(getClass()).forEach(sender::sendMessage);
|
||||
sender.sendMessage(ChatUtils.LINE);
|
||||
}
|
||||
|
||||
@Command(name = "create", desc = "Create bots.", usage = "<name> [skin]")
|
||||
@Require("playerai.manage")
|
||||
public void createBotCommand(@Sender Player sender, String name, @OptArg String skin) {
|
||||
@Command(
|
||||
name = "create",
|
||||
desc = "Create bots.",
|
||||
usage = "<name> [skin]"
|
||||
)
|
||||
public void create(@Sender Player sender, String name, @OptArg String skin) {
|
||||
manager.createBots(sender, name, skin, 1);
|
||||
}
|
||||
|
||||
@Command(name = "multi", desc = "Create multiple bots at once.", usage = "<amount> <name> [skin]")
|
||||
@Require("playerai.manage")
|
||||
public void multiBotCommand(@Sender Player sender, int n, String name, @OptArg String skin) {
|
||||
@Command(
|
||||
name = "multi",
|
||||
desc = "Create multiple bots at once.",
|
||||
usage = "<amount> <name> [skin]"
|
||||
)
|
||||
public void multi(@Sender Player sender, int n, String name, @OptArg String skin) {
|
||||
manager.createBots(sender, name, skin, n);
|
||||
}
|
||||
|
||||
@Command(name = "debug", desc = "Debug plugin code.", usage = "<expression>")
|
||||
@Require("playerai.manage")
|
||||
public void debugCommand(@Sender CommandSender sender, @Text String cmd) {
|
||||
@Command(
|
||||
name = "debug",
|
||||
desc = "Debug plugin code.",
|
||||
usage = "<expression>"
|
||||
)
|
||||
public void debug(@Sender CommandSender sender, @Text String cmd) {
|
||||
new Debugger(sender).execute(cmd);
|
||||
}
|
||||
|
||||
@Command(name = "info", desc = "Information about loaded bots.")
|
||||
@Require("playerai.manage")
|
||||
public void infoCommand(@Sender Player sender) {
|
||||
sender.sendMessage("Bot GUI coming soon!");
|
||||
@Command(
|
||||
name = "info",
|
||||
desc = "Information about loaded bots."
|
||||
)
|
||||
public void info(@Sender Player sender) {
|
||||
sender.sendMessage(ChatColor.YELLOW + "Bot GUI coming soon!");
|
||||
}
|
||||
|
||||
@Command(name = "reset", desc = "Remove all loaded bots.")
|
||||
@Require("playerai.manage")
|
||||
public void resetCommand(@Sender CommandSender sender) {
|
||||
@Command(
|
||||
name = "reset",
|
||||
desc = "Remove all loaded bots."
|
||||
)
|
||||
public void reset(@Sender CommandSender sender) {
|
||||
sender.sendMessage("Removing every bot...");
|
||||
|
||||
BotManager manager = PlayerAI.getInstance().getManager();
|
||||
|
||||
@@ -36,4 +36,13 @@ public class MathUtils {
|
||||
|
||||
return new Vector(x, 0, z);
|
||||
}
|
||||
|
||||
public static boolean isFinite(Vector vector) {
|
||||
try {
|
||||
vector.checkFinite();
|
||||
return true;
|
||||
} catch (IllegalArgumentException e) {
|
||||
return false;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@@ -23,7 +23,7 @@ public class MojangAPI {
|
||||
return values;
|
||||
}
|
||||
|
||||
// CATCHING NULLPOINTEREXCEPTION BAD!!!! eventually fix from the getAsJsonObject thingy
|
||||
// CATCHING NULL ILLEGALSTATEEXCEPTION BAD!!!! eventually fix from the getAsJsonObject thingy
|
||||
public static String[] pullFromAPI(String name) {
|
||||
try {
|
||||
String uuid = new JsonParser().parse(new InputStreamReader(new URL("https://api.mojang.com/users/profiles/minecraft/" + name)
|
||||
|
||||
Reference in New Issue
Block a user