mirror of
https://github.com/songoda/EpicBosses.git
synced 2025-01-09 08:47:34 +01:00
1.0.0-SNAPSHOT-U114
+ Added/Connected the Group Skill
This commit is contained in:
parent
ac19dbe327
commit
1eadf6a664
@ -96,38 +96,8 @@ public class BossSkillListener implements Listener {
|
|||||||
}
|
}
|
||||||
|
|
||||||
List<LivingEntity> targettedEntities = this.bossSkillManager.getTargetedEntities(activeBossHolder, skill, activeBossHolder.getLivingEntity().getLocation(), damagingEntity);
|
List<LivingEntity> targettedEntities = this.bossSkillManager.getTargetedEntities(activeBossHolder, skill, activeBossHolder.getLivingEntity().getLocation(), damagingEntity);
|
||||||
String bossDisplayName = activeBossHolder.getName();
|
|
||||||
String skillDisplayName = skill.getDisplayName();
|
|
||||||
ISkillHandler<?> skillHandler;
|
|
||||||
|
|
||||||
if(skill.getType().equalsIgnoreCase("POTION")) {
|
this.bossSkillManager.handleSkill(masterMessage, skill, targettedEntities, activeBossHolder, true, false);
|
||||||
PotionSkillElement potionSkillElement = this.bossSkillManager.getPotionSkillElement(skill);
|
|
||||||
|
|
||||||
potionSkillElement.castSkill(skill, potionSkillElement, activeBossHolder, targettedEntities);
|
|
||||||
skillHandler = potionSkillElement;
|
|
||||||
} else if(skill.getType().equalsIgnoreCase("COMMAND")) {
|
|
||||||
CommandSkillElement commandSkillElement = this.bossSkillManager.getCommandSkillElement(skill);
|
|
||||||
|
|
||||||
commandSkillElement.castSkill(skill, commandSkillElement, activeBossHolder, targettedEntities);
|
|
||||||
skillHandler = commandSkillElement;
|
|
||||||
} else if(skill.getType().equalsIgnoreCase("GROUP")) {
|
|
||||||
GroupSkillElement groupSkillElement = this.bossSkillManager.getGroupSkillElement(skill);
|
|
||||||
|
|
||||||
groupSkillElement.castSkill(skill, groupSkillElement, activeBossHolder, targettedEntities);
|
|
||||||
skillHandler = groupSkillElement;
|
|
||||||
} else if(skill.getType().equalsIgnoreCase("CUSTOM")) {
|
|
||||||
CustomSkillElement customSkillElement = this.bossSkillManager.getCustomSkillElement(skill);
|
|
||||||
|
|
||||||
skillHandler = this.bossSkillManager.handleCustomSkillCasting(skill, customSkillElement, activeBossHolder, targettedEntities);
|
|
||||||
} else {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
masterMessage.replaceAll(s -> s.replace("{boss}", bossDisplayName).replace("{skill}", skillDisplayName));
|
|
||||||
targettedEntities.forEach(livingEntity -> MessageUtils.get().sendMessage(livingEntity, masterMessage));
|
|
||||||
|
|
||||||
BossSkillEvent bossSkillEvent = new BossSkillEvent(activeBossHolder, skillHandler, skill);
|
|
||||||
ServerUtils.get().callEvent(bossSkillEvent);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -1,17 +1,16 @@
|
|||||||
package com.songoda.epicbosses.managers;
|
package com.songoda.epicbosses.managers;
|
||||||
|
|
||||||
|
import com.songoda.epicbosses.events.BossSkillEvent;
|
||||||
import com.songoda.epicbosses.holder.ActiveBossHolder;
|
import com.songoda.epicbosses.holder.ActiveBossHolder;
|
||||||
import com.songoda.epicbosses.skills.CustomSkillHandler;
|
import com.songoda.epicbosses.skills.CustomSkillHandler;
|
||||||
|
import com.songoda.epicbosses.skills.ISkillHandler;
|
||||||
import com.songoda.epicbosses.skills.Skill;
|
import com.songoda.epicbosses.skills.Skill;
|
||||||
import com.songoda.epicbosses.skills.custom.*;
|
import com.songoda.epicbosses.skills.custom.*;
|
||||||
import com.songoda.epicbosses.skills.types.CommandSkillElement;
|
import com.songoda.epicbosses.skills.types.CommandSkillElement;
|
||||||
import com.songoda.epicbosses.skills.types.CustomSkillElement;
|
import com.songoda.epicbosses.skills.types.CustomSkillElement;
|
||||||
import com.songoda.epicbosses.skills.types.GroupSkillElement;
|
import com.songoda.epicbosses.skills.types.GroupSkillElement;
|
||||||
import com.songoda.epicbosses.skills.types.PotionSkillElement;
|
import com.songoda.epicbosses.skills.types.PotionSkillElement;
|
||||||
import com.songoda.epicbosses.utils.BossesGson;
|
import com.songoda.epicbosses.utils.*;
|
||||||
import com.songoda.epicbosses.utils.Debug;
|
|
||||||
import com.songoda.epicbosses.utils.ILoadable;
|
|
||||||
import com.songoda.epicbosses.utils.RandomUtils;
|
|
||||||
import org.bukkit.Bukkit;
|
import org.bukkit.Bukkit;
|
||||||
import org.bukkit.Location;
|
import org.bukkit.Location;
|
||||||
import org.bukkit.entity.LivingEntity;
|
import org.bukkit.entity.LivingEntity;
|
||||||
@ -42,17 +41,48 @@ public class BossSkillManager implements ILoadable {
|
|||||||
registerCustomSkill(new Warp());
|
registerCustomSkill(new Warp());
|
||||||
}
|
}
|
||||||
|
|
||||||
public CustomSkillHandler handleCustomSkillCasting(Skill skill, CustomSkillElement customSkillElement, ActiveBossHolder activeBossHolder, List<LivingEntity> nearbyEntities) {
|
public void handleSkill(List<String> masterMessage, Skill skill, List<LivingEntity> targetedEntities, ActiveBossHolder activeBossHolder, boolean message, boolean subSkill) {
|
||||||
String type = customSkillElement.getCustom().getType();
|
if(skill == null) {
|
||||||
CustomSkillHandler customSkillHandler = getCustomSkillHandler(type);
|
Debug.SKILL_NOT_FOUND.debug();
|
||||||
|
return;
|
||||||
if(customSkillHandler == null) {
|
|
||||||
Debug.FAILED_TO_OBTAIN_THE_SKILL_HANDLER.debug(type);
|
|
||||||
return null;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
customSkillHandler.castSkill(skill, customSkillElement, activeBossHolder, nearbyEntities);
|
ISkillHandler<?> skillHandler;
|
||||||
return customSkillHandler;
|
String bossDisplayName = activeBossHolder.getName();
|
||||||
|
String skillDisplayName = skill.getDisplayName();
|
||||||
|
|
||||||
|
if(skill.getType().equalsIgnoreCase("POTION")) {
|
||||||
|
PotionSkillElement potionSkillElement = getPotionSkillElement(skill);
|
||||||
|
|
||||||
|
potionSkillElement.castSkill(skill, potionSkillElement, activeBossHolder, targetedEntities);
|
||||||
|
skillHandler = potionSkillElement;
|
||||||
|
} else if(skill.getType().equalsIgnoreCase("COMMAND")) {
|
||||||
|
CommandSkillElement commandSkillElement = getCommandSkillElement(skill);
|
||||||
|
|
||||||
|
commandSkillElement.castSkill(skill, commandSkillElement, activeBossHolder, targetedEntities);
|
||||||
|
skillHandler = commandSkillElement;
|
||||||
|
} else if(skill.getType().equalsIgnoreCase("GROUP")) {
|
||||||
|
if(subSkill) return;
|
||||||
|
|
||||||
|
GroupSkillElement groupSkillElement = getGroupSkillElement(skill);
|
||||||
|
|
||||||
|
groupSkillElement.castSkill(skill, groupSkillElement, activeBossHolder, targetedEntities);
|
||||||
|
skillHandler = groupSkillElement;
|
||||||
|
} else if(skill.getType().equalsIgnoreCase("CUSTOM")) {
|
||||||
|
CustomSkillElement customSkillElement = getCustomSkillElement(skill);
|
||||||
|
|
||||||
|
skillHandler = handleCustomSkillCasting(skill, customSkillElement, activeBossHolder, targetedEntities);
|
||||||
|
} else {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
if(message && masterMessage != null) {
|
||||||
|
masterMessage.replaceAll(s -> s.replace("{boss}", bossDisplayName).replace("{skill}", skillDisplayName));
|
||||||
|
targetedEntities.forEach(livingEntity -> MessageUtils.get().sendMessage(livingEntity, masterMessage));
|
||||||
|
}
|
||||||
|
|
||||||
|
BossSkillEvent bossSkillEvent = new BossSkillEvent(activeBossHolder, skillHandler, skill);
|
||||||
|
ServerUtils.get().callEvent(bossSkillEvent);
|
||||||
}
|
}
|
||||||
|
|
||||||
public PotionSkillElement getPotionSkillElement(Skill skill) {
|
public PotionSkillElement getPotionSkillElement(Skill skill) {
|
||||||
@ -127,6 +157,19 @@ public class BossSkillManager implements ILoadable {
|
|||||||
return targetedList;
|
return targetedList;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private CustomSkillHandler handleCustomSkillCasting(Skill skill, CustomSkillElement customSkillElement, ActiveBossHolder activeBossHolder, List<LivingEntity> nearbyEntities) {
|
||||||
|
String type = customSkillElement.getCustom().getType();
|
||||||
|
CustomSkillHandler customSkillHandler = getCustomSkillHandler(type);
|
||||||
|
|
||||||
|
if(customSkillHandler == null) {
|
||||||
|
Debug.FAILED_TO_OBTAIN_THE_SKILL_HANDLER.debug(type);
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
customSkillHandler.castSkill(skill, customSkillElement, activeBossHolder, nearbyEntities);
|
||||||
|
return customSkillHandler;
|
||||||
|
}
|
||||||
|
|
||||||
private CustomSkillHandler getCustomSkillHandler(String name) {
|
private CustomSkillHandler getCustomSkillHandler(String name) {
|
||||||
for(CustomSkillHandler customSkillHandler : new HashSet<>(SKILLS)) {
|
for(CustomSkillHandler customSkillHandler : new HashSet<>(SKILLS)) {
|
||||||
String skillName = customSkillHandler.getClass().getSimpleName();
|
String skillName = customSkillHandler.getClass().getSimpleName();
|
||||||
|
@ -1,9 +1,13 @@
|
|||||||
package com.songoda.epicbosses.skills.types;
|
package com.songoda.epicbosses.skills.types;
|
||||||
|
|
||||||
import com.google.gson.annotations.Expose;
|
import com.google.gson.annotations.Expose;
|
||||||
|
import com.songoda.epicbosses.CustomBosses;
|
||||||
import com.songoda.epicbosses.holder.ActiveBossHolder;
|
import com.songoda.epicbosses.holder.ActiveBossHolder;
|
||||||
|
import com.songoda.epicbosses.managers.BossSkillManager;
|
||||||
|
import com.songoda.epicbosses.managers.files.SkillsFileManager;
|
||||||
import com.songoda.epicbosses.skills.ISkillHandler;
|
import com.songoda.epicbosses.skills.ISkillHandler;
|
||||||
import com.songoda.epicbosses.skills.Skill;
|
import com.songoda.epicbosses.skills.Skill;
|
||||||
|
import com.songoda.epicbosses.utils.Debug;
|
||||||
import lombok.Getter;
|
import lombok.Getter;
|
||||||
import lombok.Setter;
|
import lombok.Setter;
|
||||||
import org.bukkit.entity.LivingEntity;
|
import org.bukkit.entity.LivingEntity;
|
||||||
@ -25,6 +29,20 @@ public class GroupSkillElement implements ISkillHandler<GroupSkillElement> {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void castSkill(Skill skill, GroupSkillElement groupSkillElement, ActiveBossHolder activeBossHolder, List<LivingEntity> nearbyEntities) {
|
public void castSkill(Skill skill, GroupSkillElement groupSkillElement, ActiveBossHolder activeBossHolder, List<LivingEntity> nearbyEntities) {
|
||||||
//TODO
|
List<String> currentGroupedSkills = getGroupedSkills();
|
||||||
|
CustomBosses plugin = CustomBosses.get();
|
||||||
|
SkillsFileManager skillsFileManager = plugin.getSkillsFileManager();
|
||||||
|
BossSkillManager bossSkillManager = plugin.getBossSkillManager();
|
||||||
|
|
||||||
|
currentGroupedSkills.forEach(string -> {
|
||||||
|
Skill innerSkill = skillsFileManager.getSkill(string);
|
||||||
|
|
||||||
|
if(innerSkill == null) {
|
||||||
|
Debug.SKILL_NOT_FOUND.debug();
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
bossSkillManager.handleSkill(null, skill, nearbyEntities, activeBossHolder, false, true);
|
||||||
|
});
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
2
pom.xml
2
pom.xml
@ -20,7 +20,7 @@
|
|||||||
|
|
||||||
<properties>
|
<properties>
|
||||||
<!--<plugin.version>maven-version-number-SNAPSHOT-U90</plugin.version>-->
|
<!--<plugin.version>maven-version-number-SNAPSHOT-U90</plugin.version>-->
|
||||||
<plugin.version>1.0.0-U113</plugin.version>
|
<plugin.version>1.0.0-U114</plugin.version>
|
||||||
<plugin.name>EpicBosses</plugin.name>
|
<plugin.name>EpicBosses</plugin.name>
|
||||||
<plugin.main>com.songoda.epicbosses.CustomBosses</plugin.main>
|
<plugin.main>com.songoda.epicbosses.CustomBosses</plugin.main>
|
||||||
<plugin.author>AMinecraftDev</plugin.author>
|
<plugin.author>AMinecraftDev</plugin.author>
|
||||||
|
Loading…
Reference in New Issue
Block a user