not finished, tried to make entity with custom skin + bug patches

This commit is contained in:
unurled 2022-12-22 00:30:39 +01:00
parent 559bead7d8
commit b935c6fee6
25 changed files with 442 additions and 113 deletions

View file

@ -16,28 +16,22 @@ repositories {
maven {
url = uri('https://papermc.io/repo/repository/maven-public/')
}
maven {
url = uri('https://oss.sonatype.org/content/groups/public/')
}
maven {
name = 'CodeMC'
url = 'https://repo.codemc.org/repository/maven-public/'
}
maven {
url = uri('https://repo.dmulloy2.net/repository/public/')
}
maven {
url = uri('https://repo.essentialsx.net/releases/')
}
maven {
url = uri('https://s01.oss.sonatype.org/content/repositories/snapshots/')
}
maven {
url = uri('https://repo.maven.apache.org/maven2/')
}
@ -65,7 +59,7 @@ dependencies {
implementation 'org.mongodb:mongodb-driver-core:4.7.2'
implementation 'de.tr7zw:item-nbt-api-plugin:2.10.0'
compileOnly 'io.papermc.paper:paper-api:1.19.2-R0.1-SNAPSHOT'
compileOnly 'io.papermc.paper:paper-api:1.19.3-R0.1-SNAPSHOT'
compileOnly 'com.comphenix.protocol:ProtocolLib:4.8.0'
compileOnly 'net.luckperms:api:5.4'
compileOnly 'com.github.MilkBowl:VaultAPI:1.7.1'
@ -80,7 +74,7 @@ dependencies {
}
group = 'me.unurled'
version = '0.5.5'
version = '0.5.6'
description = 'Raxen'
java {

View file

@ -18,7 +18,7 @@ import static me.unurled.raxen.utils.Utils.colorComp;
public final class Raxen extends JavaPlugin {
private static final String prefix = "<aqua>Rx</aqua><light_purple>></light_purple> ";
@Getter private static String version = "0.5.5";
@Getter private static String version = "0.5.6";
private final PluginManager pm = getServer().getPluginManager();
private static Raxen plugin;

View file

@ -53,8 +53,8 @@ public class NbtCommand implements TabExecutor {
a = nbti.getInteger(args[1]);
}
List<Component> lore = new ArrayList<>();
ItemMeta itm = it.getItemMeta();
lore.add((Component) itm.lore());
// ItemMeta itm = it.getItemMeta();
// lore.add((Component) itm.lore());
boolean yes = false;
boolean ever = false;
for (Component ct : lore) {
@ -74,8 +74,8 @@ public class NbtCommand implements TabExecutor {
lore.add(colorTextComp("<red>Attributes:"));
//lore.add(colorTextComp(attributes(args[0]) + ": " + (Integer.parseInt(args[1]) + a))); deprecated
}
itm.lore(lore);
it.setItemMeta(itm);
// itm.lore(lore);
// it.setItemMeta(itm);
PlayerManager pm = ((Raxen) Objects.requireNonNull(Bukkit.getPluginManager().getPlugin("Raxen"))).getManager().getPlayerManager();
nbti.setInteger(args[0], Integer.parseInt(args[1]) + a);
if (nbti.hasKey("SPEED")) {

View file

@ -31,6 +31,14 @@ public class Attribute {
this.name = name;
}
/**
* gives the name uppercased
* @return the name in uppercase
*/
public String nameUppercase() {
return name.toUpperCase();
}
/**
* get how many the Entity has Attributed
* @param entity a living entity

View file

@ -4,10 +4,14 @@ import lombok.Getter;
import lombok.Setter;
import me.unurled.raxen.Raxen;
import java.util.UUID;
import static me.unurled.raxen.utils.Utils.colorString;
public class Entity {
private java.util.UUID uuid;
private final String name;
@Getter
private Integer level;
@ -38,6 +42,7 @@ public class Entity {
this.speed = speed;
this.maxHealth = maxHealth;
this.isHostile = isHostile;
this.uuid = UUID.randomUUID();
}
public void register (Raxen main) {

View file

@ -0,0 +1,15 @@
package me.unurled.raxen.components.entity.other.custom;
import java.util.UUID;
public class Humanoid extends Entity {
private String skin; // used to get the path to the skin
private UUID skinUuid; // used to get the player skin (if i do it this way...
public Humanoid(String name, Integer level, Double maxHealth, Double strength, Double defense, Double speed, boolean isHostile, String skin, UUID skinUuid) {
super(name, level, maxHealth, strength, defense, speed, isHostile);
this.skin = skin;
this.skinUuid = skinUuid;
}
}

View file

@ -68,8 +68,7 @@ public class RaxenPlayer {
PersistentDataContainer data = player.getPersistentDataContainer();
String inv = data.get(namespacedKey.inventory, PersistentDataType.STRING);
org.bukkit.inventory.Inventory invv = Bukkit.createInventory(player, InventoryType.PLAYER);
PlayerInventory invvvvv = (PlayerInventory) Bukkit.createInventory(null, InventoryType.PLAYER);
invv = setItemsToInventory(Items.listItemStackDeserialize(inv), invvvvv);
invv = setItemsToInventory(Items.listItemStackDeserialize(inv), (PlayerInventory) invv);
Inventory invvv = new Inventory(invv);
Inventories invvvv = new Inventories(invvv);
return invvvv;

View file

@ -6,6 +6,8 @@ import me.unurled.raxen.manager.entity.PlayerManager;
import org.bukkit.Bukkit;
import org.bukkit.entity.Entity;
import org.bukkit.entity.Player;
import org.jetbrains.annotations.Contract;
import org.jetbrains.annotations.NotNull;
public class Attributes {
@ -15,7 +17,8 @@ public class Attributes {
namespacedKey = new EntityNamespacedKey(main);
}
public static Attribute getAttribute(Player player) {
@Contract("_ -> new")
public static @NotNull Attribute getAttribute(Player player) {
int maxHealth, health, itemHealth, defense, itemDefense, speed, itemSpeed, strength, itemStrength, maxMana, mana, itemMana, luck, itemLuck;
PlayerManager pm = ((Raxen) Bukkit.getPluginManager().getPlugin("Raxen")).getManager().getPlayerManager();
Entity e = player;
@ -54,4 +57,9 @@ public class Attributes {
pm.getItemSpeed().set(e, itemSpeed);
pm.getItemMana().set(e, itemMana);
}
public static String[] getNameList() {
return new String[]{"Defense", "Health", "Luck", "Mana", "Speed", "Strength"};
}
}

View file

@ -1,7 +1,7 @@
package me.unurled.raxen.components.entity.player.classes.list;
import me.unurled.raxen.components.entity.player.classes.Class;
import me.unurled.raxen.components.items.custom.weapon.Dager;
import me.unurled.raxen.components.items.custom.weapon.Dagger;
import org.bukkit.Material;
import org.bukkit.inventory.ItemStack;
@ -16,9 +16,9 @@ public class Assassin extends Class {
public Assassin() {
super("Assassin", "<red>Assassin", "ASSASSIN", new ItemStack(Material.AIR), 100);
Dager dager = new Dager();
dager.buildItem();
placeHolder = dager.getDager();
Dagger dagger = new Dagger();
dagger.buildItem();
placeHolder = dagger.getItem();
}
public Assassin(String name, String colorName, String ID, String itemPlaceHolder, Integer max_level) {

View file

@ -3,8 +3,12 @@ package me.unurled.raxen.components.gui;
import lombok.Getter;
import me.unurled.raxen.Raxen;
import me.unurled.raxen.components.entity.player.PlayerUtils;
import me.unurled.raxen.utils.Utils;
import net.kyori.adventure.text.Component;
import net.kyori.adventure.text.TextComponent;
import net.kyori.adventure.text.serializer.legacy.LegacyComponentSerializer;
import org.bukkit.Bukkit;
import org.bukkit.ChatColor;
import org.bukkit.Material;
import org.bukkit.entity.Player;
import org.bukkit.event.EventHandler;
@ -163,7 +167,8 @@ public class ItemListGui implements Listener {
//previous
if (e.getCurrentItem() != GREY_PANE) {
ItemStack pagee = einv.getItem(49);
Integer page = Integer.parseInt(pagee.displayName().toString().replace("page", ""));
String name = ChatColor.stripColor(ChatColor.translateAlternateColorCodes('&',Utils.textCompToString(pagee.displayName())));
Integer page = Integer.parseInt(name.toString().replace("page", ""));
switch(page) {
case 2:
player.openInventory(inv);
@ -189,8 +194,13 @@ public class ItemListGui implements Listener {
} else if (slot == 50) {
//next
ItemStack pagee = einv.getItem(49);
Integer page = Integer.parseInt(pagee.displayName().toString().replace("page", ""));
switch(page) {
if (pagee != null) {
String name = ChatColor.stripColor(ChatColor.translateAlternateColorCodes('&',Utils.textCompToString(pagee.displayName())));
name = name.replace("[", "");
name = name.replace("]", "");
log(name);
Integer page = Integer.parseInt(name.replace("page", ""));
switch (page) {
case 1:
player.openInventory(inv2);
case 2:
@ -208,6 +218,7 @@ public class ItemListGui implements Listener {
case 8:
player.openInventory(inv9);
}
}
} else if (slot == 53) {
//close
player.closeInventory();

View file

@ -0,0 +1,47 @@
package me.unurled.raxen.components.items.abilities.weapon;
import me.unurled.raxen.utils.RayTrace;
import org.bukkit.Location;
import org.bukkit.Material;
import org.bukkit.block.Block;
import org.bukkit.entity.Player;
import org.bukkit.inventory.ItemStack;
import org.bukkit.util.BoundingBox;
import org.bukkit.util.Vector;
import java.util.ArrayList;
public class ThrowingDagger {
Player player;
ItemStack item;
Location start;
public ThrowingDagger(Player p) {
this.player = p;
this.item = p.getActiveItem();
this.start = p.getLocation();
}
public void throwDagger() {
// ability throw a dagger in the direction the player is looking, max 20 blocks
RayTrace rayTrace = new RayTrace(player.getEyeLocation().toVector(),player.getEyeLocation().getDirection());
ArrayList<Vector> positions = rayTrace.traverse(10,0.01);
for(int i = 0; i < positions.size();i++){
Location position = positions.get(i).toLocation(player.getWorld());
Block block = player.getWorld().getBlockAt(position);
if(block != null && block.getType() != Material.AIR && rayTrace.intersects(BoundingBox.of(block),10,0.01)){
player.sendMessage(block.getType().toString());
break;
}
}
/*for (int i = 0 ; i < 20 ; i++) {
// spawn an item in air
// dispawn the last one
// repeat
}*/
}
}

View file

@ -1,11 +1,32 @@
package me.unurled.raxen.components.items.custom;
import lombok.Getter;
import me.unurled.raxen.Raxen;
import org.bukkit.inventory.ItemStack;
import org.jetbrains.annotations.NotNull;
public interface Item {
public abstract class Item {
public void buildItem();
@Getter
ItemStack item;
public void registerItem(Raxen main);
String NAME;
String ID;
ItemClass ITEM_CLASS;
ItemTypes ITEM_TYPES;
protected Item() {
this.item = buildItem();
}
public abstract ItemStack buildItem();
/**
* need item to be set before calling this method.
*/
public void registerItem(@NotNull Raxen main) {
main.getManager().getItemManager().registerItem(item);
}
}

View file

@ -0,0 +1,16 @@
package me.unurled.raxen.components.items.custom;
public enum ItemClass {
F,
E,
D,
C,
B,
A,
S,
SS,
SSS,
MYTHIC,
UNIC,
GOD,
}

View file

@ -0,0 +1,11 @@
package me.unurled.raxen.components.items.custom;
public enum ItemTypes {
WEAPON,
BOW,
TOOLS,
MEDICINE,
ARMOR,
BLOCKS,
MISCELLANEOUS
}

View file

@ -2,7 +2,7 @@ package me.unurled.raxen.components.items.custom;
import lombok.Getter;
import me.unurled.raxen.Raxen;
import me.unurled.raxen.components.items.custom.weapon.Dager;
import me.unurled.raxen.components.items.custom.weapon.Dagger;
import java.util.ArrayList;
@ -16,11 +16,11 @@ public class List {
public List(Raxen main) {
this.main = main;
this.items = new ArrayList<>();
build();
}
public void build() {
// weapons
items.add(new Dager());
items.add(new Dagger());
}
}

View file

@ -1,51 +0,0 @@
package me.unurled.raxen.components.items.custom.weapon;
import de.tr7zw.nbtapi.NBTItem;
import lombok.Getter;
import me.unurled.raxen.Raxen;
import me.unurled.raxen.components.items.custom.Item;
import net.kyori.adventure.text.Component;
import org.bukkit.Material;
import org.bukkit.enchantments.Enchantment;
import org.bukkit.inventory.ItemFlag;
import org.bukkit.inventory.ItemStack;
import org.bukkit.inventory.meta.ItemMeta;
import java.util.ArrayList;
import java.util.List;
import static me.unurled.raxen.components.items.NBT.*;
import static me.unurled.raxen.utils.Utils.colorTextComp;
public class Dager implements Item {
@Getter
ItemStack dager;
public void buildItem() {
dager = new ItemStack(Material.IRON_SWORD);
ItemMeta itm = dager.getItemMeta();
itm.displayName(colorTextComp("<aqua>Dager"));
itm.addEnchant(Enchantment.PROTECTION_ENVIRONMENTAL, 1, false);
itm.addItemFlags(ItemFlag.HIDE_ATTRIBUTES, ItemFlag.HIDE_ENCHANTS);
itm.setUnbreakable(true);
List<Component> lore = new ArrayList<>();
lore.add(Component.text("hallooo"));
itm.lore(lore);
dager.setItemMeta(itm);
NBTItem nbti = new NBTItem(dager);
nbti.setString(ID, "DAGER");
nbti.setInteger(SPEED, 100);
nbti.setInteger(STRENGTH, 50);
nbti.setString(CUSTOM_ABILITY, "throwing_dager");
nbti.setDouble(DROP_RATE, 50.0);
dager = nbti.getItem();
}
/**
* need Raxen main to be set before calling this method.
*/
@Override
public void registerItem(Raxen main) {
main.getManager().getItemManager().registerItem(dager);
}
}

View file

@ -0,0 +1,51 @@
package me.unurled.raxen.components.items.custom.weapon;
import de.tr7zw.nbtapi.NBTItem;
import lombok.Getter;
import me.unurled.raxen.components.items.NBT;
import me.unurled.raxen.components.items.custom.Item;
import me.unurled.raxen.components.items.custom.ItemClass;
import me.unurled.raxen.components.items.custom.ItemTypes;
import net.kyori.adventure.text.Component;
import org.bukkit.Material;
import org.bukkit.enchantments.Enchantment;
import org.bukkit.inventory.ItemFlag;
import org.bukkit.inventory.ItemStack;
import org.bukkit.inventory.meta.ItemMeta;
import java.util.ArrayList;
import java.util.List;
import static me.unurled.raxen.utils.Utils.colorTextComp;
public class Dagger extends Item {
@Getter
ItemStack item;
String NAME = "Dager";
String ID = "DAGER";
ItemClass ITEM_CLASS = ItemClass.F;
ItemTypes ITEM_TYPES = ItemTypes.WEAPON;
public ItemStack buildItem() {
item = new ItemStack(Material.IRON_SWORD);
ItemMeta itm = item.getItemMeta();
itm.displayName(colorTextComp("<aqua>" + this.NAME));
itm.addEnchant(Enchantment.PROTECTION_ENVIRONMENTAL, 1, false);
itm.addItemFlags(ItemFlag.HIDE_ATTRIBUTES, ItemFlag.HIDE_ENCHANTS);
itm.setUnbreakable(true);
List<Component> lore = new ArrayList<>();
lore.add(Component.text("hallooo"));
itm.lore(lore);
item.setItemMeta(itm);
NBTItem nbti = new NBTItem(item);
nbti.setString(NBT.ID, ID);
nbti.setInteger(NBT.SPEED, 100);
nbti.setInteger(NBT.STRENGTH, 50);
nbti.setString(NBT.CUSTOM_ABILITY, "throwing_dager");
nbti.setDouble(NBT.DROP_RATE, 50.0);
item = nbti.getItem();
return item;
}
}

View file

@ -2,6 +2,7 @@ package me.unurled.raxen.listener.player;
import de.tr7zw.nbtapi.NBTItem;
import me.unurled.raxen.Raxen;
import me.unurled.raxen.components.entity.Attributes.Attribute;
import me.unurled.raxen.components.entity.player.PlayerUtils;
import me.unurled.raxen.components.entity.player.attributes.Attributes;
import me.unurled.raxen.manager.entity.PlayerManager;
@ -14,6 +15,10 @@ import org.bukkit.event.Listener;
import org.bukkit.event.player.PlayerItemHeldEvent;
import org.bukkit.inventory.ItemStack;
import java.lang.reflect.InvocationTargetException;
import static me.unurled.raxen.utils.Utils.debug;
public class ItemHandEvent implements Listener {
private Raxen main;
@ -36,25 +41,66 @@ public class ItemHandEvent implements Listener {
ItemStack newItem = player.getInventory().getItem(e.getNewSlot());
if(oldItem != null && oldItem.getType() != Material.AIR) {
NBTItem nbti = new NBTItem(oldItem);
if(nbti.hasKey("SPEED")) {
for (String s : Attributes.getNameList()) {
if (nbti.hasKey(s.toUpperCase())) {
java.lang.reflect.Method method = null;
try {
method = pm.getClass().getMethod("getItem" + s);
} catch (SecurityException | NoSuchMethodException exception) {
}
if (method != null) {
me.unurled.raxen.components.entity.Attributes.Attribute attribute = null;
try {
attribute = (Attribute) method.invoke(pm, null);
} catch (InvocationTargetException | IllegalAccessException exception) {
}
if (attribute != null) {
attribute.remove(player, nbti.getInteger(s.toUpperCase()));
debug("removed " + s + " for player " + player.getName());
}
}
}
}
/*if(nbti.hasKey("SPEED")) {
pm.getItemSpeed().remove(player, nbti.getInteger("SPEED"));
}
if(nbti.hasKey("HEALTH")) {
pm.getItemHealth().remove(player, nbti.getInteger("HEALTH"));
}
if(nbti.hasKey("DEFENSE")) {
pm.getItemDefense().remove(player, nbti.getInteger("DEFENSE"));
}
if(nbti.hasKey("STRENGTH")) {
pm.getItemStrength().remove(player, nbti.getInteger("STRENGTH"));
}
}*/
}
if(newItem != null && newItem.getType() != Material.AIR) {
NBTItem nbti = new NBTItem(newItem);
if(nbti.hasKey("SPEED")) {
for (String s : Attributes.getNameList()) {
if (nbti.hasKey(s.toUpperCase())) {
java.lang.reflect.Method method = null;
try {
method = pm.getClass().getMethod("getItem" + s);
} catch (SecurityException | NoSuchMethodException exception) {
}
if (method != null) {
me.unurled.raxen.components.entity.Attributes.Attribute attribute = null;
try {
attribute = (Attribute) method.invoke(pm, null);
} catch (InvocationTargetException | IllegalAccessException exception) {
}
if (attribute != null) {
attribute.add(player, nbti.getInteger(s.toUpperCase()));
debug("add " + s + " for player " + player.getName());
}
}
}
}
/* if(nbti.hasKey("SPEED")) {
pm.getItemSpeed().add(player, nbti.getInteger("SPEED"));
}
if(nbti.hasKey("HEALTH")) {
@ -67,8 +113,7 @@ public class ItemHandEvent implements Listener {
}
if(nbti.hasKey("STRENGTH")) {
pm.getItemStrength().add(player, nbti.getInteger("STRENGTH"));
}
}*/
}
PlayerUtils.updateSkills(main, player);
}

View file

@ -1,6 +1,7 @@
package me.unurled.raxen.listener.player;
import me.unurled.raxen.Raxen;
import me.unurled.raxen.components.entity.player.PlayerUtils;
import me.unurled.raxen.components.entity.player.Scoreboard;
import me.unurled.raxen.components.resourcepack.ResourcePack;
import me.unurled.raxen.config.PlayerConfig;
@ -38,6 +39,7 @@ public class JoinEvent implements Listener {
resourcePack.join(player);
playerManager.getRaxenPlayer(player).isRaxenPlayer(true);
playerManager.registerActionBar(player);
PlayerUtils.updateSkills(main, player);
}
}

View file

@ -1,6 +1,7 @@
package me.unurled.raxen.listener.player;
import me.unurled.raxen.Raxen;
import me.unurled.raxen.components.entity.player.PlayerUtils;
import me.unurled.raxen.config.PlayerConfig;
import me.unurled.raxen.manager.entity.PlayerManager;
import org.bukkit.entity.Player;

View file

@ -44,7 +44,7 @@ public class ItemManager {
private void registerItem() {
me.unurled.raxen.components.items.custom.List lisst = new me.unurled.raxen.components.items.custom.List(main);
for (Item items : lisst.getItems()) {
items.registerItem(main);
registerItem(items.getItem());
}
}

View file

@ -7,7 +7,6 @@ import me.unurled.raxen.components.entity.other.EntityNamespacedKey;
import me.unurled.raxen.components.entity.player.RaxenPlayer;
import me.unurled.raxen.components.entity.player.classes.Class;
import me.unurled.raxen.components.entity.player.classes.Classes;
import net.kyori.adventure.text.Component;
import org.bukkit.entity.Player;
import org.bukkit.scheduler.BukkitRunnable;
import org.bukkit.scheduler.BukkitTask;
@ -19,12 +18,12 @@ import static me.unurled.raxen.utils.Utils.*;
public class PlayerManager {
private Raxen main;
private HashMap<UUID, BukkitTask> actionBar = new HashMap<>();
//TODO: player classes
private HashMap<String, Class> classes = new HashMap<>();
private final Raxen main;
private final HashMap<UUID, BukkitTask> actionBar = new HashMap<>();
// TODO: player classes
private final HashMap<String, Class> classes = new HashMap<>();
@Getter
private HashMap<String, me.unurled.raxen.components.entity.Attributes.Attribute> attribute = new HashMap<>();
private final HashMap<String, me.unurled.raxen.components.entity.Attributes.Attribute> attribute = new HashMap<>();
private Classes classesRegister;

View file

@ -0,0 +1,17 @@
package me.unurled.raxen.utils;
import org.bukkit.Bukkit;
import org.bukkit.Location;
import org.bukkit.craftbukkit.v1_19_R1.entity.CraftPlayer;
import org.bukkit.entity.Entity;
import org.bukkit.entity.Player;
public class EntityUtils {
public void setSkin(Entity e) {
if (e instanceof Player) {
}
// Bukkit.getWorld("aa").spawn(new Location(Bukkit.getWorld("aa"), 0, 0, 0), new CraftPlayer())
}
}

View file

@ -0,0 +1,108 @@
package me.unurled.raxen.utils;
import org.bukkit.Effect;
import org.bukkit.World;
import org.bukkit.util.BoundingBox;
import org.bukkit.util.Vector;
import java.util.ArrayList;
public class RayTrace {
//origin = start position
//direction = direction in which the raytrace will go
Vector origin, direction;
public RayTrace(Vector origin, Vector direction) {
this.origin = origin;
this.direction = direction;
}
//get a point on the raytrace at X blocks away
public Vector getPostion(double blocksAway) {
return origin.clone().add(direction.clone().multiply(blocksAway));
}
//checks if a position is on contained within the position
public boolean isOnLine(Vector position) {
double t = (position.getX() - origin.getX()) / direction.getX();
;
if (position.getBlockY() == origin.getY() + (t * direction.getY()) && position.getBlockZ() == origin.getZ() + (t * direction.getZ())) {
return true;
}
return false;
}
//get all postions on a raytrace
public ArrayList<Vector> traverse(double blocksAway, double accuracy) {
ArrayList<Vector> positions = new ArrayList<>();
for (double d = 0; d <= blocksAway; d += accuracy) {
positions.add(getPostion(d));
}
return positions;
}
//intersection detection for current raytrace with return
public Vector positionOfIntersection(Vector min, Vector max, double blocksAway, double accuracy) {
ArrayList<Vector> positions = traverse(blocksAway, accuracy);
for (Vector position : positions) {
if (intersects(position, min, max)) {
return position;
}
}
return null;
}
//intersection detection for current raytrace
public boolean intersects(Vector min, Vector max, double blocksAway, double accuracy) {
ArrayList<Vector> positions = traverse(blocksAway, accuracy);
for (Vector position : positions) {
if (intersects(position, min, max)) {
return true;
}
}
return false;
}
//bounding box instead of vector
public Vector positionOfIntersection(BoundingBox boundingBox, double blocksAway, double accuracy) {
ArrayList<Vector> positions = traverse(blocksAway, accuracy);
for (Vector position : positions) {
if (intersects(position, boundingBox.getMin(), boundingBox.getMax())) {
return position;
}
}
return null;
}
//bounding box instead of vector
public boolean intersects(BoundingBox boundingBox, double blocksAway, double accuracy) {
ArrayList<Vector> positions = traverse(blocksAway, accuracy);
for (Vector position : positions) {
if (intersects(position, boundingBox.getMin(), boundingBox.getMax())) {
return true;
}
}
return false;
}
//general intersection detection
public static boolean intersects(Vector position, Vector min, Vector max) {
if (position.getX() < min.getX() || position.getX() > max.getX()) {
return false;
} else if (position.getY() < min.getY() || position.getY() > max.getY()) {
return false;
} else if (position.getZ() < min.getZ() || position.getZ() > max.getZ()) {
return false;
}
return true;
}
//debug / effects
public void highlight(World world, double blocksAway, double accuracy){
for(Vector position : traverse(blocksAway,accuracy)){
world.playEffect(position.toLocation(world), Effect.BOW_FIRE,0);
}
}
}

View file

@ -98,18 +98,40 @@ public class Utils {
* @return a String
*/
public static String textCompToString(TextComponent comp) {
MiniMessage minimessage = MiniMessage.builder()
/* MiniMessage minimessage = MiniMessage.builder()
.tags(TagResolver.builder()
.resolver(StandardTags.color())
.resolver(StandardTags.decorations())
.resolver(StandardTags.reset())
.build()
)
.build();
.build(); */
return ChatColor.translateAlternateColorCodes('&', LegacyComponentSerializer.legacyAmpersand()
.serialize(comp));
}
/**
* transform a text-component to a string
* @param comp a string
* @return a String
*/
public static String textCompToString(Component comp) {
/* MiniMessage minimessage = MiniMessage.builder()
.tags(TagResolver.builder()
.resolver(StandardTags.color())
.resolver(StandardTags.decorations())
.resolver(StandardTags.reset())
.build()
)
.build(); */
return ChatColor.translateAlternateColorCodes('§', LegacyComponentSerializer.legacyAmpersand()
.serialize(comp));
}
public static void comp(Component comp) {
LegacyComponentSerializer.legacyAmpersand().serialize(comp);
}
/**
* Strips all color from a string.
* @param string the string that wants to be decolored.