EliteMobs is a Spigot plugin focused around the creation of bosses. It also adds several other features, such as quests, arenas, items, an extension to in-game progression and dungeons, to name a few.
Feature and configuration documentation: https://github.com/MagmaGuy/EliteMobs/wiki
Discord support channel: https://discord.gg/QSA2wgh
Webapp where you can create content: https://magmaguy.com/webapp/webapp.html
Maven repository:
Maven:
<repository>
<id>magmaguy-repo-releases</id>
<name>MagmaGuy's Repository</name>
<url>https://repo.magmaguy.com/releases</url>
</repository>
<dependency>
<groupId>com.magmaguy</groupId>
<artifactId>EliteMobs</artifactId>
<version>9.1.9</version>
</dependency>
Gradle:
repositories {
//EliteMobs
maven {
url = uri("https://repo.magmaguy.com/releases")
}
}
dependencies{
//EliteMobs
compileOnly("com.magmaguy:EliteMobs:9.1.9")
}
The following is a list of key classes for the plugin:
com.magmaguy.elitemobs.api.utils.EliteItemManager
This class is specifically made to be the easiest way to interface with Elite Items.
These are the key classes for the boss system. RegionalBossEntity extends CustomBossEntity which extends EliteEntity.
This is used to check if an entity is from EliteMobs and to get the specific instance of that entity.
Note: This documentation is updated as requested. If you feel like it is incomplete and should further expand on some aspects, request it and it will be updated.
EliteMobs has a few basic APIs to interface with in the com.magmaguy.elitemobs.api
package. Here's the breakdown:
Fires when an arena is successfully beaten by players.
Fires when a Custom Event starts. Note that in this instance Custom Events refers to the mechanic in which bosses randomly spawn in the Overworld.
- Can be cancelled
Fires when a dungeon is installed by an admin.
- Can be cancelled
Fires when a dungeon is uninstalled by an admin.
- Can be cancelled
Fires when an Elite Explosion happens. Note that elite explosions have a custom visual effect and regenerate the damage done to terrain after 2 minutes.
- Can be cancelled
Used for listening to moments when one Elite damages another Elite. Uses:
- Same as Bukkit's EntityDamagedByEntity event but for elites specifically
- Cancelling it might not work. Report if it doesn't.
Used for listening to events which trigger an antiexploit check - doesn't necessarily mean that it detected an exploit. Uses:
- Same as Bukkit's EntityDamagedByEntity event but for elites specifically
- Can be cancelled
Used for listening to moments when a player damages an Elite. Uses:
- Same as Bukkit's EntityDamagedByEntity event but for players damaging elites specifically
- Important: can't be cancelled as it only fires after applying the damage
Used for listening to moments when an elite is damaged in general. Uses:
- Same as Bukkit's EntityDamageEvent
- Important Cancelling this event might not 100% work, report if it doesn't
Used to listening to moments when an elite is killed. Uses:
- Same as Bukkit's EntityDeathEvent.
Used for listening to moments when an elite enters combat against a player. Note that bosses only enter combat after either striking a player or being struck, and not at the moment of targetting. Uses:
- Get the target (player only) of the Elite
- Get the elite which entered in combat
Used for listening to moments when an elite leaves combat against a player. Uses:
- Get the elite which just let combat.
Used when an elite gets healed.
- Can be cancelled.
Used when an elite mob gets removed. Please note that not all removals are permanent as bosses can be removed because the chunks unload while still being persistent.
Used for detecting whether an ItemStack is an EliteMobs ItemStack (like a custom item or a procedurally generated item). Uses:
- Detect if an ItemStack is an EliteMobs custom or dynamic item.
Used for detecting when an Elite spawns. Uses:
- Detect when an Elite spawns.
- Detect which Elite spawned.
Used for detecting when an Elite has targetted a player. Uses:
- Detect when an Elite targets a player.
- Cancel an Elite's detection of a player.
Used for listening to moments when the antiexploit runs a check but no players damaged it. Uses:
- Detect when the antiexploit is doing a non-player based exploit check.
- Cancel an antiexploit check.
Used when an npc gets removed. This removal may not be permanent, as it might just be a chunk unload.
Used when an npc gets spawned.
Used for listening to moments when players are damaged by an Elite. Uses:
- Same as Bukkit's EntityDamageEvent.
Used when a player starts teleporting through EliteMobs features. There is a 3 second timer before the teleportation actually happens.
- Can be cancelled.
Used when a player actually teleports through EliteMobs features.
- Can be cancelled.
Used when a player accepts a quest.
- Can be cancelled.
Used when a player completes a quest.
- Can be cancelled.
Used when a player leaves a quest.
Used when all quest objectives for a quest are completed.
Used when a player progresses in a quest, such as by killing a quest mob or collecting a quest item.
Used when a player gets the reward from a quest.
Used when a Super Mob gets damaged.
- Can be cancelled.
Used when a Super Mob dies.
Used when a Super Mob gets removed. Note that removals might be temporary due to chunk unloads.
Used when a Super Mob spawns.
- Can be cancelled.
- Add new enchantment class to the
com.magmaguy.elitemobs.config.enchantments.premade
** extending**EnchantmentsConfigFields
to initialize create its config file (naming convention: [EnchantmentName] Config) - Initialize enchantment in
CustomEnchantment
to initialize the config file - Add enchantment class to
com.magmaguy.elitemobs.items.customenchantments
extendingCustomEnchantment
to write the logic for the enchantment (naming convention [EnchantmentName]Enchantment) - Add a public static String called "key" to register using the ItemTagger class for persistent enchantment tracking
- Add an entry to the parseEnchantments() method in
CustomItem
so custom items detect it correctly - (Alternative) Add an entry to
generateCustomEnchantments()
method inEnchantmentGenerator
if the enchantment should appear in procedurally generated items
Note:
- Don't forget to register events in
EventsRegistrer
if the part with logic in it requires events. - Don't forget to use the damage bypass if the power is supposed to deal custom damage. Damage dealt by the player to an
elite can be overwritten in
CombatSystem
through the static "bypass" boolean field - it makes the next damage dealt to the elite use the raw damage value. For correctly assigning damage, use Bukkit'sDamageable#damage(double amount, Entity source)
and assign the source to your player.
to be documented
to be documented
to be documented
to be documented
Special Thanks to Illusion for spending a few hours proselytizing enums that are also have anonymous method implementations on their constructor.