mirror of
https://github.com/mcMMO-Dev/mcMMO.git
synced 2024-11-26 23:26:45 +01:00
Update to SpoutStuff.java
This commit is contained in:
parent
664c9d9953
commit
f2be996e3d
@ -236,7 +236,7 @@ public class HUDmmo
|
|||||||
((GenericTexture) xpicon).setUrl(m.getCapitalized(theType.toString())+".png");
|
((GenericTexture) xpicon).setUrl(m.getCapitalized(theType.toString())+".png");
|
||||||
xpicon.setDirty(true);
|
xpicon.setDirty(true);
|
||||||
|
|
||||||
((GenericTexture) xpbar).setUrl(SpoutStuff.getUrlBar(SpoutStuff.getXpInc(PP.getSkillXpLevel(theType), PP.getXpToLevel(theType), HUDType.STANDARD)));
|
((GenericTexture) xpbar).setUrl(getUrlBar(getXpInc(PP.getSkillXpLevel(theType), PP.getXpToLevel(theType), HUDType.STANDARD)));
|
||||||
xpbar.setDirty(true);
|
xpbar.setDirty(true);
|
||||||
|
|
||||||
SpoutManager.getPlayer(player).getMainScreen().setDirty(true);
|
SpoutManager.getPlayer(player).getMainScreen().setDirty(true);
|
||||||
@ -256,16 +256,82 @@ public class HUDmmo
|
|||||||
if(theType == null)
|
if(theType == null)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
Color color = SpoutStuff.getRetroColor(theType);
|
Color color = getRetroColor(theType);
|
||||||
|
|
||||||
if(xpicon != null && theType != null)
|
if(xpicon != null && theType != null)
|
||||||
xpicon.setUrl(m.getCapitalized(theType.toString())+"_r.png");
|
xpicon.setUrl(m.getCapitalized(theType.toString())+"_r.png");
|
||||||
|
|
||||||
if(theType != null)
|
if(theType != null)
|
||||||
xpfill.setBottomColor(color).setTopColor(color).setWidth(SpoutStuff.getXpInc(PP.getSkillXpLevel(theType), PP.getXpToLevel(theType), HUDType.RETRO)).setDirty(true);
|
xpfill.setBottomColor(color).setTopColor(color).setWidth(getXpInc(PP.getSkillXpLevel(theType), PP.getXpToLevel(theType), HUDType.RETRO)).setDirty(true);
|
||||||
else
|
else
|
||||||
System.out.println("theType was null!");
|
System.out.println("theType was null!");
|
||||||
|
|
||||||
SpoutManager.getPlayer(player).getMainScreen().setDirty(true);
|
SpoutManager.getPlayer(player).getMainScreen().setDirty(true);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private static Color getRetroColor(SkillType type) {
|
||||||
|
switch (type) {
|
||||||
|
case ACROBATICS:
|
||||||
|
return new Color((float) LoadProperties.acrobatics_r, (float) LoadProperties.acrobatics_g, (float) LoadProperties.acrobatics_b, 1f);
|
||||||
|
case ARCHERY:
|
||||||
|
return new Color((float) LoadProperties.archery_r, (float)LoadProperties.archery_g, (float)LoadProperties.archery_b, 1f);
|
||||||
|
case AXES:
|
||||||
|
return new Color((float) LoadProperties.axes_r, (float)LoadProperties.axes_g, (float)LoadProperties.axes_b, 1f);
|
||||||
|
case EXCAVATION:
|
||||||
|
return new Color((float)LoadProperties.excavation_r, (float)LoadProperties.excavation_g, (float)LoadProperties.excavation_b, 1f);
|
||||||
|
case HERBALISM:
|
||||||
|
return new Color((float)LoadProperties.herbalism_r, (float)LoadProperties.herbalism_g, (float)LoadProperties.herbalism_b, 1f);
|
||||||
|
case MINING:
|
||||||
|
return new Color((float)LoadProperties.mining_r, (float)LoadProperties.mining_g, (float)LoadProperties.mining_b, 1f);
|
||||||
|
case REPAIR:
|
||||||
|
return new Color((float)LoadProperties.repair_r, (float)LoadProperties.repair_g, (float)LoadProperties.repair_b, 1f);
|
||||||
|
case SWORDS:
|
||||||
|
return new Color((float)LoadProperties.swords_r, (float)LoadProperties.swords_g, (float)LoadProperties.swords_b, 1f);
|
||||||
|
case TAMING:
|
||||||
|
return new Color((float)LoadProperties.taming_r, (float)LoadProperties.taming_g, (float)LoadProperties.taming_b, 1f);
|
||||||
|
case UNARMED:
|
||||||
|
return new Color((float)LoadProperties.unarmed_r, (float)LoadProperties.unarmed_g, (float)LoadProperties.unarmed_b, 1f);
|
||||||
|
case WOODCUTTING:
|
||||||
|
return new Color((float)LoadProperties.woodcutting_r, (float)LoadProperties.woodcutting_g, (float)LoadProperties.woodcutting_b, 1f);
|
||||||
|
case FISHING:
|
||||||
|
return new Color((float)LoadProperties.fishing_r, (float)LoadProperties.fishing_g, (float)LoadProperties.fishing_b, 1f);
|
||||||
|
default:
|
||||||
|
return new Color(0.3f, 0.3f, 0.75f, 1f);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private static String getUrlBar(Integer number) {
|
||||||
|
char[] num = number.toString().toCharArray();
|
||||||
|
|
||||||
|
switch (num.length) {
|
||||||
|
case 1:
|
||||||
|
return "xpbar_inc00"+number+".png";
|
||||||
|
|
||||||
|
case 2:
|
||||||
|
return "xpbar_inc0"+number+".png";
|
||||||
|
|
||||||
|
default:
|
||||||
|
return "xpbar_inc"+number+".png";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private static Integer getXpInc(int skillxp, int xptolevel, HUDType hud) {
|
||||||
|
double percentage = (double) skillxp / xptolevel;
|
||||||
|
double inc;
|
||||||
|
|
||||||
|
switch (hud) {
|
||||||
|
case RETRO:
|
||||||
|
inc = 0.0079365079365079;
|
||||||
|
break;
|
||||||
|
|
||||||
|
case STANDARD:
|
||||||
|
inc = 0.0039370078740157;
|
||||||
|
break;
|
||||||
|
|
||||||
|
default:
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
return (int) (percentage / inc);
|
||||||
|
}
|
||||||
}
|
}
|
@ -16,8 +16,7 @@ import com.gmail.nossr50.skills.Herbalism;
|
|||||||
import com.gmail.nossr50.skills.Mining;
|
import com.gmail.nossr50.skills.Mining;
|
||||||
import com.gmail.nossr50.skills.Skills;
|
import com.gmail.nossr50.skills.Skills;
|
||||||
import com.gmail.nossr50.skills.WoodCutting;
|
import com.gmail.nossr50.skills.WoodCutting;
|
||||||
import com.gmail.nossr50.spout.SpoutStuff;
|
import com.gmail.nossr50.spout.SpoutSounds;
|
||||||
|
|
||||||
|
|
||||||
import org.bukkit.Bukkit;
|
import org.bukkit.Bukkit;
|
||||||
import org.bukkit.CropState;
|
import org.bukkit.CropState;
|
||||||
@ -274,7 +273,7 @@ public class mcBlockListener implements Listener {
|
|||||||
|
|
||||||
/* TREE FELLER SOUNDS */
|
/* TREE FELLER SOUNDS */
|
||||||
if (LoadProperties.spoutEnabled && mat.equals(Material.LOG) && PP.getTreeFellerMode()) {
|
if (LoadProperties.spoutEnabled && mat.equals(Material.LOG) && PP.getTreeFellerMode()) {
|
||||||
SpoutStuff.playSoundForPlayer(SoundEffect.FIZZ, player, block.getLocation());
|
SpoutSounds.playSoundForPlayer(SoundEffect.FIZZ, player, block.getLocation());
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@ -302,7 +301,7 @@ public class mcBlockListener implements Listener {
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (LoadProperties.spoutEnabled) {
|
if (LoadProperties.spoutEnabled) {
|
||||||
SpoutStuff.playSoundForPlayer(SoundEffect.POP, player, block.getLocation());
|
SpoutSounds.playSoundForPlayer(SoundEffect.POP, player, block.getLocation());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else if (PP.getSuperBreakerMode() && Skills.triggerCheck(player, block, AbilityType.SUPER_BREAKER)) {
|
else if (PP.getSuperBreakerMode() && Skills.triggerCheck(player, block, AbilityType.SUPER_BREAKER)) {
|
||||||
|
@ -14,14 +14,14 @@ import java.util.Iterator;
|
|||||||
|
|
||||||
import org.bukkit.Bukkit;
|
import org.bukkit.Bukkit;
|
||||||
import org.bukkit.entity.Player;
|
import org.bukkit.entity.Player;
|
||||||
|
|
||||||
import com.gmail.nossr50.Users;
|
import com.gmail.nossr50.Users;
|
||||||
import com.gmail.nossr50.mcMMO;
|
import com.gmail.nossr50.mcMMO;
|
||||||
import com.gmail.nossr50.datatypes.PlayerProfile;
|
import com.gmail.nossr50.datatypes.PlayerProfile;
|
||||||
import com.gmail.nossr50.locale.mcLocale;
|
import com.gmail.nossr50.locale.mcLocale;
|
||||||
|
|
||||||
|
|
||||||
public class Party
|
public class Party {
|
||||||
{
|
|
||||||
/*
|
/*
|
||||||
* This file is part of mmoMinecraft (http://code.google.com/p/mmo-minecraft/).
|
* This file is part of mmoMinecraft (http://code.google.com/p/mmo-minecraft/).
|
||||||
*
|
*
|
||||||
|
@ -11,7 +11,7 @@ import org.bukkit.entity.Player;
|
|||||||
import org.bukkit.inventory.ItemStack;
|
import org.bukkit.inventory.ItemStack;
|
||||||
import org.bukkit.event.player.PlayerAnimationEvent;
|
import org.bukkit.event.player.PlayerAnimationEvent;
|
||||||
|
|
||||||
import com.gmail.nossr50.spout.SpoutStuff;
|
import com.gmail.nossr50.spout.SpoutSounds;
|
||||||
import com.gmail.nossr50.Users;
|
import com.gmail.nossr50.Users;
|
||||||
import com.gmail.nossr50.m;
|
import com.gmail.nossr50.m;
|
||||||
import com.gmail.nossr50.mcPermissions;
|
import com.gmail.nossr50.mcPermissions;
|
||||||
@ -139,7 +139,7 @@ public class Excavation {
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (LoadProperties.spoutEnabled) {
|
if (LoadProperties.spoutEnabled) {
|
||||||
SpoutStuff.playSoundForPlayer(SoundEffect.POP, player, block.getLocation());
|
SpoutSounds.playSoundForPlayer(SoundEffect.POP, player, block.getLocation());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
@ -15,7 +15,7 @@ import com.gmail.nossr50.Users;
|
|||||||
import com.gmail.nossr50.m;
|
import com.gmail.nossr50.m;
|
||||||
import com.gmail.nossr50.mcPermissions;
|
import com.gmail.nossr50.mcPermissions;
|
||||||
import com.gmail.nossr50.config.LoadProperties;
|
import com.gmail.nossr50.config.LoadProperties;
|
||||||
import com.gmail.nossr50.spout.SpoutStuff;
|
import com.gmail.nossr50.spout.SpoutSounds;
|
||||||
import com.gmail.nossr50.datatypes.PlayerProfile;
|
import com.gmail.nossr50.datatypes.PlayerProfile;
|
||||||
import com.gmail.nossr50.datatypes.SkillType;
|
import com.gmail.nossr50.datatypes.SkillType;
|
||||||
|
|
||||||
@ -259,7 +259,7 @@ public class Mining
|
|||||||
miningBlockCheck(player, block);
|
miningBlockCheck(player, block);
|
||||||
|
|
||||||
if (LoadProperties.spoutEnabled) {
|
if (LoadProperties.spoutEnabled) {
|
||||||
SpoutStuff.playSoundForPlayer(SoundEffect.POP, player, block.getLocation());
|
SpoutSounds.playSoundForPlayer(SoundEffect.POP, player, block.getLocation());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -15,7 +15,7 @@ import com.gmail.nossr50.Users;
|
|||||||
import com.gmail.nossr50.m;
|
import com.gmail.nossr50.m;
|
||||||
import com.gmail.nossr50.mcPermissions;
|
import com.gmail.nossr50.mcPermissions;
|
||||||
import com.gmail.nossr50.config.LoadProperties;
|
import com.gmail.nossr50.config.LoadProperties;
|
||||||
import com.gmail.nossr50.spout.SpoutStuff;
|
import com.gmail.nossr50.spout.SpoutSounds;
|
||||||
import com.gmail.nossr50.datatypes.PlayerProfile;
|
import com.gmail.nossr50.datatypes.PlayerProfile;
|
||||||
import com.gmail.nossr50.datatypes.SkillType;
|
import com.gmail.nossr50.datatypes.SkillType;
|
||||||
import com.gmail.nossr50.locale.mcLocale;
|
import com.gmail.nossr50.locale.mcLocale;
|
||||||
@ -145,7 +145,7 @@ public class Repair {
|
|||||||
|
|
||||||
//CLANG CLANG
|
//CLANG CLANG
|
||||||
if (LoadProperties.spoutEnabled) {
|
if (LoadProperties.spoutEnabled) {
|
||||||
SpoutStuff.playRepairNoise(player);
|
SpoutSounds.playRepairNoise(player);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -20,7 +20,7 @@ import com.gmail.nossr50.config.LoadProperties;
|
|||||||
import com.gmail.nossr50.datatypes.PlayerProfile;
|
import com.gmail.nossr50.datatypes.PlayerProfile;
|
||||||
import com.gmail.nossr50.datatypes.SkillType;
|
import com.gmail.nossr50.datatypes.SkillType;
|
||||||
import com.gmail.nossr50.locale.mcLocale;
|
import com.gmail.nossr50.locale.mcLocale;
|
||||||
import com.gmail.nossr50.spout.SpoutStuff;
|
import com.gmail.nossr50.spout.SpoutSounds;
|
||||||
|
|
||||||
import org.getspout.spoutapi.sound.SoundEffect;
|
import org.getspout.spoutapi.sound.SoundEffect;
|
||||||
|
|
||||||
@ -311,7 +311,7 @@ public class WoodCutting {
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (LoadProperties.spoutEnabled) {
|
if (LoadProperties.spoutEnabled) {
|
||||||
SpoutStuff.playSoundForPlayer(SoundEffect.POP, player, block.getLocation());
|
SpoutSounds.playSoundForPlayer(SoundEffect.POP, player, block.getLocation());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
52
src/main/java/com/gmail/nossr50/spout/SpoutSounds.java
Normal file
52
src/main/java/com/gmail/nossr50/spout/SpoutSounds.java
Normal file
@ -0,0 +1,52 @@
|
|||||||
|
package com.gmail.nossr50.spout;
|
||||||
|
|
||||||
|
import org.bukkit.Bukkit;
|
||||||
|
import org.bukkit.Location;
|
||||||
|
import org.bukkit.entity.Player;
|
||||||
|
import org.getspout.spoutapi.SpoutManager;
|
||||||
|
import org.getspout.spoutapi.player.SpoutPlayer;
|
||||||
|
import org.getspout.spoutapi.sound.SoundEffect;
|
||||||
|
import org.getspout.spoutapi.sound.SoundManager;
|
||||||
|
|
||||||
|
public class SpoutSounds {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Play sound effect through Spout.
|
||||||
|
*
|
||||||
|
* @param effect The sound effect to play
|
||||||
|
* @param player The player to play the sound to
|
||||||
|
* @param location The location the sound should come from
|
||||||
|
*/
|
||||||
|
public static void playSoundForPlayer(SoundEffect effect, Player player, Location location) {
|
||||||
|
SoundManager SM = SpoutManager.getSoundManager();
|
||||||
|
SpoutPlayer sPlayer = SpoutManager.getPlayer(player);
|
||||||
|
|
||||||
|
SM.playSoundEffect(sPlayer, effect, location);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Play noise on successful repair.
|
||||||
|
*
|
||||||
|
* @param player The player who repaired an item
|
||||||
|
*/
|
||||||
|
public static void playRepairNoise(Player player) {
|
||||||
|
SoundManager SM = SpoutManager.getSoundManager();
|
||||||
|
SpoutPlayer sPlayer = SpoutManager.getPlayer(player);
|
||||||
|
|
||||||
|
//If this is pulling from online, why have it in the jar?
|
||||||
|
SM.playCustomSoundEffect(Bukkit.getServer().getPluginManager().getPlugin("mcMMO"), sPlayer, "repair.wav", false);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Play noise on level-up.
|
||||||
|
*
|
||||||
|
* @param player The player who leveled up
|
||||||
|
*/
|
||||||
|
protected static void playLevelUpNoise(Player player) {
|
||||||
|
SoundManager SM = SpoutManager.getSoundManager();
|
||||||
|
SpoutPlayer sPlayer = SpoutManager.getPlayer(player);
|
||||||
|
|
||||||
|
//If this is pulling from online, why have it in the jar?
|
||||||
|
SM.playCustomSoundEffect(Bukkit.getServer().getPluginManager().getPlugin("mcMMO"), sPlayer, "level.wav", false);
|
||||||
|
}
|
||||||
|
}
|
@ -14,21 +14,15 @@ import java.util.jar.JarFile;
|
|||||||
|
|
||||||
import org.bukkit.Bukkit;
|
import org.bukkit.Bukkit;
|
||||||
import org.bukkit.ChatColor;
|
import org.bukkit.ChatColor;
|
||||||
import org.bukkit.Location;
|
|
||||||
import org.bukkit.Material;
|
import org.bukkit.Material;
|
||||||
import org.bukkit.entity.Player;
|
import org.bukkit.entity.Player;
|
||||||
import org.getspout.spoutapi.SpoutManager;
|
import org.getspout.spoutapi.SpoutManager;
|
||||||
import org.getspout.spoutapi.gui.Color;
|
|
||||||
import org.getspout.spoutapi.keyboard.Keyboard;
|
import org.getspout.spoutapi.keyboard.Keyboard;
|
||||||
import org.getspout.spoutapi.player.SpoutPlayer;
|
import org.getspout.spoutapi.player.SpoutPlayer;
|
||||||
import org.getspout.spoutapi.sound.SoundEffect;
|
|
||||||
import org.getspout.spoutapi.sound.SoundManager;
|
|
||||||
|
|
||||||
import com.gmail.nossr50.Users;
|
import com.gmail.nossr50.Users;
|
||||||
import com.gmail.nossr50.m;
|
import com.gmail.nossr50.m;
|
||||||
import com.gmail.nossr50.mcMMO;
|
import com.gmail.nossr50.mcMMO;
|
||||||
import com.gmail.nossr50.config.LoadProperties;
|
|
||||||
import com.gmail.nossr50.datatypes.HUDType;
|
|
||||||
import com.gmail.nossr50.datatypes.HUDmmo;
|
import com.gmail.nossr50.datatypes.HUDmmo;
|
||||||
import com.gmail.nossr50.datatypes.PlayerProfile;
|
import com.gmail.nossr50.datatypes.PlayerProfile;
|
||||||
import com.gmail.nossr50.datatypes.popups.PopupMMO;
|
import com.gmail.nossr50.datatypes.popups.PopupMMO;
|
||||||
@ -37,8 +31,8 @@ import com.gmail.nossr50.listeners.mcSpoutInputListener;
|
|||||||
import com.gmail.nossr50.listeners.mcSpoutListener;
|
import com.gmail.nossr50.listeners.mcSpoutListener;
|
||||||
import com.gmail.nossr50.listeners.mcSpoutScreenListener;
|
import com.gmail.nossr50.listeners.mcSpoutScreenListener;
|
||||||
|
|
||||||
public class SpoutStuff
|
public class SpoutStuff {
|
||||||
{
|
|
||||||
static mcMMO plugin = (mcMMO) Bukkit.getServer().getPluginManager().getPlugin("mcMMO");
|
static mcMMO plugin = (mcMMO) Bukkit.getServer().getPluginManager().getPlugin("mcMMO");
|
||||||
|
|
||||||
private final static mcSpoutListener spoutListener = new mcSpoutListener(plugin);
|
private final static mcSpoutListener spoutListener = new mcSpoutListener(plugin);
|
||||||
@ -50,31 +44,46 @@ public class SpoutStuff
|
|||||||
|
|
||||||
public static Keyboard keypress;
|
public static Keyboard keypress;
|
||||||
|
|
||||||
public static void writeFile(String theFileName, String theFilePath)
|
/**
|
||||||
{
|
* Write file to disk.
|
||||||
|
*
|
||||||
|
* @param theFileName The name of the file
|
||||||
|
* @param theFilePath The name of the file path
|
||||||
|
*/
|
||||||
|
public static void writeFile(String theFileName, String theFilePath) {
|
||||||
try {
|
try {
|
||||||
File currentFile = new File("plugins/mcMMO/Resources/"+theFilePath+theFileName);
|
File currentFile = new File("plugins/mcMMO/Resources/" + theFilePath + theFileName);
|
||||||
|
|
||||||
@SuppressWarnings("static-access")
|
@SuppressWarnings("static-access")
|
||||||
JarFile jar = new JarFile(plugin.mcmmo);
|
JarFile jar = new JarFile(plugin.mcmmo);
|
||||||
JarEntry entry = jar.getJarEntry("resources/"+theFileName);
|
JarEntry entry = jar.getJarEntry("resources/" + theFileName);
|
||||||
InputStream is = jar.getInputStream(entry);
|
InputStream is = jar.getInputStream(entry);
|
||||||
|
|
||||||
byte[] buf = new byte[2048];
|
byte[] buf = new byte[2048];
|
||||||
int nbRead;
|
int nbRead;
|
||||||
|
|
||||||
OutputStream os = new BufferedOutputStream(new FileOutputStream(currentFile));
|
OutputStream os = new BufferedOutputStream(new FileOutputStream(currentFile));
|
||||||
while((nbRead = is.read(buf)) != -1) {
|
|
||||||
|
while ((nbRead = is.read(buf)) != -1) {
|
||||||
os.write(buf, 0, nbRead);
|
os.write(buf, 0, nbRead);
|
||||||
}
|
}
|
||||||
|
|
||||||
os.flush();
|
os.flush();
|
||||||
os.close();
|
os.close();
|
||||||
} catch (FileNotFoundException e) {
|
}
|
||||||
|
catch (FileNotFoundException e) {
|
||||||
e.printStackTrace();
|
e.printStackTrace();
|
||||||
} catch (IOException e) {
|
}
|
||||||
|
catch (IOException e) {
|
||||||
e.printStackTrace();
|
e.printStackTrace();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public static void extractFiles()
|
/**
|
||||||
{
|
* Extract Spout files to the Resources directory.
|
||||||
|
*/
|
||||||
|
public static void extractFiles() {
|
||||||
|
|
||||||
//Setup directories
|
//Setup directories
|
||||||
new File("plugins/mcMMO/Resources/").mkdir();
|
new File("plugins/mcMMO/Resources/").mkdir();
|
||||||
new File("plugins/mcMMO/Resources/HUD/").mkdir();
|
new File("plugins/mcMMO/Resources/HUD/").mkdir();
|
||||||
@ -82,478 +91,496 @@ public class SpoutStuff
|
|||||||
new File("plugins/mcMMO/Resources/HUD/Retro/").mkdir();
|
new File("plugins/mcMMO/Resources/HUD/Retro/").mkdir();
|
||||||
new File("plugins/mcMMO/Resources/Sound/").mkdir();
|
new File("plugins/mcMMO/Resources/Sound/").mkdir();
|
||||||
|
|
||||||
//Xp Bar images
|
//XP Bar images
|
||||||
for(int x =0; x < 255; x++)
|
for (int x = 0; x < 255; x++) {
|
||||||
{
|
|
||||||
//String s = File.separator;
|
|
||||||
String theFilePath = "HUD/Standard/";
|
String theFilePath = "HUD/Standard/";
|
||||||
if(x < 10)
|
String theFileName;
|
||||||
{
|
|
||||||
String theFileName = "xpbar_inc00"+x+".png";
|
if (x < 10) {
|
||||||
writeFile(theFileName, theFilePath);
|
theFileName = "xpbar_inc00" + x + ".png";
|
||||||
} else if (x < 100)
|
|
||||||
{
|
|
||||||
String theFileName = "xpbar_inc0"+x+".png";
|
|
||||||
writeFile(theFileName, theFilePath);
|
|
||||||
} else
|
|
||||||
{
|
|
||||||
String theFileName = "xpbar_inc"+x+".png";
|
|
||||||
writeFile(theFileName, theFilePath);
|
|
||||||
}
|
}
|
||||||
|
else if (x < 100) {
|
||||||
|
theFileName = "xpbar_inc0" + x + ".png";
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
theFileName = "xpbar_inc" + x + ".png";
|
||||||
|
}
|
||||||
|
|
||||||
|
writeFile(theFileName, theFilePath);
|
||||||
}
|
}
|
||||||
|
|
||||||
//Standard XP Icons
|
//Standard XP Icons
|
||||||
|
String standardFilePath = "HUD/Standard/";
|
||||||
|
String retroFilePath = "HUD/Retro/";
|
||||||
|
|
||||||
String theFilePathA = "HUD/Standard/";
|
for (SkillType y : SkillType.values()) {
|
||||||
String theFilePathB = "HUD/Retro/";
|
if (y.equals(SkillType.ALL)) {
|
||||||
|
|
||||||
for(SkillType y : SkillType.values())
|
|
||||||
{
|
|
||||||
if(y == SkillType.ALL)
|
|
||||||
continue;
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
String theFileNameA = m.getCapitalized(y.toString())+".png";
|
String standardFileName = m.getCapitalized(y.toString())+".png";
|
||||||
String theFileNameB = m.getCapitalized(y.toString())+"_r.png";
|
String retroFileName = m.getCapitalized(y.toString())+"_r.png";
|
||||||
|
|
||||||
writeFile(theFileNameA, theFilePathA);
|
writeFile(standardFileName, standardFilePath);
|
||||||
writeFile(theFileNameB, theFilePathB);
|
writeFile(retroFileName, retroFilePath);
|
||||||
}
|
}
|
||||||
|
|
||||||
//Blank icons
|
//Blank icons
|
||||||
|
writeFile("Icon.png", standardFilePath);
|
||||||
|
writeFile("Icon_r.png", retroFilePath);
|
||||||
|
|
||||||
writeFile("Icon.png", theFilePathA);
|
//Sound FX
|
||||||
writeFile("Icon_r.png", theFilePathB);
|
|
||||||
|
|
||||||
String theSoundFilePath = "Sound/";
|
String theSoundFilePath = "Sound/";
|
||||||
//Repair SFX
|
|
||||||
writeFile("repair.wav", theSoundFilePath);
|
writeFile("repair.wav", theSoundFilePath);
|
||||||
writeFile("level.wav", theSoundFilePath);
|
writeFile("level.wav", theSoundFilePath);
|
||||||
}
|
}
|
||||||
|
|
||||||
public static void setupSpoutConfigs()
|
/**
|
||||||
{
|
* Setup Spout config options
|
||||||
|
*/
|
||||||
|
public static void setupSpoutConfigs() {
|
||||||
String temp = plugin.getConfig().getString("Spout.Menu.Key", "KEY_M");
|
String temp = plugin.getConfig().getString("Spout.Menu.Key", "KEY_M");
|
||||||
|
|
||||||
for(Keyboard x : Keyboard.values())
|
for (Keyboard x : Keyboard.values()) {
|
||||||
{
|
if (x.toString().equalsIgnoreCase(temp)) {
|
||||||
if(x.toString().equalsIgnoreCase(temp))
|
|
||||||
{
|
|
||||||
keypress = x;
|
keypress = x;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if(keypress == null)
|
if (keypress == null) {
|
||||||
{
|
|
||||||
System.out.println("Invalid KEY for Spout.Menu.Key, using KEY_M");
|
System.out.println("Invalid KEY for Spout.Menu.Key, using KEY_M");
|
||||||
keypress = Keyboard.KEY_M;
|
keypress = Keyboard.KEY_M;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
public static ArrayList<File> getFiles()
|
|
||||||
{
|
/**
|
||||||
|
* Get all the Spout files in the Resources folder.
|
||||||
|
*
|
||||||
|
* @return a list of all files is the Resources folder
|
||||||
|
*/
|
||||||
|
public static ArrayList<File> getFiles() {
|
||||||
ArrayList<File> files = new ArrayList<File>();
|
ArrayList<File> files = new ArrayList<File>();
|
||||||
String dir = "plugins/mcMMO/Resources/";
|
String dir = "plugins/mcMMO/Resources/";
|
||||||
int x = 0;
|
|
||||||
|
|
||||||
//XP BAR
|
/* XP BAR */
|
||||||
while(x < 255)
|
for (int x = 0; x < 255; x++) {
|
||||||
{
|
if (x < 10) {
|
||||||
if(x < 10)
|
files.add(new File(dir + "HUD/Standard/xpbar_inc00" + x + ".png"));
|
||||||
{
|
}
|
||||||
files.add(new File(dir+"HUD/Standard/xpbar_inc00"+x+".png"));
|
else if (x < 100) {
|
||||||
} else if (x < 100)
|
files.add(new File(dir + "HUD/Standard/xpbar_inc0" + x + ".png"));
|
||||||
{
|
}
|
||||||
files.add(new File(dir+"HUD/Standard/xpbar_inc0"+x+".png"));
|
else {
|
||||||
} else
|
files.add(new File(dir + "HUD/Standard/xpbar_inc" + x + ".png"));
|
||||||
{
|
|
||||||
files.add(new File(dir+"HUD/Standard/xpbar_inc"+x+".png"));
|
|
||||||
}
|
}
|
||||||
x++;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
//Standard XP Icons
|
/* Standard XP Icons */
|
||||||
for(SkillType y : SkillType.values())
|
for (SkillType y : SkillType.values()) {
|
||||||
{
|
if (y.equals(SkillType.ALL)) {
|
||||||
if(y == SkillType.ALL)
|
|
||||||
continue;
|
continue;
|
||||||
files.add(new File(dir+"HUD/Standard/"+m.getCapitalized(y.toString())+".png"));
|
|
||||||
files.add(new File(dir+"HUD/Retro/"+m.getCapitalized(y.toString())+"_r.png"));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
//Blank icons
|
files.add(new File(dir + "HUD/Standard/" + m.getCapitalized(y.toString()) + ".png"));
|
||||||
files.add(new File(dir+"HUD/Standard/Icon.png"));
|
files.add(new File(dir + "HUD/Retro/" + m.getCapitalized(y.toString()) + "_r.png"));
|
||||||
files.add(new File(dir+"HUD/Retro/Icon_r.png"));
|
}
|
||||||
|
|
||||||
|
/* Blank icons */
|
||||||
|
files.add(new File(dir + "HUD/Standard/Icon.png"));
|
||||||
|
files.add(new File(dir + "HUD/Retro/Icon_r.png"));
|
||||||
|
|
||||||
//Repair SFX
|
//Repair SFX
|
||||||
files.add(new File(dir+"Sound/repair.wav"));
|
files.add(new File(dir + "Sound/repair.wav"));
|
||||||
|
|
||||||
//Level SFX
|
//Level SFX
|
||||||
files.add(new File(dir+"Sound/level.wav"));
|
files.add(new File(dir + "Sound/level.wav"));
|
||||||
|
|
||||||
return files;
|
return files;
|
||||||
}
|
}
|
||||||
public static void registerCustomEvent()
|
|
||||||
{
|
/**
|
||||||
|
* Register custom Spout events.
|
||||||
|
*/
|
||||||
|
public static void registerCustomEvent() {
|
||||||
Bukkit.getServer().getPluginManager().registerEvents(spoutListener, plugin);
|
Bukkit.getServer().getPluginManager().registerEvents(spoutListener, plugin);
|
||||||
Bukkit.getServer().getPluginManager().registerEvents(spoutInputListener, plugin);
|
Bukkit.getServer().getPluginManager().registerEvents(spoutInputListener, plugin);
|
||||||
Bukkit.getServer().getPluginManager().registerEvents(spoutScreenListener, plugin);
|
Bukkit.getServer().getPluginManager().registerEvents(spoutScreenListener, plugin);
|
||||||
}
|
}
|
||||||
|
|
||||||
public static Color getRetroColor(SkillType type)
|
/**
|
||||||
{
|
* Gets a Spout player from a player name.
|
||||||
switch(type)
|
*
|
||||||
{
|
* @param playerName The player name
|
||||||
case ACROBATICS:
|
* @return the SpoutPlayer related to this player name, null if there's no player online with that name.
|
||||||
return new Color((float) LoadProperties.acrobatics_r, (float) LoadProperties.acrobatics_g, (float) LoadProperties.acrobatics_b, 1);
|
*/
|
||||||
case ARCHERY:
|
public static SpoutPlayer getSpoutPlayer(String playerName) {
|
||||||
return new Color((float) LoadProperties.archery_r, (float)LoadProperties.archery_g, (float)LoadProperties.archery_b, 1f);
|
for (Player x : Bukkit.getServer().getOnlinePlayers()) {
|
||||||
case AXES:
|
if (x.getName().equalsIgnoreCase(playerName)) {
|
||||||
return new Color((float) LoadProperties.axes_r, (float)LoadProperties.axes_g, (float)LoadProperties.axes_b, 1f);
|
|
||||||
case EXCAVATION:
|
|
||||||
return new Color((float)LoadProperties.excavation_r, (float)LoadProperties.excavation_g, (float)LoadProperties.excavation_b, 1f);
|
|
||||||
case HERBALISM:
|
|
||||||
return new Color((float)LoadProperties.herbalism_r, (float)LoadProperties.herbalism_g, (float)LoadProperties.herbalism_b, 1f);
|
|
||||||
case MINING:
|
|
||||||
return new Color((float)LoadProperties.mining_r, (float)LoadProperties.mining_g, (float)LoadProperties.mining_b, 1f);
|
|
||||||
case REPAIR:
|
|
||||||
return new Color((float)LoadProperties.repair_r, (float)LoadProperties.repair_g, (float)LoadProperties.repair_b, 1f);
|
|
||||||
case SWORDS:
|
|
||||||
return new Color((float)LoadProperties.swords_r, (float)LoadProperties.swords_g, (float)LoadProperties.swords_b, 1f);
|
|
||||||
case TAMING:
|
|
||||||
return new Color((float)LoadProperties.taming_r, (float)LoadProperties.taming_g, (float)LoadProperties.taming_b, 1f);
|
|
||||||
case UNARMED:
|
|
||||||
return new Color((float)LoadProperties.unarmed_r, (float)LoadProperties.unarmed_g, (float)LoadProperties.unarmed_b, 1f);
|
|
||||||
case WOODCUTTING:
|
|
||||||
return new Color((float)LoadProperties.woodcutting_r, (float)LoadProperties.woodcutting_g, (float)LoadProperties.woodcutting_b, 1f);
|
|
||||||
case FISHING:
|
|
||||||
return new Color((float)LoadProperties.fishing_r, (float)LoadProperties.fishing_g, (float)LoadProperties.fishing_b, 1f);
|
|
||||||
default:
|
|
||||||
return new Color(0.3f, 0.3f, 0.75f, 1f);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
public static SpoutPlayer getSpoutPlayer(String playerName)
|
|
||||||
{
|
|
||||||
for(Player x : Bukkit.getServer().getOnlinePlayers())
|
|
||||||
{
|
|
||||||
if(x.getName().equalsIgnoreCase(playerName))
|
|
||||||
{
|
|
||||||
return SpoutManager.getPlayer(x);
|
return SpoutManager.getPlayer(x);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
public static void playSoundForPlayer(SoundEffect effect, Player player, Location location)
|
/**
|
||||||
{
|
* Handle level-up notifications through Spout.
|
||||||
//Contrib stuff
|
*
|
||||||
SoundManager SM = SpoutManager.getSoundManager();
|
* @param skillType The skill that leveled up
|
||||||
SpoutPlayer sPlayer = SpoutManager.getPlayer(player);
|
* @param sPlayer The player that leveled up
|
||||||
SM.playSoundEffect(sPlayer, effect, location);
|
*/
|
||||||
}
|
public static void levelUpNotification(SkillType skillType, SpoutPlayer sPlayer) {
|
||||||
|
|
||||||
public static void playRepairNoise(Player player)
|
|
||||||
{
|
|
||||||
SoundManager SM = SpoutManager.getSoundManager();
|
|
||||||
SpoutPlayer sPlayer = SpoutManager.getPlayer(player);
|
|
||||||
SM.playCustomSoundEffect(Bukkit.getServer().getPluginManager().getPlugin("mcMMO"), sPlayer, "http://mcmmo.rycochet.net/mcmmo/Sound/repair.wav", false);
|
|
||||||
}
|
|
||||||
|
|
||||||
public static void playLevelUpNoise(Player player)
|
|
||||||
{
|
|
||||||
SoundManager SM = SpoutManager.getSoundManager();
|
|
||||||
SpoutPlayer sPlayer = SpoutManager.getPlayer(player);
|
|
||||||
SM.playCustomSoundEffect(Bukkit.getServer().getPluginManager().getPlugin("mcMMO"), sPlayer, "http://mcmmo.rycochet.net/mcmmo/Sound/level.wav", false);
|
|
||||||
}
|
|
||||||
|
|
||||||
public static void levelUpNotification(SkillType skillType, SpoutPlayer sPlayer)
|
|
||||||
{
|
|
||||||
PlayerProfile PP = Users.getProfile(sPlayer);
|
PlayerProfile PP = Users.getProfile(sPlayer);
|
||||||
|
int notificationTier = getNotificationTier(PP.getSkillLevel(skillType));
|
||||||
Material mat = null;
|
Material mat = null;
|
||||||
switch(skillType)
|
|
||||||
{
|
switch (skillType) {
|
||||||
case TAMING:
|
case TAMING:
|
||||||
switch(getNotificationTier(PP.getSkillLevel(skillType)))
|
switch (notificationTier) {
|
||||||
{
|
|
||||||
case 1:
|
case 1:
|
||||||
mat = Material.PORK;
|
|
||||||
break;
|
|
||||||
case 2:
|
case 2:
|
||||||
mat = Material.PORK;
|
mat = Material.PORK;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 3:
|
case 3:
|
||||||
mat = Material.GRILLED_PORK;
|
|
||||||
break;
|
|
||||||
case 4:
|
case 4:
|
||||||
mat = Material.GRILLED_PORK;
|
mat = Material.GRILLED_PORK;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 5:
|
case 5:
|
||||||
mat = Material.BONE;
|
mat = Material.BONE;
|
||||||
break;
|
break;
|
||||||
}
|
|
||||||
|
default:
|
||||||
break;
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
break;
|
||||||
|
|
||||||
case MINING:
|
case MINING:
|
||||||
switch(getNotificationTier(PP.getSkillLevel(skillType)))
|
switch (notificationTier) {
|
||||||
{
|
|
||||||
case 1:
|
case 1:
|
||||||
mat = Material.COAL_ORE;
|
mat = Material.COAL_ORE;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 2:
|
case 2:
|
||||||
mat = Material.IRON_ORE;
|
mat = Material.IRON_ORE;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 3:
|
case 3:
|
||||||
mat = Material.GOLD_ORE;
|
mat = Material.GOLD_ORE;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 4:
|
case 4:
|
||||||
mat = Material.LAPIS_ORE;
|
mat = Material.LAPIS_ORE;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 5:
|
case 5:
|
||||||
mat = Material.DIAMOND_ORE;
|
mat = Material.DIAMOND_ORE;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
default:
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case WOODCUTTING:
|
case WOODCUTTING:
|
||||||
switch(getNotificationTier(PP.getSkillLevel(skillType)))
|
switch (notificationTier) {
|
||||||
{
|
|
||||||
case 1:
|
case 1:
|
||||||
mat = Material.WOOD;
|
|
||||||
break;
|
|
||||||
case 2:
|
case 2:
|
||||||
mat = Material.WOOD;
|
|
||||||
break;
|
|
||||||
case 3:
|
case 3:
|
||||||
mat = Material.WOOD;
|
mat = Material.WOOD;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 4:
|
case 4:
|
||||||
mat = Material.LOG;
|
|
||||||
break;
|
|
||||||
case 5:
|
case 5:
|
||||||
mat = Material.LOG;
|
mat = Material.LOG;
|
||||||
break;
|
break;
|
||||||
}
|
|
||||||
|
default:
|
||||||
break;
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
break;
|
||||||
|
|
||||||
case REPAIR:
|
case REPAIR:
|
||||||
switch(getNotificationTier(PP.getSkillLevel(skillType)))
|
switch (notificationTier) {
|
||||||
{
|
|
||||||
case 1:
|
case 1:
|
||||||
mat = Material.COBBLESTONE;
|
mat = Material.COBBLESTONE;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 2:
|
case 2:
|
||||||
mat = Material.IRON_BLOCK;
|
mat = Material.IRON_BLOCK;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 3:
|
case 3:
|
||||||
mat = Material.GOLD_BLOCK;
|
mat = Material.GOLD_BLOCK;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 4:
|
case 4:
|
||||||
mat = Material.LAPIS_BLOCK;
|
mat = Material.LAPIS_BLOCK;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 5:
|
case 5:
|
||||||
mat = Material.DIAMOND_BLOCK;
|
mat = Material.DIAMOND_BLOCK;
|
||||||
break;
|
break;
|
||||||
}
|
|
||||||
|
default:
|
||||||
break;
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
break;
|
||||||
|
|
||||||
case HERBALISM:
|
case HERBALISM:
|
||||||
switch(getNotificationTier(PP.getSkillLevel(skillType)))
|
switch (notificationTier) {
|
||||||
{
|
|
||||||
case 1:
|
case 1:
|
||||||
mat = Material.YELLOW_FLOWER;
|
mat = Material.YELLOW_FLOWER;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 2:
|
case 2:
|
||||||
mat = Material.RED_ROSE;
|
mat = Material.RED_ROSE;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 3:
|
case 3:
|
||||||
mat = Material.BROWN_MUSHROOM;
|
mat = Material.BROWN_MUSHROOM;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 4:
|
case 4:
|
||||||
mat = Material.RED_MUSHROOM;
|
mat = Material.RED_MUSHROOM;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 5:
|
case 5:
|
||||||
mat = Material.PUMPKIN;
|
mat = Material.PUMPKIN;
|
||||||
break;
|
break;
|
||||||
}
|
|
||||||
|
default:
|
||||||
break;
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
break;
|
||||||
|
|
||||||
case ACROBATICS:
|
case ACROBATICS:
|
||||||
switch(getNotificationTier(PP.getSkillLevel(skillType)))
|
switch (notificationTier) {
|
||||||
{
|
|
||||||
case 1:
|
case 1:
|
||||||
mat = Material.LEATHER_BOOTS;
|
mat = Material.LEATHER_BOOTS;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 2:
|
case 2:
|
||||||
mat = Material.CHAINMAIL_BOOTS;
|
mat = Material.CHAINMAIL_BOOTS;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 3:
|
case 3:
|
||||||
mat = Material.IRON_BOOTS;
|
mat = Material.IRON_BOOTS;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 4:
|
case 4:
|
||||||
mat = Material.GOLD_BOOTS;
|
mat = Material.GOLD_BOOTS;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 5:
|
case 5:
|
||||||
mat = Material.DIAMOND_BOOTS;
|
mat = Material.DIAMOND_BOOTS;
|
||||||
break;
|
break;
|
||||||
}
|
|
||||||
|
default:
|
||||||
break;
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
break;
|
||||||
|
|
||||||
case SWORDS:
|
case SWORDS:
|
||||||
switch(getNotificationTier(PP.getSkillLevel(skillType)))
|
switch (notificationTier) {
|
||||||
{
|
|
||||||
case 1:
|
case 1:
|
||||||
mat = Material.WOOD_SWORD;
|
mat = Material.WOOD_SWORD;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 2:
|
case 2:
|
||||||
mat = Material.STONE_SWORD;
|
mat = Material.STONE_SWORD;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 3:
|
case 3:
|
||||||
mat = Material.IRON_SWORD;
|
mat = Material.IRON_SWORD;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 4:
|
case 4:
|
||||||
mat = Material.GOLD_SWORD;
|
mat = Material.GOLD_SWORD;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 5:
|
case 5:
|
||||||
mat = Material.DIAMOND_SWORD;
|
mat = Material.DIAMOND_SWORD;
|
||||||
break;
|
break;
|
||||||
}
|
|
||||||
|
default:
|
||||||
break;
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
break;
|
||||||
|
|
||||||
case ARCHERY:
|
case ARCHERY:
|
||||||
|
switch (notificationTier) {
|
||||||
|
case 1:
|
||||||
|
case 2:
|
||||||
|
case 3:
|
||||||
mat = Material.ARROW;
|
mat = Material.ARROW;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
case 4:
|
||||||
|
case 5:
|
||||||
|
mat = Material.BOW;
|
||||||
|
break;
|
||||||
|
|
||||||
|
default:
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
break;
|
||||||
|
|
||||||
case UNARMED:
|
case UNARMED:
|
||||||
switch(getNotificationTier(PP.getSkillLevel(skillType)))
|
switch (notificationTier) {
|
||||||
{
|
|
||||||
case 1:
|
case 1:
|
||||||
mat = Material.LEATHER_HELMET;
|
mat = Material.LEATHER_HELMET;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 2:
|
case 2:
|
||||||
mat = Material.CHAINMAIL_HELMET;
|
mat = Material.CHAINMAIL_HELMET;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 3:
|
case 3:
|
||||||
mat = Material.IRON_HELMET;
|
mat = Material.IRON_HELMET;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 4:
|
case 4:
|
||||||
mat = Material.GOLD_HELMET;
|
mat = Material.GOLD_HELMET;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 5:
|
case 5:
|
||||||
mat = Material.DIAMOND_HELMET;
|
mat = Material.DIAMOND_HELMET;
|
||||||
break;
|
break;
|
||||||
}
|
|
||||||
|
default:
|
||||||
break;
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
break;
|
||||||
|
|
||||||
case EXCAVATION:
|
case EXCAVATION:
|
||||||
switch(getNotificationTier(PP.getSkillLevel(skillType)))
|
switch (notificationTier) {
|
||||||
{
|
|
||||||
case 1:
|
case 1:
|
||||||
mat = Material.WOOD_SPADE;
|
mat = Material.WOOD_SPADE;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 2:
|
case 2:
|
||||||
mat = Material.STONE_SPADE;
|
mat = Material.STONE_SPADE;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 3:
|
case 3:
|
||||||
mat = Material.IRON_SPADE;
|
mat = Material.IRON_SPADE;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 4:
|
case 4:
|
||||||
mat = Material.GOLD_SPADE;
|
mat = Material.GOLD_SPADE;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 5:
|
case 5:
|
||||||
mat = Material.DIAMOND_SPADE;
|
mat = Material.DIAMOND_SPADE;
|
||||||
break;
|
break;
|
||||||
}
|
|
||||||
|
default:
|
||||||
break;
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
break;
|
||||||
|
|
||||||
case AXES:
|
case AXES:
|
||||||
switch(getNotificationTier(PP.getSkillLevel(skillType)))
|
switch (notificationTier) {
|
||||||
{
|
|
||||||
case 1:
|
case 1:
|
||||||
mat = Material.WOOD_AXE;
|
mat = Material.WOOD_AXE;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 2:
|
case 2:
|
||||||
mat = Material.STONE_AXE;
|
mat = Material.STONE_AXE;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 3:
|
case 3:
|
||||||
mat = Material.IRON_AXE;
|
mat = Material.IRON_AXE;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 4:
|
case 4:
|
||||||
mat = Material.GOLD_AXE;
|
mat = Material.GOLD_AXE;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 5:
|
case 5:
|
||||||
mat = Material.DIAMOND_AXE;
|
mat = Material.DIAMOND_AXE;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
default:
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case FISHING:
|
case FISHING:
|
||||||
switch(getNotificationTier(PP.getSkillLevel(skillType)))
|
switch (notificationTier) {
|
||||||
{
|
|
||||||
case 1:
|
case 1:
|
||||||
mat = Material.RAW_FISH;
|
|
||||||
break;
|
|
||||||
case 2:
|
case 2:
|
||||||
mat = Material.RAW_FISH;
|
mat = Material.RAW_FISH;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 3:
|
case 3:
|
||||||
mat = Material.COOKED_FISH;
|
|
||||||
break;
|
|
||||||
case 4:
|
case 4:
|
||||||
mat = Material.COOKED_FISH;
|
mat = Material.COOKED_FISH;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 5:
|
case 5:
|
||||||
mat = Material.FISHING_ROD;
|
mat = Material.FISHING_ROD;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
default:
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
break;
|
||||||
|
|
||||||
default:
|
default:
|
||||||
mat = Material.WATCH;
|
mat = Material.WATCH;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
sPlayer.sendNotification(ChatColor.GREEN+"Level Up!", ChatColor.YELLOW+m.getCapitalized(skillType.toString())+ChatColor.DARK_AQUA+" ("+ChatColor.GREEN+PP.getSkillLevel(skillType)+ChatColor.DARK_AQUA+")", mat);
|
|
||||||
playLevelUpNoise(sPlayer);
|
//TODO: Use Locale
|
||||||
|
sPlayer.sendNotification(ChatColor.GREEN + "Level Up!", ChatColor.YELLOW + m.getCapitalized(skillType.toString()) + ChatColor.DARK_AQUA + " (" + ChatColor.GREEN + PP.getSkillLevel(skillType) + ChatColor.DARK_AQUA + ")", mat);
|
||||||
|
SpoutSounds.playLevelUpNoise(sPlayer);
|
||||||
}
|
}
|
||||||
|
|
||||||
public static Integer getNotificationTier(Integer level)
|
/**
|
||||||
{
|
* Gets the notification tier of a skill.
|
||||||
if(level < 200)
|
*
|
||||||
return 1;
|
* @param level The level of the skill
|
||||||
else if (level >= 200 && level < 400)
|
* @return the notification tier of the skill
|
||||||
return 2;
|
*/
|
||||||
else if (level >= 400 && level < 600)
|
private static Integer getNotificationTier(Integer level) {
|
||||||
return 3;
|
if (level >= 800) {
|
||||||
else if (level >= 600 && level < 800)
|
|
||||||
return 4;
|
|
||||||
else
|
|
||||||
return 5;
|
return 5;
|
||||||
}
|
}
|
||||||
|
else if (level >= 600) {
|
||||||
public static Integer getXpInc(int skillxp, int xptolevel, HUDType hud)
|
return 4;
|
||||||
{
|
}
|
||||||
if(hud == HUDType.STANDARD)
|
else if (level >= 400) {
|
||||||
{
|
return 3;
|
||||||
double percentage = (double) skillxp/xptolevel;
|
}
|
||||||
double inc = 0.0039370078740157;
|
else if (level >= 200) {
|
||||||
return (int) (percentage/inc);
|
return 2;
|
||||||
} else if (hud == HUDType.RETRO)
|
}
|
||||||
{
|
else {
|
||||||
double percentage = (double) skillxp/xptolevel;
|
|
||||||
double inc = 0.0079365079365079;
|
|
||||||
return (int) (percentage/inc);
|
|
||||||
} else {
|
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public static void updateXpBar(Player player)
|
/**
|
||||||
{
|
* Update a player's Spout XP bar.
|
||||||
|
*
|
||||||
|
* @param player The player whose bar to update
|
||||||
|
*/
|
||||||
|
public static void updateXpBar(Player player) {
|
||||||
playerHUDs.get(player).updateXpBarDisplay(Users.getProfile(player).getHUDType(), player);
|
playerHUDs.get(player).updateXpBarDisplay(Users.getProfile(player).getHUDType(), player);
|
||||||
}
|
}
|
||||||
|
|
||||||
public static String getUrlBar(Integer number)
|
|
||||||
{
|
|
||||||
if(number.toString().toCharArray().length == 1)
|
|
||||||
{
|
|
||||||
return "xpbar_inc00"+number+".png";
|
|
||||||
} else if (number.toString().toCharArray().length == 2)
|
|
||||||
{
|
|
||||||
return "xpbar_inc0"+number+".png";
|
|
||||||
} else {
|
|
||||||
return "xpbar_inc"+number+".png";
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public static String getUrlIcon(SkillType skillType)
|
|
||||||
{
|
|
||||||
return m.getCapitalized(skillType.toString())+".png";
|
|
||||||
}
|
|
||||||
public static boolean shouldBeFilled(PlayerProfile PP)
|
|
||||||
{
|
|
||||||
return PP.getXpBarInc() < getXpInc(PP.getSkillXpLevel(PP.getLastGained()), PP.getXpToLevel(PP.getLastGained()), HUDType.STANDARD);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user