|
@@ -1,16 +1,14 @@
|
|
package com.gmail.nossr50.commands.skills;
|
|
package com.gmail.nossr50.commands.skills;
|
|
|
|
|
|
import com.gmail.nossr50.commands.SkillCommand;
|
|
import com.gmail.nossr50.commands.SkillCommand;
|
|
-import com.gmail.nossr50.config.AdvancedConfig;
|
|
|
|
-import com.gmail.nossr50.config.Config;
|
|
|
|
import com.gmail.nossr50.datatypes.SkillType;
|
|
import com.gmail.nossr50.datatypes.SkillType;
|
|
import com.gmail.nossr50.locale.LocaleLoader;
|
|
import com.gmail.nossr50.locale.LocaleLoader;
|
|
|
|
+import com.gmail.nossr50.skills.mining.BlastMining;
|
|
|
|
+import com.gmail.nossr50.skills.mining.Mining;
|
|
import com.gmail.nossr50.util.Misc;
|
|
import com.gmail.nossr50.util.Misc;
|
|
import com.gmail.nossr50.util.Permissions;
|
|
import com.gmail.nossr50.util.Permissions;
|
|
-import com.gmail.nossr50.util.Skills;
|
|
|
|
|
|
|
|
public class MiningCommand extends SkillCommand {
|
|
public class MiningCommand extends SkillCommand {
|
|
- AdvancedConfig advancedConfig = AdvancedConfig.getInstance();
|
|
|
|
private String doubleDropChance;
|
|
private String doubleDropChance;
|
|
private String doubleDropChanceLucky;
|
|
private String doubleDropChanceLucky;
|
|
private String superBreakerLength;
|
|
private String superBreakerLength;
|
|
@@ -19,27 +17,12 @@ public class MiningCommand extends SkillCommand {
|
|
private String blastRadiusIncrease;
|
|
private String blastRadiusIncrease;
|
|
private String blastDamageDecrease;
|
|
private String blastDamageDecrease;
|
|
|
|
|
|
- private int blastMiningRank1 = advancedConfig.getBlastMiningRank1();
|
|
|
|
- private int blastMiningRank2 = advancedConfig.getBlastMiningRank2();
|
|
|
|
- private int blastMiningRank3 = advancedConfig.getBlastMiningRank3();
|
|
|
|
- private int blastMiningRank4 = advancedConfig.getBlastMiningRank4();
|
|
|
|
- private int blastMiningRank5 = advancedConfig.getBlastMiningRank5();
|
|
|
|
- private int blastMiningRank6 = advancedConfig.getBlastMiningRank6();
|
|
|
|
- private int blastMiningRank7 = advancedConfig.getBlastMiningRank7();
|
|
|
|
- private int blastMiningRank8 = advancedConfig.getBlastMiningRank8();
|
|
|
|
-
|
|
|
|
- private double doubleDropsMaxBonus = advancedConfig.getMiningDoubleDropChance();
|
|
|
|
- private int doubleDropsMaxLevel = advancedConfig.getMiningDoubleDropMaxLevel();
|
|
|
|
- public int abilityLengthIncreaseLevel = advancedConfig.getAbilityLength();
|
|
|
|
-
|
|
|
|
private boolean canSuperBreaker;
|
|
private boolean canSuperBreaker;
|
|
private boolean canDoubleDrop;
|
|
private boolean canDoubleDrop;
|
|
private boolean canBlast;
|
|
private boolean canBlast;
|
|
private boolean canBiggerBombs;
|
|
private boolean canBiggerBombs;
|
|
private boolean canDemoExpert;
|
|
private boolean canDemoExpert;
|
|
private boolean doubleDropsDisabled;
|
|
private boolean doubleDropsDisabled;
|
|
- private boolean lucky;
|
|
|
|
- private boolean endurance;
|
|
|
|
|
|
|
|
public MiningCommand() {
|
|
public MiningCommand() {
|
|
super(SkillType.MINING);
|
|
super(SkillType.MINING);
|
|
@@ -47,69 +30,53 @@ public class MiningCommand extends SkillCommand {
|
|
|
|
|
|
@Override
|
|
@Override
|
|
protected void dataCalculations() {
|
|
protected void dataCalculations() {
|
|
- float doubleDropChanceF;
|
|
|
|
- //Super Breaker
|
|
|
|
- int length = 2 + (int) ((double) skillValue / (double) abilityLengthIncreaseLevel);
|
|
|
|
- superBreakerLength = String.valueOf(length);
|
|
|
|
-
|
|
|
|
- if (Permissions.activationTwelve(player)) {
|
|
|
|
- length = length + 12;
|
|
|
|
- }
|
|
|
|
- else if (Permissions.activationEight(player)) {
|
|
|
|
- length = length + 8;
|
|
|
|
- }
|
|
|
|
- else if (Permissions.activationFour(player)) {
|
|
|
|
- length = length + 4;
|
|
|
|
- }
|
|
|
|
- int maxLength = SkillType.MINING.getAbility().getMaxTicks();
|
|
|
|
- if (maxLength != 0 && length > maxLength) {
|
|
|
|
- length = maxLength;
|
|
|
|
- }
|
|
|
|
- superBreakerLengthEndurance = String.valueOf(length);
|
|
|
|
- //Double Drops
|
|
|
|
- if (skillValue >= doubleDropsMaxLevel) doubleDropChanceF = (float) (doubleDropsMaxBonus);
|
|
|
|
- else doubleDropChanceF = (float) ((doubleDropsMaxBonus / doubleDropsMaxLevel) * skillValue);
|
|
|
|
- doubleDropChance = percent.format(doubleDropChanceF / 100D);
|
|
|
|
- if (doubleDropChanceF * 1.3333D >= 100D) doubleDropChanceLucky = percent.format(1D);
|
|
|
|
- else doubleDropChanceLucky = percent.format(doubleDropChanceF * 1.3333D / 100D);
|
|
|
|
-
|
|
|
|
- //Blast Mining
|
|
|
|
- if (skillValue >= blastMiningRank8) {
|
|
|
|
|
|
+ //SUPER BREAKER
|
|
|
|
+ String[] superBreakerStrings = calculateLengthDisplayValues();
|
|
|
|
+ superBreakerLength = superBreakerStrings[0];
|
|
|
|
+ superBreakerLengthEndurance = superBreakerStrings[1];
|
|
|
|
+
|
|
|
|
+ //DOUBLE DROPS
|
|
|
|
+ String[] doubleDropStrings = calculateAbilityDisplayValues(Mining.doubleDropsMaxLevel, Mining.doubleDropsMaxChance);
|
|
|
|
+ doubleDropChance = doubleDropStrings[0];
|
|
|
|
+ doubleDropChanceLucky = doubleDropStrings[1];
|
|
|
|
+
|
|
|
|
+ //BLAST MINING
|
|
|
|
+ if (skillValue >= BlastMining.rank8) {
|
|
blastMiningRank = "8";
|
|
blastMiningRank = "8";
|
|
blastDamageDecrease = "100.00%";
|
|
blastDamageDecrease = "100.00%";
|
|
blastRadiusIncrease = "4";
|
|
blastRadiusIncrease = "4";
|
|
}
|
|
}
|
|
- else if (skillValue >= blastMiningRank7) {
|
|
|
|
|
|
+ else if (skillValue >= BlastMining.rank7) {
|
|
blastMiningRank = "7";
|
|
blastMiningRank = "7";
|
|
blastDamageDecrease = "50.00%";
|
|
blastDamageDecrease = "50.00%";
|
|
blastRadiusIncrease = "3";
|
|
blastRadiusIncrease = "3";
|
|
}
|
|
}
|
|
- else if (skillValue >= blastMiningRank6) {
|
|
|
|
|
|
+ else if (skillValue >= BlastMining.rank6) {
|
|
blastMiningRank = "6";
|
|
blastMiningRank = "6";
|
|
blastDamageDecrease = "50.00%";
|
|
blastDamageDecrease = "50.00%";
|
|
blastRadiusIncrease = "3";
|
|
blastRadiusIncrease = "3";
|
|
}
|
|
}
|
|
- else if (skillValue >= blastMiningRank5) {
|
|
|
|
|
|
+ else if (skillValue >= BlastMining.rank5) {
|
|
blastMiningRank = "5";
|
|
blastMiningRank = "5";
|
|
blastDamageDecrease = "25.00%";
|
|
blastDamageDecrease = "25.00%";
|
|
blastRadiusIncrease = "2";
|
|
blastRadiusIncrease = "2";
|
|
}
|
|
}
|
|
- else if (skillValue >= blastMiningRank4) {
|
|
|
|
|
|
+ else if (skillValue >= BlastMining.rank4) {
|
|
blastMiningRank = "4";
|
|
blastMiningRank = "4";
|
|
blastDamageDecrease = "25.00%";
|
|
blastDamageDecrease = "25.00%";
|
|
blastRadiusIncrease = "2";
|
|
blastRadiusIncrease = "2";
|
|
}
|
|
}
|
|
- else if (skillValue >= blastMiningRank3) {
|
|
|
|
|
|
+ else if (skillValue >= BlastMining.rank3) {
|
|
blastMiningRank = "3";
|
|
blastMiningRank = "3";
|
|
blastDamageDecrease = "0.00%";
|
|
blastDamageDecrease = "0.00%";
|
|
blastRadiusIncrease = "1";
|
|
blastRadiusIncrease = "1";
|
|
}
|
|
}
|
|
- else if (skillValue >= blastMiningRank2) {
|
|
|
|
|
|
+ else if (skillValue >= BlastMining.rank2) {
|
|
blastMiningRank = "2";
|
|
blastMiningRank = "2";
|
|
blastDamageDecrease = "0.00%";
|
|
blastDamageDecrease = "0.00%";
|
|
blastRadiusIncrease = "1";
|
|
blastRadiusIncrease = "1";
|
|
}
|
|
}
|
|
- else if (skillValue >= blastMiningRank1) {
|
|
|
|
|
|
+ else if (skillValue >= BlastMining.rank1) {
|
|
blastMiningRank = "1";
|
|
blastMiningRank = "1";
|
|
blastDamageDecrease = "0.00%";
|
|
blastDamageDecrease = "0.00%";
|
|
blastRadiusIncrease = "0";
|
|
blastRadiusIncrease = "0";
|
|
@@ -123,16 +90,12 @@ public class MiningCommand extends SkillCommand {
|
|
|
|
|
|
@Override
|
|
@Override
|
|
protected void permissionsCheck() {
|
|
protected void permissionsCheck() {
|
|
- Config configInstance = Config.getInstance();
|
|
|
|
-
|
|
|
|
canBiggerBombs = Permissions.biggerBombs(player);
|
|
canBiggerBombs = Permissions.biggerBombs(player);
|
|
canBlast = Permissions.blastMining(player);
|
|
canBlast = Permissions.blastMining(player);
|
|
canDemoExpert = Permissions.demolitionsExpertise(player);
|
|
canDemoExpert = Permissions.demolitionsExpertise(player);
|
|
canDoubleDrop = Permissions.miningDoubleDrops(player);
|
|
canDoubleDrop = Permissions.miningDoubleDrops(player);
|
|
canSuperBreaker = Permissions.superBreaker(player);
|
|
canSuperBreaker = Permissions.superBreaker(player);
|
|
- doubleDropsDisabled = configInstance.miningDoubleDropsDisabled();
|
|
|
|
- lucky = Permissions.luckyMining(player);
|
|
|
|
- endurance = Permissions.activationTwelve(player) || Permissions.activationEight(player) || Permissions.activationFour(player);
|
|
|
|
|
|
+ doubleDropsDisabled = Mining.doubleDropsDisabled;
|
|
}
|
|
}
|
|
|
|
|
|
@Override
|
|
@Override
|
|
@@ -142,10 +105,7 @@ public class MiningCommand extends SkillCommand {
|
|
|
|
|
|
@Override
|
|
@Override
|
|
protected void effectsDisplay() {
|
|
protected void effectsDisplay() {
|
|
- if (lucky) {
|
|
|
|
- String perkPrefix = LocaleLoader.getString("MOTD.PerksPrefix");
|
|
|
|
- player.sendMessage(perkPrefix + LocaleLoader.getString("Effects.Template", new Object[] { LocaleLoader.getString("Perks.lucky.name"), LocaleLoader.getString("Perks.lucky.desc", new Object[] { Skills.localizeSkillName(SkillType.MINING) }) }));
|
|
|
|
- }
|
|
|
|
|
|
+ luckyEffectsDisplay();
|
|
|
|
|
|
if (canSuperBreaker) {
|
|
if (canSuperBreaker) {
|
|
player.sendMessage(LocaleLoader.getString("Effects.Template", new Object[] { LocaleLoader.getString("Mining.Effect.0"), LocaleLoader.getString("Mining.Effect.1") }));
|
|
player.sendMessage(LocaleLoader.getString("Effects.Template", new Object[] { LocaleLoader.getString("Mining.Effect.0"), LocaleLoader.getString("Mining.Effect.1") }));
|
|
@@ -176,22 +136,26 @@ public class MiningCommand extends SkillCommand {
|
|
@Override
|
|
@Override
|
|
protected void statsDisplay() {
|
|
protected void statsDisplay() {
|
|
if (canDoubleDrop && !doubleDropsDisabled) {
|
|
if (canDoubleDrop && !doubleDropsDisabled) {
|
|
- if (lucky)
|
|
|
|
|
|
+ if (isLucky) {
|
|
player.sendMessage(LocaleLoader.getString("Mining.Effect.DropChance", new Object[] { doubleDropChance }) + LocaleLoader.getString("Perks.lucky.bonus", new Object[] { doubleDropChanceLucky }));
|
|
player.sendMessage(LocaleLoader.getString("Mining.Effect.DropChance", new Object[] { doubleDropChance }) + LocaleLoader.getString("Perks.lucky.bonus", new Object[] { doubleDropChanceLucky }));
|
|
- else
|
|
|
|
|
|
+ }
|
|
|
|
+ else {
|
|
player.sendMessage(LocaleLoader.getString("Mining.Effect.DropChance", new Object[] { doubleDropChance }));
|
|
player.sendMessage(LocaleLoader.getString("Mining.Effect.DropChance", new Object[] { doubleDropChance }));
|
|
|
|
+ }
|
|
}
|
|
}
|
|
|
|
|
|
if (canSuperBreaker) {
|
|
if (canSuperBreaker) {
|
|
- if (endurance)
|
|
|
|
|
|
+ if (hasEndurance) {
|
|
player.sendMessage(LocaleLoader.getString("Mining.Ability.Length", new Object[] { superBreakerLength }) + LocaleLoader.getString("Perks.activationtime.bonus", new Object[] { superBreakerLengthEndurance }));
|
|
player.sendMessage(LocaleLoader.getString("Mining.Ability.Length", new Object[] { superBreakerLength }) + LocaleLoader.getString("Perks.activationtime.bonus", new Object[] { superBreakerLengthEndurance }));
|
|
- else
|
|
|
|
|
|
+ }
|
|
|
|
+ else {
|
|
player.sendMessage(LocaleLoader.getString("Mining.Ability.Length", new Object[] { superBreakerLength }));
|
|
player.sendMessage(LocaleLoader.getString("Mining.Ability.Length", new Object[] { superBreakerLength }));
|
|
|
|
+ }
|
|
}
|
|
}
|
|
|
|
|
|
if (canBlast) {
|
|
if (canBlast) {
|
|
- if (skillValue < blastMiningRank1) {
|
|
|
|
- player.sendMessage(LocaleLoader.getString("Ability.Generic.Template.Lock", new Object[] { LocaleLoader.getString("Mining.Ability.Locked.0", new Object[] { blastMiningRank1 }) }));
|
|
|
|
|
|
+ if (skillValue < BlastMining.rank1) {
|
|
|
|
+ player.sendMessage(LocaleLoader.getString("Ability.Generic.Template.Lock", new Object[] { LocaleLoader.getString("Mining.Ability.Locked.0", new Object[] { BlastMining.rank1 }) }));
|
|
}
|
|
}
|
|
else {
|
|
else {
|
|
player.sendMessage(LocaleLoader.getString("Mining.Blast.Rank", new Object[] { blastMiningRank, LocaleLoader.getString("Mining.Blast.Effect." + (Misc.getInt(blastMiningRank) - 1)) }));
|
|
player.sendMessage(LocaleLoader.getString("Mining.Blast.Rank", new Object[] { blastMiningRank, LocaleLoader.getString("Mining.Blast.Effect." + (Misc.getInt(blastMiningRank) - 1)) }));
|
|
@@ -199,8 +163,8 @@ public class MiningCommand extends SkillCommand {
|
|
}
|
|
}
|
|
|
|
|
|
if (canBiggerBombs) {
|
|
if (canBiggerBombs) {
|
|
- if (skillValue < blastMiningRank2) {
|
|
|
|
- player.sendMessage(LocaleLoader.getString("Ability.Generic.Template.Lock", new Object[] { LocaleLoader.getString("Mining.Ability.Locked.1", new Object[] { blastMiningRank2 }) }));
|
|
|
|
|
|
+ if (skillValue < BlastMining.rank2) {
|
|
|
|
+ player.sendMessage(LocaleLoader.getString("Ability.Generic.Template.Lock", new Object[] { LocaleLoader.getString("Mining.Ability.Locked.1", new Object[] { BlastMining.rank2 }) }));
|
|
}
|
|
}
|
|
else {
|
|
else {
|
|
player.sendMessage(LocaleLoader.getString("Mining.Blast.Radius.Increase", new Object[] { blastRadiusIncrease }));
|
|
player.sendMessage(LocaleLoader.getString("Mining.Blast.Radius.Increase", new Object[] { blastRadiusIncrease }));
|
|
@@ -208,8 +172,8 @@ public class MiningCommand extends SkillCommand {
|
|
}
|
|
}
|
|
|
|
|
|
if (canDemoExpert) {
|
|
if (canDemoExpert) {
|
|
- if (skillValue < blastMiningRank4) {
|
|
|
|
- player.sendMessage(LocaleLoader.getString("Ability.Generic.Template.Lock", new Object[] { LocaleLoader.getString("Mining.Ability.Locked.2", new Object[] { blastMiningRank4 }) }));
|
|
|
|
|
|
+ if (skillValue < BlastMining.rank4) {
|
|
|
|
+ player.sendMessage(LocaleLoader.getString("Ability.Generic.Template.Lock", new Object[] { LocaleLoader.getString("Mining.Ability.Locked.2", new Object[] { BlastMining.rank4 }) }));
|
|
}
|
|
}
|
|
else {
|
|
else {
|
|
player.sendMessage(LocaleLoader.getString("Mining.Effect.Decrease", new Object[] { blastDamageDecrease }));
|
|
player.sendMessage(LocaleLoader.getString("Mining.Effect.Decrease", new Object[] { blastDamageDecrease }));
|