2012-01-09 20:00:13 +01:00
|
|
|
package com.gmail.nossr50.commands.skills;
|
|
|
|
|
2012-11-22 22:40:55 +01:00
|
|
|
import org.bukkit.ChatColor;
|
|
|
|
|
2012-05-31 20:08:17 +02:00
|
|
|
import com.gmail.nossr50.commands.SkillCommand;
|
2012-11-21 21:49:54 +01:00
|
|
|
import com.gmail.nossr50.config.AdvancedConfig;
|
2012-01-09 20:00:13 +01:00
|
|
|
import com.gmail.nossr50.datatypes.SkillType;
|
2012-04-27 11:47:11 +02:00
|
|
|
import com.gmail.nossr50.locale.LocaleLoader;
|
2013-01-14 18:41:39 +01:00
|
|
|
import com.gmail.nossr50.skills.archery.Archery;
|
2013-01-16 05:30:58 +01:00
|
|
|
import com.gmail.nossr50.util.Misc;
|
2013-01-07 02:52:31 +01:00
|
|
|
import com.gmail.nossr50.util.Permissions;
|
2012-01-09 20:00:13 +01:00
|
|
|
|
2012-05-31 20:08:17 +02:00
|
|
|
public class ArcheryCommand extends SkillCommand {
|
2012-11-26 01:18:30 +01:00
|
|
|
AdvancedConfig advancedConfig = AdvancedConfig.getInstance();
|
2012-11-21 21:49:54 +01:00
|
|
|
|
2012-11-26 01:18:30 +01:00
|
|
|
private String skillShotBonus;
|
|
|
|
private String dazeChance;
|
2013-01-06 12:16:08 +01:00
|
|
|
private String dazeChanceLucky;
|
2012-11-26 01:18:30 +01:00
|
|
|
private String retrieveChance;
|
2013-01-06 12:16:08 +01:00
|
|
|
private String retrieveChanceLucky;
|
2012-11-21 21:49:54 +01:00
|
|
|
|
2012-11-26 01:18:30 +01:00
|
|
|
private boolean canSkillShot;
|
|
|
|
private boolean canDaze;
|
|
|
|
private boolean canRetrieve;
|
2013-01-07 02:52:31 +01:00
|
|
|
private boolean lucky;
|
2012-11-21 21:49:54 +01:00
|
|
|
|
2012-11-26 01:18:30 +01:00
|
|
|
public ArcheryCommand() {
|
|
|
|
super(SkillType.ARCHERY);
|
|
|
|
}
|
2012-11-21 21:49:54 +01:00
|
|
|
|
2012-11-26 01:18:30 +01:00
|
|
|
@Override
|
|
|
|
protected void dataCalculations() {
|
2013-01-06 12:16:08 +01:00
|
|
|
float dazeChanceF;
|
|
|
|
float retrieveChanceF;
|
|
|
|
|
2012-11-26 01:18:30 +01:00
|
|
|
// SkillShot
|
2013-01-14 18:41:39 +01:00
|
|
|
double bonus = (int)((double) skillValue / (double) Archery.skillShotIncreaseLevel) * Archery.skillShotIncreasePercentage;
|
|
|
|
if (bonus > Archery.skillShotMaxBonusPercentage) skillShotBonus = percent.format(Archery.skillShotMaxBonusPercentage);
|
2012-11-21 21:49:54 +01:00
|
|
|
else skillShotBonus = percent.format(bonus);
|
2012-12-24 22:56:25 +01:00
|
|
|
|
2012-11-26 01:18:30 +01:00
|
|
|
// Daze
|
2013-01-14 18:41:39 +01:00
|
|
|
if (skillValue >= Archery.dazeMaxBonusLevel) dazeChanceF = (float) Archery.dazeMaxBonus;
|
|
|
|
else dazeChanceF = (float) (( Archery.dazeMaxBonus / Archery.dazeMaxBonusLevel) * skillValue);
|
2013-01-11 19:07:00 +01:00
|
|
|
dazeChance = percent.format(dazeChanceF / 100D);
|
2013-01-13 00:11:23 +01:00
|
|
|
if (dazeChanceF * 1.3333D >= 100D) dazeChanceLucky = percent.format(1D);
|
|
|
|
else dazeChanceLucky = percent.format(dazeChanceF * 1.3333D / 100D);
|
2012-11-26 01:18:30 +01:00
|
|
|
|
|
|
|
// Retrieve
|
2013-01-14 18:41:39 +01:00
|
|
|
if (skillValue >= Archery.retrieveMaxBonusLevel) retrieveChanceF = (float) Archery.retrieveMaxChance;
|
|
|
|
else retrieveChanceF = (float) ((Archery.retrieveMaxChance / Archery.retrieveMaxBonusLevel) * skillValue);
|
2013-01-11 19:07:00 +01:00
|
|
|
retrieveChance = percent.format(retrieveChanceF / 100D);
|
2013-01-13 00:11:23 +01:00
|
|
|
if (retrieveChanceF * 1.3333D >= 100D) retrieveChanceLucky = percent.format(1D);
|
|
|
|
else retrieveChanceLucky = percent.format(retrieveChanceF * 1.3333D / 100D);
|
2012-11-26 01:18:30 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
protected void permissionsCheck() {
|
2013-01-07 02:52:31 +01:00
|
|
|
canSkillShot = Permissions.archeryBonus(player);
|
|
|
|
canDaze = Permissions.daze(player);
|
|
|
|
canRetrieve = Permissions.trackArrows(player);
|
|
|
|
lucky = Permissions.luckyArchery(player);
|
2012-11-26 01:18:30 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
protected boolean effectsHeaderPermissions() {
|
|
|
|
return canSkillShot || canDaze || canRetrieve;
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
protected void effectsDisplay() {
|
2013-01-07 02:52:31 +01:00
|
|
|
if (lucky) {
|
2012-12-24 22:56:25 +01:00
|
|
|
String perkPrefix = ChatColor.RED + "[mcMMO Perks] ";
|
2013-01-16 05:30:58 +01:00
|
|
|
player.sendMessage(perkPrefix + LocaleLoader.getString("Effects.Template", new Object[] { LocaleLoader.getString("Perks.lucky.name"), LocaleLoader.getString("Perks.lucky.desc", new Object[] { Misc.getCapitalized(LocaleLoader.getString("Archery.SkillName")) }) }));
|
2012-12-24 22:56:25 +01:00
|
|
|
}
|
2012-11-22 22:40:55 +01:00
|
|
|
|
2012-11-26 01:18:30 +01:00
|
|
|
if (canSkillShot) {
|
|
|
|
player.sendMessage(LocaleLoader.getString("Effects.Template", new Object[] { LocaleLoader.getString("Archery.Effect.0"), LocaleLoader.getString("Archery.Effect.1") }));
|
|
|
|
}
|
|
|
|
|
|
|
|
if (canDaze) {
|
|
|
|
player.sendMessage(LocaleLoader.getString("Effects.Template", new Object[] { LocaleLoader.getString("Archery.Effect.2"), LocaleLoader.getString("Archery.Effect.3") }));
|
|
|
|
}
|
|
|
|
|
|
|
|
if (canRetrieve) {
|
|
|
|
player.sendMessage(LocaleLoader.getString("Effects.Template", new Object[] { LocaleLoader.getString("Archery.Effect.4"), LocaleLoader.getString("Archery.Effect.5") }));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
protected boolean statsHeaderPermissions() {
|
|
|
|
return canSkillShot || canDaze || canRetrieve;
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
protected void statsDisplay() {
|
|
|
|
if (canSkillShot) {
|
2013-01-06 12:16:08 +01:00
|
|
|
player.sendMessage(LocaleLoader.getString("Archery.Combat.SkillshotBonus", new Object[] { skillShotBonus }));
|
2012-11-26 01:18:30 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
if (canDaze) {
|
2013-01-10 19:45:36 +01:00
|
|
|
if (lucky)
|
2013-01-06 12:16:08 +01:00
|
|
|
player.sendMessage(LocaleLoader.getString("Archery.Combat.DazeChance", new Object[] { dazeChance }) + LocaleLoader.getString("Perks.lucky.bonus", new Object[] { dazeChanceLucky }));
|
|
|
|
else
|
|
|
|
player.sendMessage(LocaleLoader.getString("Archery.Combat.DazeChance", new Object[] { dazeChance }));
|
2012-11-26 01:18:30 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
if (canRetrieve) {
|
2013-01-10 19:45:36 +01:00
|
|
|
if (lucky)
|
2013-01-06 12:16:08 +01:00
|
|
|
player.sendMessage(LocaleLoader.getString("Archery.Combat.RetrieveChance", new Object[] { retrieveChance }) + LocaleLoader.getString("Perks.lucky.bonus", new Object[] { retrieveChanceLucky }));
|
|
|
|
else
|
|
|
|
player.sendMessage(LocaleLoader.getString("Archery.Combat.RetrieveChance", new Object[] { retrieveChance }));
|
2012-11-26 01:18:30 +01:00
|
|
|
}
|
|
|
|
}
|
2012-01-09 20:00:13 +01:00
|
|
|
}
|