Clean up Util

This commit is contained in:
fullwall 2022-04-19 15:33:52 +08:00
parent f358f6fb2e
commit e88a7b6278
3 changed files with 33 additions and 76 deletions

View File

@ -84,10 +84,10 @@ public class SkinUpdateTracker {
double deltaX = skinLoc.getX() - playerLoc.getX(); double deltaX = skinLoc.getX() - playerLoc.getX();
double deltaZ = skinLoc.getZ() - playerLoc.getZ(); double deltaZ = skinLoc.getZ() - playerLoc.getZ();
double angle = Math.atan2(deltaX, deltaZ); double angle = Math.atan2(deltaX, deltaZ);
float skinYaw = Util.clampYaw(-(float) Math.toDegrees(angle)); float skinYaw = Util.clamp(-(float) Math.toDegrees(angle));
float playerYaw = Util.clampYaw(playerLoc.getYaw()); float playerYaw = Util.clamp(playerLoc.getYaw());
float upperBound = Util.clampYaw(playerYaw + FIELD_OF_VIEW); float upperBound = Util.clamp(playerYaw + FIELD_OF_VIEW);
float lowerBound = Util.clampYaw(playerYaw - FIELD_OF_VIEW); float lowerBound = Util.clamp(playerYaw - FIELD_OF_VIEW);
if (upperBound == -180.0 && playerYaw > 0) { if (upperBound == -180.0 && playerYaw > 0) {
upperBound = 0; upperBound = 0;
} }
@ -404,10 +404,10 @@ public class SkinUpdateTracker {
player.getLocation(this.location); player.getLocation(this.location);
if (rotationCount < 3) { if (rotationCount < 3) {
float rotationDegrees = Setting.NPC_SKIN_ROTATION_UPDATE_DEGREES.asFloat(); float rotationDegrees = Setting.NPC_SKIN_ROTATION_UPDATE_DEGREES.asFloat();
float yaw = Util.clampYaw(this.location.getYaw()); float yaw = Util.clamp(this.location.getYaw());
this.startYaw = yaw; this.startYaw = yaw;
this.upperBound = Util.clampYaw(yaw + rotationDegrees); this.upperBound = Util.clamp(yaw + rotationDegrees);
this.lowerBound = Util.clampYaw(yaw - rotationDegrees); this.lowerBound = Util.clamp(yaw - rotationDegrees);
if (upperBound == -180.0 && startYaw > 0) { if (upperBound == -180.0 && startYaw > 0) {
upperBound = 0; upperBound = 0;
} }
@ -423,7 +423,7 @@ public class SkinUpdateTracker {
} }
if (rotationCount < 3) { if (rotationCount < 3) {
float yaw = Util.clampYaw(currentLoc.getYaw()); float yaw = Util.clamp(currentLoc.getYaw());
boolean hasRotated; boolean hasRotated;
if (startYaw - 90 < -180 || startYaw + 90 > 180) { if (startYaw - 90 < -180 || startYaw + 90 > 180) {
hasRotated = yaw > lowerBound && yaw < upperBound; hasRotated = yaw > lowerBound && yaw < upperBound;

View File

@ -64,7 +64,7 @@ public class Poses extends Trait {
if (!npc.isSpawned()) { if (!npc.isSpawned()) {
npc.spawn(npc.getOrAddTrait(CurrentLocation.class).getLocation(), SpawnReason.COMMAND); npc.spawn(npc.getOrAddTrait(CurrentLocation.class).getLocation(), SpawnReason.COMMAND);
} }
Util.assumePose(npc.getEntity(), yaw, pitch); Util.setRotation(npc.getEntity(), yaw, pitch);
} }
/** /**

View File

@ -4,10 +4,8 @@ import java.util.EnumSet;
import java.util.Random; import java.util.Random;
import java.util.Set; import java.util.Set;
import java.util.UUID; import java.util.UUID;
import java.util.regex.Pattern;
import org.bukkit.Bukkit; import org.bukkit.Bukkit;
import org.bukkit.ChatColor;
import org.bukkit.Location; import org.bukkit.Location;
import org.bukkit.Material; import org.bukkit.Material;
import org.bukkit.block.Block; import org.bukkit.block.Block;
@ -33,14 +31,9 @@ import net.citizensnpcs.api.util.SpigotUtil;
import net.citizensnpcs.npc.ai.NPCHolder; import net.citizensnpcs.npc.ai.NPCHolder;
public class Util { public class Util {
// Static class for small (emphasis small) utility methods
private Util() { private Util() {
} }
public static void assumePose(Entity entity, float yaw, float pitch) {
NMS.look(entity, yaw, pitch);
}
public static void callCollisionEvent(NPC npc, Entity entity) { public static void callCollisionEvent(NPC npc, Entity entity) {
if (NPCCollisionEvent.getHandlerList().getRegisteredListeners().length > 0) { if (NPCCollisionEvent.getHandlerList().getRegisteredListeners().length > 0) {
Bukkit.getPluginManager().callEvent(new NPCCollisionEvent(npc, entity)); Bukkit.getPluginManager().callEvent(new NPCCollisionEvent(npc, entity));
@ -65,15 +58,18 @@ public class Util {
return !event.isCancelled() ? event.getCollisionVector() : null; return !event.isCancelled() ? event.getCollisionVector() : null;
} }
public static float clampYaw(float yaw) { /**
while (yaw < -180.0F) { * Clamps the rotation angle to [-180, 180]
yaw += 360.0F; */
public static float clamp(float angle) {
while (angle < -180.0F) {
angle += 360.0F;
} }
while (yaw >= 180.0F) { while (angle >= 180.0F) {
yaw -= 360.0F; angle -= 360.0F;
} }
return yaw; return angle;
} }
public static void face(Entity entity, float yaw, float pitch) { public static void face(Entity entity, float yaw, float pitch) {
@ -82,13 +78,13 @@ public class Util {
faceLocation(entity, entity.getLocation(AT_LOCATION).clone().add(vector)); faceLocation(entity, entity.getLocation(AT_LOCATION).clone().add(vector));
} }
public static void faceEntity(Entity entity, Entity at) { public static void faceEntity(Entity entity, Entity to) {
if (at == null || entity == null || entity.getWorld() != at.getWorld()) if (to == null || entity == null || entity.getWorld() != to.getWorld())
return; return;
if (at instanceof LivingEntity) { if (to instanceof LivingEntity) {
NMS.look(entity, at); NMS.look(entity, to);
} else { } else {
faceLocation(entity, at.getLocation(AT_LOCATION)); faceLocation(entity, to.getLocation(AT_LOCATION));
} }
} }
@ -124,7 +120,7 @@ public class Util {
} }
public static Location getCenterLocation(Block block) { public static Location getCenterLocation(Block block) {
Location bloc = block.getLocation(); Location bloc = block.getLocation(AT_LOCATION);
Location center = new Location(bloc.getWorld(), bloc.getBlockX() + 0.5, bloc.getBlockY(), Location center = new Location(bloc.getWorld(), bloc.getBlockX() + 0.5, bloc.getBlockY(),
bloc.getBlockZ() + 0.5); bloc.getBlockZ() + 0.5);
BoundingBox bb = NMS.getCollisionBox(block); BoundingBox bb = NMS.getCollisionBox(block);
@ -134,6 +130,9 @@ public class Util {
return center; return center;
} }
/**
* Returns the yaw to face along the given velocity (corrected for dragon yaw i.e. facing backwards)
*/
public static float getDragonYaw(Entity entity, double motX, double motZ) { public static float getDragonYaw(Entity entity, double motX, double motZ) {
Location location = entity.getLocation(AT_LOCATION); Location location = entity.getLocation(AT_LOCATION);
double x = location.getX(); double x = location.getX();
@ -250,7 +249,7 @@ public class Util {
return false; return false;
if (current.getWorld() != target.getWorld()) if (current.getWorld() != target.getWorld())
return false; return false;
return current.distanceSquared(target) <= Math.pow(range, 2); return current.distance(target) <= range;
} }
public static EntityType matchEntityType(String toMatch) { public static EntityType matchEntityType(String toMatch) {
@ -343,52 +342,11 @@ public class Util {
} }
} }
public static String[] splitPlayerName(String coloredName) { /**
String name = coloredName, prefix = null, suffix = null; * Sets the entity's yaw and pitch directly including head yaw.
if (coloredName.length() > 16) { */
if (coloredName.length() >= 30) { public static void setRotation(Entity entity, float yaw, float pitch) {
prefix = coloredName.substring(0, 16); NMS.look(entity, yaw, pitch);
int len = 30;
name = coloredName.substring(16, 30);
String prefixColors = ChatColor.getLastColors(prefix);
if (prefixColors.isEmpty()) {
if (NON_ALPHABET_MATCHER.matcher(name).matches()) {
if (coloredName.length() >= 32) {
len = 32;
name = coloredName.substring(16, 32);
} else if (coloredName.length() == 31) {
len = 31;
name = coloredName.substring(16, 31);
}
} else {
prefixColors = ChatColor.RESET.toString();
}
} else if (prefixColors.length() > 2) {
prefixColors = prefixColors.substring(prefixColors.length() - 2);
}
name = prefixColors + name;
suffix = coloredName.substring(len);
} else {
prefix = coloredName.substring(0, coloredName.length() - 16);
name = coloredName.substring(prefix.length());
if (prefix.endsWith(String.valueOf(ChatColor.COLOR_CHAR))) {
prefix = prefix.substring(0, prefix.length() - 1);
name = ChatColor.COLOR_CHAR + name;
}
String prefixColors = ChatColor.getLastColors(prefix);
if (prefixColors.isEmpty() && !NON_ALPHABET_MATCHER.matcher(name).matches()) {
prefixColors = ChatColor.RESET.toString();
} else if (prefixColors.length() > 2) {
prefixColors = prefixColors.substring(prefixColors.length() - 2);
}
name = prefixColors + name;
if (name.length() > 16) {
suffix = name.substring(16);
name = name.substring(0, 16);
}
}
}
return new String[] { name, prefix, suffix };
} }
public static void updateNPCTeams(Player toUpdate, int mode) { public static void updateNPCTeams(Player toUpdate, int mode) {
@ -407,5 +365,4 @@ public class Util {
private static final Location AT_LOCATION = new Location(null, 0, 0, 0); private static final Location AT_LOCATION = new Location(null, 0, 0, 0);
private static final Scoreboard DUMMY_SCOREBOARD = Bukkit.getScoreboardManager().getNewScoreboard(); private static final Scoreboard DUMMY_SCOREBOARD = Bukkit.getScoreboardManager().getNewScoreboard();
private static String MINECRAFT_REVISION; private static String MINECRAFT_REVISION;
private static final Pattern NON_ALPHABET_MATCHER = Pattern.compile(".*[^A-Za-z0-9_].*");
} }