6 Commits

Author SHA1 Message Date
YouHaveTrouble f2bae4adee bump version 2022-05-28 11:20:51 +02:00
YouHaveTrouble 75457eca4b Merge pull request #1 from YouHaveTrouble/dev
2.0.0
2022-05-28 11:20:25 +02:00
YouHaveTrouble 2e0b137666 faster checks 2022-05-28 11:05:01 +02:00
YouHaveTrouble 956abd5ef0 use paper custom name methods 2022-05-28 10:37:02 +02:00
YouHaveTrouble b89e332ed4 add more docs, add fromEntity method 2022-05-18 18:30:51 +02:00
YouHaveTrouble 301a358a60 well, that's awkward 2022-05-12 19:15:38 +02:00
4 changed files with 54 additions and 14 deletions
+2 -2
View File
@@ -6,14 +6,14 @@
<groupId>me.youhavetrouble</groupId> <groupId>me.youhavetrouble</groupId>
<artifactId>Entiddy</artifactId> <artifactId>Entiddy</artifactId>
<version>1.1.0</version> <version>2.0.0</version>
<packaging>jar</packaging> <packaging>jar</packaging>
<name>Entiddy</name> <name>Entiddy</name>
<description>A very serious library concerning entities</description> <description>A very serious library concerning entities</description>
<properties> <properties>
<java.version>1.8</java.version> <java.version>17</java.version>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding> <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
</properties> </properties>
@@ -5,6 +5,7 @@ import me.youhavetrouble.entiddy.SpecialEntities.JebSheep;
import me.youhavetrouble.entiddy.SpecialEntities.Johnny; import me.youhavetrouble.entiddy.SpecialEntities.Johnny;
import me.youhavetrouble.entiddy.SpecialEntities.KillerBunny; import me.youhavetrouble.entiddy.SpecialEntities.KillerBunny;
import me.youhavetrouble.entiddy.SpecialEntities.Toast; import me.youhavetrouble.entiddy.SpecialEntities.Toast;
import net.kyori.adventure.text.Component;
import org.bukkit.entity.EntityType; import org.bukkit.entity.EntityType;
import org.bukkit.entity.LivingEntity; import org.bukkit.entity.LivingEntity;
import org.bukkit.entity.Player; import org.bukkit.entity.Player;
@@ -12,9 +13,27 @@ import org.jetbrains.annotations.NotNull;
public enum Entiddy { public enum Entiddy {
/**
* Killer bunny that attacks players monthy python style
*/
KILLER_BUNNY(EntityType.RABBIT, new KillerBunny()), KILLER_BUNNY(EntityType.RABBIT, new KillerBunny()),
/**
* Its wool cycles with interpolation through all dye colors
* Sheep with rgb lighting
*/
JEB_SHEEP(EntityType.SHEEP, new JebSheep()), JEB_SHEEP(EntityType.SHEEP, new JebSheep()),
/**
* Johnny is hostile to basically every mob with few exceptions
* HERE'S JOHNNY
*/
JOHNNY(EntityType.VINDICATOR, new Johnny()), JOHNNY(EntityType.VINDICATOR, new Johnny()),
/**
* Toast has the appearance of a black dutch, with a large black and white patch and more black fur around the face
* than the natural black and white spotted rabbit.
*/
TOAST(EntityType.RABBIT, new Toast()); TOAST(EntityType.RABBIT, new Toast());
private final EntityType entityType; private final EntityType entityType;
@@ -39,7 +58,7 @@ public enum Entiddy {
*/ */
public static void upsideDown(@NotNull LivingEntity entity) { public static void upsideDown(@NotNull LivingEntity entity) {
if (entity instanceof Player) return; if (entity instanceof Player) return;
entity.setCustomName("Grumm"); entity.customName(Component.text("Grumm"));
} }
/** /**
@@ -47,10 +66,21 @@ public enum Entiddy {
*/ */
public static boolean isSpecialEntity(@NotNull LivingEntity entity) { public static boolean isSpecialEntity(@NotNull LivingEntity entity) {
if (entity instanceof Player) return false; if (entity instanceof Player) return false;
for (Entiddy enTiddy: Entiddy.values()) { for (Entiddy entiddy: Entiddy.values()) {
if (enTiddy.entiddy().isInstance(entity)) return true; if (entiddy.entiddy().isInstance(entity)) return true;
} }
return false; return false;
} }
/**
* @return Special entity type or null
*/
public static Entiddy fromEntity(@NotNull LivingEntity entity) {
if (entity instanceof Player) return null;
for (Entiddy entiddy: Entiddy.values()) {
if (entiddy.entiddy().isInstance(entity)) return entiddy;
}
return null;
}
} }
@@ -1,14 +1,14 @@
package me.youhavetrouble.entiddy.SpecialEntities; package me.youhavetrouble.entiddy.SpecialEntities;
import me.youhavetrouble.entiddy.EntiddyInterface; import me.youhavetrouble.entiddy.EntiddyInterface;
import net.kyori.adventure.text.Component;
import org.bukkit.Location; import org.bukkit.Location;
import org.bukkit.entity.Entity; import org.bukkit.entity.*;
import org.bukkit.entity.EntityType;
import org.bukkit.entity.LivingEntity;
import org.bukkit.entity.Rabbit;
import org.bukkit.event.entity.CreatureSpawnEvent; import org.bukkit.event.entity.CreatureSpawnEvent;
import org.jetbrains.annotations.NotNull; import org.jetbrains.annotations.NotNull;
import java.util.Objects;
public class JebSheep implements EntiddyInterface { public class JebSheep implements EntiddyInterface {
@Override @Override
@@ -16,12 +16,15 @@ public class JebSheep implements EntiddyInterface {
if (location.getWorld() == null) { if (location.getWorld() == null) {
throw new NullPointerException("World cannot be null"); throw new NullPointerException("World cannot be null");
} }
return location.getWorld().spawnEntity(location, EntityType.SHEEP, spawnReason, (entity) -> entity.setCustomName("jeb_")); return location.getWorld().spawnEntity(location, EntityType.SHEEP, spawnReason, (entity) -> {
entity.customName(Component.text("jeb_"));
entity.setCustomNameVisible(false);
});
} }
@Override @Override
public boolean isInstance(@NotNull LivingEntity entity) { public boolean isInstance(@NotNull LivingEntity entity) {
if (!(entity instanceof Rabbit)) return false; if (!(entity instanceof Sheep)) return false;
return entity.getCustomName() != null && entity.getCustomName().equals("jeb_"); return Objects.equals(entity.customName(), Component.text("jeb_"));
} }
} }
@@ -1,6 +1,7 @@
package me.youhavetrouble.entiddy.SpecialEntities; package me.youhavetrouble.entiddy.SpecialEntities;
import me.youhavetrouble.entiddy.EntiddyInterface; import me.youhavetrouble.entiddy.EntiddyInterface;
import net.kyori.adventure.text.Component;
import org.bukkit.Location; import org.bukkit.Location;
import org.bukkit.entity.Entity; import org.bukkit.entity.Entity;
import org.bukkit.entity.EntityType; import org.bukkit.entity.EntityType;
@@ -9,6 +10,8 @@ import org.bukkit.entity.Rabbit;
import org.bukkit.event.entity.CreatureSpawnEvent; import org.bukkit.event.entity.CreatureSpawnEvent;
import org.jetbrains.annotations.NotNull; import org.jetbrains.annotations.NotNull;
import java.util.Objects;
public class Toast implements EntiddyInterface { public class Toast implements EntiddyInterface {
@Override @Override
@@ -16,12 +19,16 @@ public class Toast implements EntiddyInterface {
if (location.getWorld() == null) { if (location.getWorld() == null) {
throw new NullPointerException("World cannot be null"); throw new NullPointerException("World cannot be null");
} }
return location.getWorld().spawnEntity(location, EntityType.RABBIT, spawnReason, (entity) -> entity.setCustomName("Toast")); return location.getWorld().spawnEntity(location, EntityType.RABBIT, spawnReason,
(entity) -> {
entity.customName(Component.text("Toast"));
entity.setCustomNameVisible(false);
});
} }
@Override @Override
public boolean isInstance(@NotNull LivingEntity entity) { public boolean isInstance(@NotNull LivingEntity entity) {
if (!(entity instanceof Rabbit)) return false; if (!(entity instanceof Rabbit)) return false;
return entity.getCustomName() != null && entity.getCustomName().equals("Toast"); return Objects.equals(entity.customName(), Component.text("Toast"));
} }
} }