2012-01-09 20:00:13 +01:00
|
|
|
package com.gmail.nossr50.commands.skills;
|
|
|
|
|
2012-05-31 20:08:17 +02:00
|
|
|
import com.gmail.nossr50.commands.SkillCommand;
|
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;
|
2012-01-09 20:00:13 +01:00
|
|
|
|
2012-05-31 20:08:17 +02:00
|
|
|
public class ArcheryCommand extends SkillCommand {
|
2012-04-24 00:05:30 +02:00
|
|
|
private String skillShotBonus;
|
|
|
|
private String dazeChance;
|
|
|
|
private String retrieveChance;
|
|
|
|
|
2012-04-30 04:58:54 +02:00
|
|
|
private boolean canSkillShot;
|
|
|
|
private boolean canDaze;
|
|
|
|
private boolean canRetrieve;
|
|
|
|
|
2012-05-31 20:08:17 +02:00
|
|
|
public ArcheryCommand() {
|
|
|
|
super(SkillType.ARCHERY);
|
|
|
|
}
|
|
|
|
|
2012-04-24 00:05:30 +02:00
|
|
|
@Override
|
2012-05-31 20:08:17 +02:00
|
|
|
protected void dataCalculations() {
|
|
|
|
if (skillValue >= 1000) {
|
|
|
|
skillShotBonus = "200.00%";
|
|
|
|
dazeChance = "50.00%";
|
|
|
|
retrieveChance = "100.00%";
|
2012-04-24 00:05:30 +02:00
|
|
|
}
|
2012-05-31 20:08:17 +02:00
|
|
|
else {
|
|
|
|
skillShotBonus = percent.format(((int) skillValue / 50) * 0.1D); //TODO: Not sure if this is the best way to calculate this or not...
|
|
|
|
dazeChance = percent.format(skillValue / 2000);
|
|
|
|
retrieveChance = percent.format(skillValue / 1000);
|
2012-04-04 16:57:13 +02:00
|
|
|
}
|
2012-05-31 20:08:17 +02:00
|
|
|
}
|
2012-01-09 20:00:13 +01:00
|
|
|
|
2012-05-31 20:08:17 +02:00
|
|
|
@Override
|
|
|
|
protected void permissionsCheck() {
|
|
|
|
canSkillShot = permInstance.archeryBonus(player);
|
|
|
|
canDaze = permInstance.daze(player);
|
|
|
|
canRetrieve = permInstance.trackArrows(player);
|
|
|
|
}
|
2012-01-09 20:00:13 +01:00
|
|
|
|
2012-05-31 20:08:17 +02:00
|
|
|
@Override
|
|
|
|
protected boolean effectsHeaderPermissions() {
|
|
|
|
return canSkillShot || canDaze || canRetrieve;
|
|
|
|
}
|
2012-04-30 04:58:54 +02:00
|
|
|
|
2012-05-31 20:08:17 +02:00
|
|
|
@Override
|
|
|
|
protected void effectsDisplay() {
|
2012-04-30 04:58:54 +02: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") }));
|
|
|
|
}
|
2012-01-09 20:00:13 +01:00
|
|
|
|
2012-04-30 04:58:54 +02:00
|
|
|
if (canRetrieve) {
|
|
|
|
player.sendMessage(LocaleLoader.getString("Effects.Template", new Object[] { LocaleLoader.getString("Archery.Effect.4"), LocaleLoader.getString("Archery.Effect.5") }));
|
|
|
|
}
|
2012-05-31 20:08:17 +02:00
|
|
|
}
|
2012-04-30 04:58:54 +02:00
|
|
|
|
2012-05-31 20:08:17 +02:00
|
|
|
@Override
|
|
|
|
protected boolean statsHeaderPermissions() {
|
|
|
|
return canSkillShot || canDaze || canRetrieve;
|
|
|
|
}
|
2012-04-30 04:58:54 +02:00
|
|
|
|
2012-05-31 20:08:17 +02:00
|
|
|
@Override
|
|
|
|
protected void statsDisplay() {
|
2012-04-30 04:58:54 +02:00
|
|
|
if (canSkillShot) {
|
|
|
|
player.sendMessage(LocaleLoader.getString("Archery.Combat.SkillshotBonus", new Object[] { skillShotBonus }));
|
|
|
|
}
|
|
|
|
|
|
|
|
if (canDaze) {
|
|
|
|
player.sendMessage(LocaleLoader.getString("Archery.Combat.DazeChance", new Object[] { dazeChance }));
|
|
|
|
}
|
|
|
|
|
|
|
|
if (canRetrieve) {
|
|
|
|
player.sendMessage(LocaleLoader.getString("Archery.Combat.RetrieveChance", new Object[] { retrieveChance }));
|
|
|
|
}
|
|
|
|
}
|
2012-01-09 20:00:13 +01:00
|
|
|
}
|