|
@@ -272,13 +272,13 @@ public final class ExperienceAPI {
|
|
|
}
|
|
|
|
|
|
/**
|
|
|
- * Get the amount of XP left before leveling up.
|
|
|
+ * Get the total amount of XP needed to reach the next level.
|
|
|
* </br>
|
|
|
* This function is designed for API usage.
|
|
|
*
|
|
|
* @param player The player to get the XP amount for
|
|
|
* @param skillType The skill to get the XP amount for
|
|
|
- * @return the amount of XP left before leveling up a specifc skill
|
|
|
+ * @return the total amount of XP needed to reach the next level
|
|
|
*
|
|
|
* @throws InvalidSkillException if the given skill is not valid
|
|
|
* @throws UnsupportedOperationException if the given skill is a child skill
|
|
@@ -298,13 +298,13 @@ public final class ExperienceAPI {
|
|
|
}
|
|
|
|
|
|
/**
|
|
|
- * Get the amount of XP an offline player has left before leveling up.
|
|
|
+ * Get the total amount of XP an offline player needs to reach the next level.
|
|
|
* </br>
|
|
|
* This function is designed for API usage.
|
|
|
*
|
|
|
* @param playerName The player to get XP for
|
|
|
* @param skillType The skill to get XP for
|
|
|
- * @return the amount of XP in a given skill
|
|
|
+ * @return the total amount of XP needed to reach the next level
|
|
|
*
|
|
|
* @throws InvalidSkillException if the given skill is not valid
|
|
|
* @throws InvalidPlayerException if the given player does not exist in the database
|
|
@@ -324,6 +324,63 @@ public final class ExperienceAPI {
|
|
|
return getOfflineProfile(playerName).getXpToLevel(skill);
|
|
|
}
|
|
|
|
|
|
+ /**
|
|
|
+ * Get the amount of XP remaining until the next level.
|
|
|
+ * </br>
|
|
|
+ * This function is designed for API usage.
|
|
|
+ *
|
|
|
+ * @param player The player to get the XP amount for
|
|
|
+ * @param skillType The skill to get the XP amount for
|
|
|
+ * @return the amount of XP remaining until the next level
|
|
|
+ *
|
|
|
+ * @throws InvalidSkillException if the given skill is not valid
|
|
|
+ * @throws UnsupportedOperationException if the given skill is a child skill
|
|
|
+ */
|
|
|
+ public static int getXPRemaining(Player player, String skillType) {
|
|
|
+ SkillType skill = SkillType.getSkill(skillType);
|
|
|
+
|
|
|
+ if (skill == null) {
|
|
|
+ throw new InvalidSkillException();
|
|
|
+ }
|
|
|
+
|
|
|
+ if (skill.isChildSkill()) {
|
|
|
+ throw new UnsupportedOperationException("Child skills do not have XP");
|
|
|
+ }
|
|
|
+
|
|
|
+ PlayerProfile profile = UserManager.getPlayer(player).getProfile();
|
|
|
+
|
|
|
+ return profile.getXpToLevel(skill) - profile.getSkillXpLevel(skill);
|
|
|
+ }
|
|
|
+
|
|
|
+ /**
|
|
|
+ * Get the amount of XP an offline player has left before leveling up.
|
|
|
+ * </br>
|
|
|
+ * This function is designed for API usage.
|
|
|
+ *
|
|
|
+ * @param playerName The player to get XP for
|
|
|
+ * @param skillType The skill to get XP for
|
|
|
+ * @return the amount of XP needed to reach the next level
|
|
|
+ *
|
|
|
+ * @throws InvalidSkillException if the given skill is not valid
|
|
|
+ * @throws InvalidPlayerException if the given player does not exist in the database
|
|
|
+ * @throws UnsupportedOperationException if the given skill is a child skill
|
|
|
+ */
|
|
|
+ public static int getOfflineXPRemaining(String playerName, String skillType) {
|
|
|
+ SkillType skill = SkillType.getSkill(skillType);
|
|
|
+
|
|
|
+ if (skill == null) {
|
|
|
+ throw new InvalidSkillException();
|
|
|
+ }
|
|
|
+
|
|
|
+ if (skill.isChildSkill()) {
|
|
|
+ throw new UnsupportedOperationException("Child skills do not have XP");
|
|
|
+ }
|
|
|
+
|
|
|
+ PlayerProfile profile = getOfflineProfile(playerName);
|
|
|
+
|
|
|
+ return profile.getXpToLevel(skill) - profile.getSkillXpLevel(skill);
|
|
|
+ }
|
|
|
+
|
|
|
/**
|
|
|
* Add levels to a skill.
|
|
|
* </br>
|