forked from Upstream/mmocore
improved sound api
This commit is contained in:
parent
7efc388428
commit
156a7c5b56
@ -1,6 +1,7 @@
|
|||||||
package net.Indyuce.mmocore;
|
package net.Indyuce.mmocore;
|
||||||
|
|
||||||
import io.lumine.mythic.lib.MythicLib;
|
import io.lumine.mythic.lib.MythicLib;
|
||||||
|
import io.lumine.mythic.lib.UtilityMethods;
|
||||||
import io.lumine.mythic.lib.comp.Metrics;
|
import io.lumine.mythic.lib.comp.Metrics;
|
||||||
import io.lumine.mythic.lib.version.SpigotPlugin;
|
import io.lumine.mythic.lib.version.SpigotPlugin;
|
||||||
import io.lumine.mythic.utils.plugin.LuminePlugin;
|
import io.lumine.mythic.utils.plugin.LuminePlugin;
|
||||||
@ -40,7 +41,7 @@ import net.Indyuce.mmocore.manager.profession.*;
|
|||||||
import net.Indyuce.mmocore.manager.social.BoosterManager;
|
import net.Indyuce.mmocore.manager.social.BoosterManager;
|
||||||
import net.Indyuce.mmocore.manager.social.PartyManager;
|
import net.Indyuce.mmocore.manager.social.PartyManager;
|
||||||
import net.Indyuce.mmocore.manager.social.RequestManager;
|
import net.Indyuce.mmocore.manager.social.RequestManager;
|
||||||
import net.Indyuce.mmocore.skill.cast.listener.SkillBar;
|
import net.Indyuce.mmocore.skill.cast.SkillCastingMode;
|
||||||
import net.Indyuce.mmocore.skill.list.Ambers;
|
import net.Indyuce.mmocore.skill.list.Ambers;
|
||||||
import net.Indyuce.mmocore.skill.list.Neptune_Gift;
|
import net.Indyuce.mmocore.skill.list.Neptune_Gift;
|
||||||
import net.Indyuce.mmocore.skill.list.Sneaky_Picky;
|
import net.Indyuce.mmocore.skill.list.Sneaky_Picky;
|
||||||
@ -221,6 +222,14 @@ public class MMOCore extends LuminePlugin {
|
|||||||
DebugMode.enableActionBar();
|
DebugMode.enableActionBar();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Skill casting
|
||||||
|
try {
|
||||||
|
SkillCastingMode mode = SkillCastingMode.valueOf(UtilityMethods.enumName(getConfig().getString("skill-casting.mode")));
|
||||||
|
Bukkit.getPluginManager().registerEvents(mode.loadFromConfig(getConfig().getConfigurationSection("skill-casting")), this);
|
||||||
|
} catch (RuntimeException exception) {
|
||||||
|
getLogger().log(Level.WARNING, "Could not load skill casting: " + exception.getMessage());
|
||||||
|
}
|
||||||
|
|
||||||
if (configManager.overrideVanillaExp = getConfig().getBoolean("override-vanilla-exp"))
|
if (configManager.overrideVanillaExp = getConfig().getBoolean("override-vanilla-exp"))
|
||||||
Bukkit.getPluginManager().registerEvents(new VanillaExperienceOverride(), this);
|
Bukkit.getPluginManager().registerEvents(new VanillaExperienceOverride(), this);
|
||||||
|
|
||||||
|
20
src/main/java/net/Indyuce/mmocore/api/SoundEvent.java
Normal file
20
src/main/java/net/Indyuce/mmocore/api/SoundEvent.java
Normal file
@ -0,0 +1,20 @@
|
|||||||
|
package net.Indyuce.mmocore.api;
|
||||||
|
|
||||||
|
public enum SoundEvent {
|
||||||
|
LEVEL_UP,
|
||||||
|
WARP_TELEPORT,
|
||||||
|
WARP_CANCELLED,
|
||||||
|
WARP_CHARGE,
|
||||||
|
WARP_UNLOCK,
|
||||||
|
HOTBAR_SWAP,
|
||||||
|
SPELL_CAST_BEGIN,
|
||||||
|
SPELL_CAST_END,
|
||||||
|
CANT_SELECT_CLASS,
|
||||||
|
SELECT_CLASS,
|
||||||
|
LEVEL_ATTRIBUTE,
|
||||||
|
RESET_ATTRIBUTES,
|
||||||
|
NOT_ENOUGH_POINTS,
|
||||||
|
CANCEL_QUEST,
|
||||||
|
START_QUEST,
|
||||||
|
CLOSE_LOOT_CHEST;
|
||||||
|
}
|
@ -1,53 +1,106 @@
|
|||||||
package net.Indyuce.mmocore.api;
|
package net.Indyuce.mmocore.api;
|
||||||
|
|
||||||
|
import io.lumine.mythic.lib.UtilityMethods;
|
||||||
|
import io.lumine.mythic.lib.util.configobject.ConfigObject;
|
||||||
|
import org.bukkit.Location;
|
||||||
import org.bukkit.Sound;
|
import org.bukkit.Sound;
|
||||||
|
import org.bukkit.configuration.ConfigurationSection;
|
||||||
|
import org.bukkit.entity.Player;
|
||||||
|
|
||||||
|
import javax.annotation.Nullable;
|
||||||
|
|
||||||
public class SoundObject {
|
public class SoundObject {
|
||||||
private final Sound sound;
|
|
||||||
private final String key;
|
|
||||||
private final float volume;
|
|
||||||
private final float pitch;
|
|
||||||
|
|
||||||
public SoundObject(String input) {
|
@Nullable
|
||||||
String[] split = input.split(",");
|
private final Sound sound;
|
||||||
if(split.length > 2) {
|
|
||||||
input = split[0];
|
|
||||||
volume = Float.parseFloat(split[1]);
|
|
||||||
pitch = Float.parseFloat(split[2]);
|
|
||||||
} else {
|
|
||||||
volume = 1;
|
|
||||||
pitch = 1;
|
|
||||||
}
|
|
||||||
|
|
||||||
Sound sound = null;
|
@Nullable
|
||||||
String key = "";
|
private final String key;
|
||||||
try {
|
|
||||||
sound = Sound.valueOf(input.toUpperCase().replace("-", "_"));
|
|
||||||
} catch(Exception ignored) {
|
|
||||||
key = input;
|
|
||||||
}
|
|
||||||
|
|
||||||
this.sound = sound;
|
private final float volume;
|
||||||
this.key = key;
|
private final float pitch;
|
||||||
}
|
|
||||||
|
|
||||||
public boolean hasSound() {
|
public SoundObject(String input) {
|
||||||
return key.isEmpty();
|
String[] split = input.split(",");
|
||||||
}
|
|
||||||
|
|
||||||
public Sound getSound() {
|
Sound sound = null;
|
||||||
return sound;
|
String key = null;
|
||||||
}
|
try {
|
||||||
|
sound = Sound.valueOf(UtilityMethods.enumName(split[0]));
|
||||||
|
} catch (Exception ignored) {
|
||||||
|
key = split[0];
|
||||||
|
}
|
||||||
|
|
||||||
public String getKey() {
|
this.sound = sound;
|
||||||
return key;
|
this.key = key;
|
||||||
}
|
|
||||||
|
|
||||||
public float getVolume() {
|
volume = split.length > 1 ? Float.parseFloat(split[1]) : 1;
|
||||||
return volume;
|
pitch = split.length > 2 ? Float.parseFloat(split[2]) : 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
public float getPitch() {
|
public SoundObject(ConfigurationSection config) {
|
||||||
return pitch;
|
String input = config.getString("sound");
|
||||||
}
|
|
||||||
|
Sound sound = null;
|
||||||
|
String key = null;
|
||||||
|
try {
|
||||||
|
sound = Sound.valueOf(UtilityMethods.enumName(input));
|
||||||
|
} catch (Exception ignored) {
|
||||||
|
key = input;
|
||||||
|
}
|
||||||
|
|
||||||
|
this.sound = sound;
|
||||||
|
this.key = key;
|
||||||
|
|
||||||
|
volume = (float) config.getDouble("volume", 1);
|
||||||
|
pitch = (float) config.getDouble("pitch", 1);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @return If this object is custom a custom sound, potentially
|
||||||
|
* from a resource pack
|
||||||
|
*/
|
||||||
|
public boolean isCustom() {
|
||||||
|
return sound == null;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Nullable
|
||||||
|
public Sound getSound() {
|
||||||
|
return sound;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Nullable
|
||||||
|
public String getKey() {
|
||||||
|
return key;
|
||||||
|
}
|
||||||
|
|
||||||
|
public float getVolume() {
|
||||||
|
return volume;
|
||||||
|
}
|
||||||
|
|
||||||
|
public float getPitch() {
|
||||||
|
return pitch;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void playTo(Player player) {
|
||||||
|
playTo(player, volume, pitch);
|
||||||
|
}
|
||||||
|
|
||||||
|
public void playTo(Player player, float volume, float pitch) {
|
||||||
|
if (isCustom())
|
||||||
|
player.playSound(player.getLocation(), key, volume, pitch);
|
||||||
|
else
|
||||||
|
player.playSound(player.getLocation(), sound, volume, pitch);
|
||||||
|
}
|
||||||
|
|
||||||
|
public void playAt(Location loc) {
|
||||||
|
playAt(loc, volume, pitch);
|
||||||
|
}
|
||||||
|
|
||||||
|
public void playAt(Location loc, float volume, float pitch) {
|
||||||
|
if (isCustom())
|
||||||
|
loc.getWorld().playSound(loc, key, volume, pitch);
|
||||||
|
else
|
||||||
|
loc.getWorld().playSound(loc, sound, volume, pitch);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -5,6 +5,7 @@ import io.lumine.mythic.lib.player.TemporaryPlayerData;
|
|||||||
import io.lumine.mythic.lib.player.cooldown.CooldownMap;
|
import io.lumine.mythic.lib.player.cooldown.CooldownMap;
|
||||||
import net.Indyuce.mmocore.MMOCore;
|
import net.Indyuce.mmocore.MMOCore;
|
||||||
import net.Indyuce.mmocore.api.ConfigMessage;
|
import net.Indyuce.mmocore.api.ConfigMessage;
|
||||||
|
import net.Indyuce.mmocore.api.SoundEvent;
|
||||||
import net.Indyuce.mmocore.api.Waypoint;
|
import net.Indyuce.mmocore.api.Waypoint;
|
||||||
import net.Indyuce.mmocore.api.event.PlayerExperienceGainEvent;
|
import net.Indyuce.mmocore.api.event.PlayerExperienceGainEvent;
|
||||||
import net.Indyuce.mmocore.api.event.PlayerLevelUpEvent;
|
import net.Indyuce.mmocore.api.event.PlayerLevelUpEvent;
|
||||||
@ -74,11 +75,11 @@ public class PlayerData extends OfflinePlayerData implements Closable {
|
|||||||
private final PlayerProfessions collectSkills = new PlayerProfessions(this);
|
private final PlayerProfessions collectSkills = new PlayerProfessions(this);
|
||||||
private final PlayerAttributes attributes = new PlayerAttributes(this);
|
private final PlayerAttributes attributes = new PlayerAttributes(this);
|
||||||
private final Map<String, SavedClassInformation> classSlots = new HashMap<>();
|
private final Map<String, SavedClassInformation> classSlots = new HashMap<>();
|
||||||
private final Map<PlayerActivity, Long> lastActivity = new HashMap<>();
|
private final Map<PlayerActivity, Long> lastActivity = new HashMap<>();
|
||||||
|
|
||||||
// NON-FINAL player data stuff made public to facilitate field change
|
// NON-FINAL player data stuff made public to facilitate field change
|
||||||
public int skillGuiDisplayOffset;
|
public int skillGuiDisplayOffset;
|
||||||
public SkillCasting skillCasting;
|
public Object skillCasting;
|
||||||
public boolean noCooldown;
|
public boolean noCooldown;
|
||||||
public CombatRunnable combat;
|
public CombatRunnable combat;
|
||||||
|
|
||||||
@ -438,7 +439,7 @@ private final Map<PlayerActivity, Long> lastActivity = new HashMap<>();
|
|||||||
return;
|
return;
|
||||||
if (getPlayer().getLocation().getBlockX() != x || getPlayer().getLocation().getBlockY() != y
|
if (getPlayer().getLocation().getBlockX() != x || getPlayer().getLocation().getBlockY() != y
|
||||||
|| getPlayer().getLocation().getBlockZ() != z) {
|
|| getPlayer().getLocation().getBlockZ() != z) {
|
||||||
MMOCore.plugin.soundManager.play(getPlayer(), SoundManager.SoundEvent.WARP_CANCELLED);
|
MMOCore.plugin.soundManager.getSound(SoundEvent.WARP_CANCELLED).playTo(getPlayer());
|
||||||
MMOCore.plugin.configManager.getSimpleMessage("warping-canceled").send(getPlayer());
|
MMOCore.plugin.configManager.getSimpleMessage("warping-canceled").send(getPlayer());
|
||||||
giveStellium(waypoint.getStelliumCost(), PlayerResourceUpdateEvent.UpdateReason.SKILL_REGENERATION);
|
giveStellium(waypoint.getStelliumCost(), PlayerResourceUpdateEvent.UpdateReason.SKILL_REGENERATION);
|
||||||
cancel();
|
cancel();
|
||||||
@ -449,12 +450,12 @@ private final Map<PlayerActivity, Long> lastActivity = new HashMap<>();
|
|||||||
if (t++ >= 100) {
|
if (t++ >= 100) {
|
||||||
getPlayer().teleport(waypoint.getLocation());
|
getPlayer().teleport(waypoint.getLocation());
|
||||||
getPlayer().addPotionEffect(new PotionEffect(PotionEffectType.BLINDNESS, 20, 1, false, false));
|
getPlayer().addPotionEffect(new PotionEffect(PotionEffectType.BLINDNESS, 20, 1, false, false));
|
||||||
MMOCore.plugin.soundManager.play(getPlayer(), SoundManager.SoundEvent.WARP_TELEPORT);
|
MMOCore.plugin.soundManager.getSound(SoundEvent.WARP_TELEPORT).playTo(getPlayer());
|
||||||
cancel();
|
cancel();
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
MMOCore.plugin.soundManager.play(getPlayer(), SoundManager.SoundEvent.WARP_CHARGE, 1, (float) (t / Math.PI * .015 + .5));
|
MMOCore.plugin.soundManager.getSound(SoundEvent.WARP_CHARGE).playTo(getPlayer(), 1, (float) (t / Math.PI * .015 + .5));
|
||||||
double r = Math.sin((double) t / 100 * Math.PI);
|
double r = Math.sin((double) t / 100 * Math.PI);
|
||||||
for (double j = 0; j < Math.PI * 2; j += Math.PI / 4)
|
for (double j = 0; j < Math.PI * 2; j += Math.PI / 4)
|
||||||
getPlayer().getLocation().getWorld().spawnParticle(Particle.REDSTONE,
|
getPlayer().getLocation().getWorld().spawnParticle(Particle.REDSTONE,
|
||||||
@ -532,7 +533,7 @@ private final Map<PlayerActivity, Long> lastActivity = new HashMap<>();
|
|||||||
Bukkit.getPluginManager().callEvent(new PlayerLevelUpEvent(this, null, oldLevel, level));
|
Bukkit.getPluginManager().callEvent(new PlayerLevelUpEvent(this, null, oldLevel, level));
|
||||||
if (isOnline()) {
|
if (isOnline()) {
|
||||||
new ConfigMessage("level-up").addPlaceholders("level", "" + level).send(getPlayer());
|
new ConfigMessage("level-up").addPlaceholders("level", "" + level).send(getPlayer());
|
||||||
MMOCore.plugin.soundManager.play(getPlayer(), SoundManager.SoundEvent.LEVEL_UP);
|
MMOCore.plugin.soundManager.getSound(SoundEvent.LEVEL_UP).playTo(getPlayer());
|
||||||
new SmallParticleEffect(getPlayer(), Particle.SPELL_INSTANT);
|
new SmallParticleEffect(getPlayer(), Particle.SPELL_INSTANT);
|
||||||
}
|
}
|
||||||
getStats().updateStats();
|
getStats().updateStats();
|
||||||
|
@ -149,21 +149,18 @@ public class Party {
|
|||||||
new ArrayList<>(members).forEach(action);
|
new ArrayList<>(members).forEach(action);
|
||||||
}
|
}
|
||||||
|
|
||||||
private static final String PARTY_BUFF_MODIFIER_KEY = "mmocoreParty";
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Applies party stat bonuses to a specific player
|
* Applies party stat bonuses to a specific player
|
||||||
*/
|
*/
|
||||||
private void applyStatBonuses(PlayerData player) {
|
private void applyStatBonuses(PlayerData player) {
|
||||||
MMOCore.plugin.partyManager.getBonuses().forEach(stat -> player.getStats().getInstance(stat).addModifier(PARTY_BUFF_MODIFIER_KEY,
|
MMOCore.plugin.partyManager.getBonuses().forEach(buff -> buff.multiply(members.size() - 1).register(player.getMMOPlayerData()));
|
||||||
MMOCore.plugin.partyManager.getBonus(stat).multiply(members.size() - 1)));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Clear party stat bonuses from a player
|
* Clear party stat bonuses from a player
|
||||||
*/
|
*/
|
||||||
private void clearStatBonuses(PlayerData player) {
|
private void clearStatBonuses(PlayerData player) {
|
||||||
MMOCore.plugin.partyManager.getBonuses().forEach(stat -> player.getStats().getInstance(stat).remove(PARTY_BUFF_MODIFIER_KEY));
|
MMOCore.plugin.partyManager.getBonuses().forEach(buff -> buff.unregister(player.getMMOPlayerData()));
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -6,6 +6,7 @@ import com.google.gson.JsonObject;
|
|||||||
import io.lumine.mythic.lib.MythicLib;
|
import io.lumine.mythic.lib.MythicLib;
|
||||||
import net.Indyuce.mmocore.MMOCore;
|
import net.Indyuce.mmocore.MMOCore;
|
||||||
import net.Indyuce.mmocore.api.ConfigMessage;
|
import net.Indyuce.mmocore.api.ConfigMessage;
|
||||||
|
import net.Indyuce.mmocore.api.SoundEvent;
|
||||||
import net.Indyuce.mmocore.api.event.PlayerExperienceGainEvent;
|
import net.Indyuce.mmocore.api.event.PlayerExperienceGainEvent;
|
||||||
import net.Indyuce.mmocore.api.event.PlayerLevelUpEvent;
|
import net.Indyuce.mmocore.api.event.PlayerLevelUpEvent;
|
||||||
import net.Indyuce.mmocore.api.player.PlayerData;
|
import net.Indyuce.mmocore.api.player.PlayerData;
|
||||||
@ -195,7 +196,7 @@ public class PlayerProfessions {
|
|||||||
new SmallParticleEffect(playerData.getPlayer(), Particle.SPELL_INSTANT);
|
new SmallParticleEffect(playerData.getPlayer(), Particle.SPELL_INSTANT);
|
||||||
new ConfigMessage("profession-level-up").addPlaceholders("level", "" + level, "profession", profession.getName())
|
new ConfigMessage("profession-level-up").addPlaceholders("level", "" + level, "profession", profession.getName())
|
||||||
.send(playerData.getPlayer());
|
.send(playerData.getPlayer());
|
||||||
MMOCore.plugin.soundManager.play(playerData.getPlayer(), SoundManager.SoundEvent.LEVEL_UP);
|
MMOCore.plugin.soundManager.getSound(SoundEvent.LEVEL_UP).playTo(playerData.getPlayer());
|
||||||
playerData.getStats().updateStats();
|
playerData.getStats().updateStats();
|
||||||
|
|
||||||
// Apply profession experience table
|
// Apply profession experience table
|
||||||
|
@ -1,6 +1,7 @@
|
|||||||
package net.Indyuce.mmocore.gui;
|
package net.Indyuce.mmocore.gui;
|
||||||
|
|
||||||
import net.Indyuce.mmocore.MMOCore;
|
import net.Indyuce.mmocore.MMOCore;
|
||||||
|
import net.Indyuce.mmocore.api.SoundEvent;
|
||||||
import net.Indyuce.mmocore.api.event.PlayerAttributeUseEvent;
|
import net.Indyuce.mmocore.api.event.PlayerAttributeUseEvent;
|
||||||
import net.Indyuce.mmocore.api.player.PlayerData;
|
import net.Indyuce.mmocore.api.player.PlayerData;
|
||||||
import net.Indyuce.mmocore.api.player.attribute.PlayerAttribute;
|
import net.Indyuce.mmocore.api.player.attribute.PlayerAttribute;
|
||||||
@ -89,13 +90,13 @@ public class AttributeView extends EditableInventory {
|
|||||||
int spent = playerData.getAttributes().countSkillPoints();
|
int spent = playerData.getAttributes().countSkillPoints();
|
||||||
if (spent < 1) {
|
if (spent < 1) {
|
||||||
MMOCore.plugin.configManager.getSimpleMessage("no-attribute-points-spent").send(player);
|
MMOCore.plugin.configManager.getSimpleMessage("no-attribute-points-spent").send(player);
|
||||||
MMOCore.plugin.soundManager.play(getPlayer(), SoundManager.SoundEvent.NOT_ENOUGH_POINTS);
|
MMOCore.plugin.soundManager.getSound(SoundEvent.NOT_ENOUGH_POINTS).playTo(getPlayer());
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (playerData.getAttributeReallocationPoints() < 1) {
|
if (playerData.getAttributeReallocationPoints() < 1) {
|
||||||
MMOCore.plugin.configManager.getSimpleMessage("not-attribute-reallocation-point").send(player);
|
MMOCore.plugin.configManager.getSimpleMessage("not-attribute-reallocation-point").send(player);
|
||||||
MMOCore.plugin.soundManager.play(getPlayer(), SoundManager.SoundEvent.NOT_ENOUGH_POINTS);
|
MMOCore.plugin.soundManager.getSound(SoundEvent.NOT_ENOUGH_POINTS).playTo(getPlayer());
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -103,7 +104,7 @@ public class AttributeView extends EditableInventory {
|
|||||||
playerData.giveAttributePoints(spent);
|
playerData.giveAttributePoints(spent);
|
||||||
playerData.giveAttributeReallocationPoints(-1);
|
playerData.giveAttributeReallocationPoints(-1);
|
||||||
MMOCore.plugin.configManager.getSimpleMessage("attribute-points-reallocated", "points", "" + playerData.getAttributePoints()).send(player);
|
MMOCore.plugin.configManager.getSimpleMessage("attribute-points-reallocated", "points", "" + playerData.getAttributePoints()).send(player);
|
||||||
MMOCore.plugin.soundManager.play(getPlayer(), SoundManager.SoundEvent.RESET_ATTRIBUTES);
|
MMOCore.plugin.soundManager.getSound(SoundEvent.RESET_ATTRIBUTES).playTo(getPlayer());
|
||||||
open();
|
open();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -112,21 +113,21 @@ public class AttributeView extends EditableInventory {
|
|||||||
|
|
||||||
if (playerData.getAttributePoints() < 1) {
|
if (playerData.getAttributePoints() < 1) {
|
||||||
MMOCore.plugin.configManager.getSimpleMessage("not-attribute-point").send(player);
|
MMOCore.plugin.configManager.getSimpleMessage("not-attribute-point").send(player);
|
||||||
MMOCore.plugin.soundManager.play(getPlayer(), SoundManager.SoundEvent.NOT_ENOUGH_POINTS);
|
MMOCore.plugin.soundManager.getSound(SoundEvent.NOT_ENOUGH_POINTS).playTo(getPlayer());
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
AttributeInstance ins = playerData.getAttributes().getInstance(attribute);
|
AttributeInstance ins = playerData.getAttributes().getInstance(attribute);
|
||||||
if (attribute.hasMax() && ins.getBase() >= attribute.getMax()) {
|
if (attribute.hasMax() && ins.getBase() >= attribute.getMax()) {
|
||||||
MMOCore.plugin.configManager.getSimpleMessage("attribute-max-points-hit").send(player);
|
MMOCore.plugin.configManager.getSimpleMessage("attribute-max-points-hit").send(player);
|
||||||
MMOCore.plugin.soundManager.play(getPlayer(), SoundManager.SoundEvent.NOT_ENOUGH_POINTS);
|
MMOCore.plugin.soundManager.getSound(SoundEvent.NOT_ENOUGH_POINTS).playTo(getPlayer());
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
ins.addBase(1);
|
ins.addBase(1);
|
||||||
playerData.giveAttributePoints(-1);
|
playerData.giveAttributePoints(-1);
|
||||||
MMOCore.plugin.configManager.getSimpleMessage("attribute-level-up", "attribute", attribute.getName(), "level", "" + ins.getBase()).send(player);
|
MMOCore.plugin.configManager.getSimpleMessage("attribute-level-up", "attribute", attribute.getName(), "level", "" + ins.getBase()).send(player);
|
||||||
MMOCore.plugin.soundManager.play(getPlayer(), SoundManager.SoundEvent.LEVEL_ATTRIBUTE);
|
MMOCore.plugin.soundManager.getSound(SoundEvent.LEVEL_ATTRIBUTE).playTo(getPlayer());
|
||||||
|
|
||||||
PlayerAttributeUseEvent playerAttributeUseEvent = new PlayerAttributeUseEvent(playerData, attribute);
|
PlayerAttributeUseEvent playerAttributeUseEvent = new PlayerAttributeUseEvent(playerData, attribute);
|
||||||
Bukkit.getServer().getPluginManager().callEvent(playerAttributeUseEvent);
|
Bukkit.getServer().getPluginManager().callEvent(playerAttributeUseEvent);
|
||||||
|
@ -1,6 +1,7 @@
|
|||||||
package net.Indyuce.mmocore.gui;
|
package net.Indyuce.mmocore.gui;
|
||||||
|
|
||||||
import net.Indyuce.mmocore.MMOCore;
|
import net.Indyuce.mmocore.MMOCore;
|
||||||
|
import net.Indyuce.mmocore.api.SoundEvent;
|
||||||
import net.Indyuce.mmocore.api.event.PlayerChangeClassEvent;
|
import net.Indyuce.mmocore.api.event.PlayerChangeClassEvent;
|
||||||
import net.Indyuce.mmocore.api.player.PlayerData;
|
import net.Indyuce.mmocore.api.player.PlayerData;
|
||||||
import net.Indyuce.mmocore.api.player.profess.PlayerClass;
|
import net.Indyuce.mmocore.api.player.profess.PlayerClass;
|
||||||
@ -125,7 +126,7 @@ public class ClassConfirmation extends EditableInventory {
|
|||||||
(playerData.hasSavedClass(profess) ? playerData.getClassInfo(profess)
|
(playerData.hasSavedClass(profess) ? playerData.getClassInfo(profess)
|
||||||
: new SavedClassInformation(MMOCore.plugin.dataProvider.getDataManager().getDefaultData())).load(profess, playerData);
|
: new SavedClassInformation(MMOCore.plugin.dataProvider.getDataManager().getDefaultData())).load(profess, playerData);
|
||||||
MMOCore.plugin.configManager.getSimpleMessage("class-select", "class", profess.getName()).send(player);
|
MMOCore.plugin.configManager.getSimpleMessage("class-select", "class", profess.getName()).send(player);
|
||||||
MMOCore.plugin.soundManager.play(player, SoundManager.SoundEvent.SELECT_CLASS);
|
MMOCore.plugin.soundManager.getSound(SoundEvent.SELECT_CLASS).playTo(player);
|
||||||
player.closeInventory();
|
player.closeInventory();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -5,6 +5,7 @@ import io.lumine.mythic.lib.api.item.ItemTag;
|
|||||||
import io.lumine.mythic.lib.api.item.NBTItem;
|
import io.lumine.mythic.lib.api.item.NBTItem;
|
||||||
import net.Indyuce.mmocore.MMOCore;
|
import net.Indyuce.mmocore.MMOCore;
|
||||||
import net.Indyuce.mmocore.api.ConfigMessage;
|
import net.Indyuce.mmocore.api.ConfigMessage;
|
||||||
|
import net.Indyuce.mmocore.api.SoundEvent;
|
||||||
import net.Indyuce.mmocore.api.player.PlayerData;
|
import net.Indyuce.mmocore.api.player.PlayerData;
|
||||||
import net.Indyuce.mmocore.api.player.profess.ClassOption;
|
import net.Indyuce.mmocore.api.player.profess.ClassOption;
|
||||||
import net.Indyuce.mmocore.api.player.profess.PlayerClass;
|
import net.Indyuce.mmocore.api.player.profess.PlayerClass;
|
||||||
@ -109,14 +110,14 @@ public class ClassSelect extends EditableInventory {
|
|||||||
return;
|
return;
|
||||||
|
|
||||||
if (playerData.getClassPoints() < 1) {
|
if (playerData.getClassPoints() < 1) {
|
||||||
MMOCore.plugin.soundManager.play(player, SoundManager.SoundEvent.CANT_SELECT_CLASS);
|
MMOCore.plugin.soundManager.getSound(SoundEvent.CANT_SELECT_CLASS).playTo(player);
|
||||||
new ConfigMessage("cant-choose-new-class").send(player);
|
new ConfigMessage("cant-choose-new-class").send(player);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
PlayerClass profess = MMOCore.plugin.classManager.get(tag);
|
PlayerClass profess = MMOCore.plugin.classManager.get(tag);
|
||||||
if (profess.equals(playerData.getProfess())) {
|
if (profess.equals(playerData.getProfess())) {
|
||||||
MMOCore.plugin.soundManager.play(player, SoundManager.SoundEvent.CANT_SELECT_CLASS);
|
MMOCore.plugin.soundManager.getSound(SoundEvent.CANT_SELECT_CLASS).playTo(player);
|
||||||
MMOCore.plugin.configManager.getSimpleMessage("already-on-class", "class", profess.getName()).send(player);
|
MMOCore.plugin.configManager.getSimpleMessage("already-on-class", "class", profess.getName()).send(player);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
@ -3,6 +3,7 @@ package net.Indyuce.mmocore.gui;
|
|||||||
import io.lumine.mythic.lib.api.item.ItemTag;
|
import io.lumine.mythic.lib.api.item.ItemTag;
|
||||||
import io.lumine.mythic.lib.api.item.NBTItem;
|
import io.lumine.mythic.lib.api.item.NBTItem;
|
||||||
import net.Indyuce.mmocore.MMOCore;
|
import net.Indyuce.mmocore.MMOCore;
|
||||||
|
import net.Indyuce.mmocore.api.SoundEvent;
|
||||||
import net.Indyuce.mmocore.experience.Profession;
|
import net.Indyuce.mmocore.experience.Profession;
|
||||||
import net.Indyuce.mmocore.api.player.PlayerData;
|
import net.Indyuce.mmocore.api.player.PlayerData;
|
||||||
import net.Indyuce.mmocore.api.quest.Quest;
|
import net.Indyuce.mmocore.api.quest.Quest;
|
||||||
@ -235,7 +236,7 @@ public class QuestViewer extends EditableInventory {
|
|||||||
if (playerData.getQuestData().hasCurrent(quest)) {
|
if (playerData.getQuestData().hasCurrent(quest)) {
|
||||||
if (event.getAction() == InventoryAction.PICKUP_HALF) {
|
if (event.getAction() == InventoryAction.PICKUP_HALF) {
|
||||||
playerData.getQuestData().start(null);
|
playerData.getQuestData().start(null);
|
||||||
MMOCore.plugin.soundManager.play(player, SoundManager.SoundEvent.CANCEL_QUEST);
|
MMOCore.plugin.soundManager.getSound(SoundEvent.CANCEL_QUEST).playTo(player);
|
||||||
MMOCore.plugin.configManager.getSimpleMessage("cancel-quest").send(player);
|
MMOCore.plugin.configManager.getSimpleMessage("cancel-quest").send(player);
|
||||||
open();
|
open();
|
||||||
}
|
}
|
||||||
@ -293,7 +294,7 @@ public class QuestViewer extends EditableInventory {
|
|||||||
* eventually start a new quest.
|
* eventually start a new quest.
|
||||||
*/
|
*/
|
||||||
MMOCore.plugin.configManager.getSimpleMessage("start-quest", "quest", quest.getName()).send(player);
|
MMOCore.plugin.configManager.getSimpleMessage("start-quest", "quest", quest.getName()).send(player);
|
||||||
MMOCore.plugin.soundManager.play(player, SoundManager.SoundEvent.START_QUEST);
|
MMOCore.plugin.soundManager.getSound(SoundEvent.START_QUEST).playTo(player);
|
||||||
playerData.getQuestData().start(quest);
|
playerData.getQuestData().start(quest);
|
||||||
open();
|
open();
|
||||||
}
|
}
|
||||||
|
@ -1,6 +1,7 @@
|
|||||||
package net.Indyuce.mmocore.gui;
|
package net.Indyuce.mmocore.gui;
|
||||||
|
|
||||||
import net.Indyuce.mmocore.MMOCore;
|
import net.Indyuce.mmocore.MMOCore;
|
||||||
|
import net.Indyuce.mmocore.api.SoundEvent;
|
||||||
import net.Indyuce.mmocore.api.event.PlayerChangeClassEvent;
|
import net.Indyuce.mmocore.api.event.PlayerChangeClassEvent;
|
||||||
import net.Indyuce.mmocore.api.player.PlayerData;
|
import net.Indyuce.mmocore.api.player.PlayerData;
|
||||||
import net.Indyuce.mmocore.api.player.profess.PlayerClass;
|
import net.Indyuce.mmocore.api.player.profess.PlayerClass;
|
||||||
@ -66,7 +67,7 @@ public class SubclassConfirmation extends EditableInventory {
|
|||||||
|
|
||||||
playerData.setClass(profess);
|
playerData.setClass(profess);
|
||||||
MMOCore.plugin.configManager.getSimpleMessage("class-select", "class", profess.getName()).send(player);
|
MMOCore.plugin.configManager.getSimpleMessage("class-select", "class", profess.getName()).send(player);
|
||||||
MMOCore.plugin.soundManager.play(player, SoundManager.SoundEvent.SELECT_CLASS);
|
MMOCore.plugin.soundManager.getSound(SoundEvent.SELECT_CLASS).playTo(player);
|
||||||
player.closeInventory();
|
player.closeInventory();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -5,6 +5,7 @@ import io.lumine.mythic.lib.api.item.ItemTag;
|
|||||||
import io.lumine.mythic.lib.api.item.NBTItem;
|
import io.lumine.mythic.lib.api.item.NBTItem;
|
||||||
import net.Indyuce.mmocore.MMOCore;
|
import net.Indyuce.mmocore.MMOCore;
|
||||||
import net.Indyuce.mmocore.api.ConfigMessage;
|
import net.Indyuce.mmocore.api.ConfigMessage;
|
||||||
|
import net.Indyuce.mmocore.api.SoundEvent;
|
||||||
import net.Indyuce.mmocore.api.player.PlayerData;
|
import net.Indyuce.mmocore.api.player.PlayerData;
|
||||||
import net.Indyuce.mmocore.api.player.profess.PlayerClass;
|
import net.Indyuce.mmocore.api.player.profess.PlayerClass;
|
||||||
import net.Indyuce.mmocore.api.player.profess.Subclass;
|
import net.Indyuce.mmocore.api.player.profess.Subclass;
|
||||||
@ -118,7 +119,7 @@ public class SubclassSelect extends EditableInventory {
|
|||||||
|
|
||||||
if (playerData.getClassPoints() < 1) {
|
if (playerData.getClassPoints() < 1) {
|
||||||
player.closeInventory();
|
player.closeInventory();
|
||||||
MMOCore.plugin.soundManager.play(getPlayer(), SoundManager.SoundEvent.CANT_SELECT_CLASS);
|
MMOCore.plugin.soundManager.getSound(SoundEvent.CANT_SELECT_CLASS).playTo(getPlayer());
|
||||||
new ConfigMessage("cant-choose-new-class").send(player);
|
new ConfigMessage("cant-choose-new-class").send(player);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
@ -1,5 +1,6 @@
|
|||||||
package net.Indyuce.mmocore.listener;
|
package net.Indyuce.mmocore.listener;
|
||||||
|
|
||||||
|
import net.Indyuce.mmocore.api.SoundEvent;
|
||||||
import net.Indyuce.mmocore.manager.SoundManager;
|
import net.Indyuce.mmocore.manager.SoundManager;
|
||||||
import org.bukkit.Particle;
|
import org.bukkit.Particle;
|
||||||
import org.bukkit.entity.Player;
|
import org.bukkit.entity.Player;
|
||||||
@ -29,7 +30,7 @@ public class WaypointsListener implements Listener {
|
|||||||
data.unlockWaypoint(waypoint);
|
data.unlockWaypoint(waypoint);
|
||||||
new SmallParticleEffect(player, Particle.SPELL_WITCH);
|
new SmallParticleEffect(player, Particle.SPELL_WITCH);
|
||||||
MMOCore.plugin.configManager.getSimpleMessage("new-waypoint", "waypoint", waypoint.getName()).send(player);
|
MMOCore.plugin.configManager.getSimpleMessage("new-waypoint", "waypoint", waypoint.getName()).send(player);
|
||||||
MMOCore.plugin.soundManager.play(player, SoundManager.SoundEvent.WARP_UNLOCK);
|
MMOCore.plugin.soundManager.getSound(SoundEvent.WARP_UNLOCK).playTo(player);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1,6 +1,7 @@
|
|||||||
package net.Indyuce.mmocore.loot.chest;
|
package net.Indyuce.mmocore.loot.chest;
|
||||||
|
|
||||||
import net.Indyuce.mmocore.MMOCore;
|
import net.Indyuce.mmocore.MMOCore;
|
||||||
|
import net.Indyuce.mmocore.api.SoundEvent;
|
||||||
import net.Indyuce.mmocore.manager.SoundManager;
|
import net.Indyuce.mmocore.manager.SoundManager;
|
||||||
import org.bukkit.Location;
|
import org.bukkit.Location;
|
||||||
import org.bukkit.Material;
|
import org.bukkit.Material;
|
||||||
@ -66,7 +67,7 @@ public class LootChest {
|
|||||||
|
|
||||||
// If a player is responsible of closing the chest, close it with sound
|
// If a player is responsible of closing the chest, close it with sound
|
||||||
if (player) {
|
if (player) {
|
||||||
MMOCore.plugin.soundManager.play(block.loc.getBlock(), SoundManager.SoundEvent.CLOSE_LOOT_CHEST);
|
MMOCore.plugin.soundManager.getSound(SoundEvent.CLOSE_LOOT_CHEST).playAt(block.loc);
|
||||||
block.loc.getWorld().spawnParticle(Particle.CRIT, block.loc.clone().add(.5, .5, .5), 16, 0, 0, 0, .5);
|
block.loc.getWorld().spawnParticle(Particle.CRIT, block.loc.clone().add(.5, .5, .5), 16, 0, 0, 0, .5);
|
||||||
MMOCore.plugin.lootChests.unregister(this);
|
MMOCore.plugin.lootChests.unregister(this);
|
||||||
}
|
}
|
||||||
|
@ -1,72 +1,24 @@
|
|||||||
package net.Indyuce.mmocore.manager;
|
package net.Indyuce.mmocore.manager;
|
||||||
|
|
||||||
|
import net.Indyuce.mmocore.api.SoundEvent;
|
||||||
import net.Indyuce.mmocore.api.SoundObject;
|
import net.Indyuce.mmocore.api.SoundObject;
|
||||||
import org.bukkit.Location;
|
|
||||||
import org.bukkit.block.Block;
|
|
||||||
import org.bukkit.configuration.file.FileConfiguration;
|
import org.bukkit.configuration.file.FileConfiguration;
|
||||||
import org.bukkit.entity.Player;
|
import org.jetbrains.annotations.NotNull;
|
||||||
|
|
||||||
import java.util.HashMap;
|
import java.util.HashMap;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
|
import java.util.Objects;
|
||||||
|
|
||||||
public class SoundManager {
|
public class SoundManager {
|
||||||
private final Map<SoundEvent, SoundObject> sounds = new HashMap<>();
|
private final Map<SoundEvent, SoundObject> sounds = new HashMap<>();
|
||||||
|
|
||||||
public SoundManager(FileConfiguration config) {
|
public SoundManager(FileConfiguration config) {
|
||||||
for(SoundEvent sound : SoundEvent.values())
|
for (SoundEvent sound : SoundEvent.values())
|
||||||
sounds.put(sound, new SoundObject(config.getString(sound.name().replace("_", "-").toLowerCase())));
|
sounds.put(sound, new SoundObject(config.getString(sound.name().replace("_", "-").toLowerCase())));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@NotNull
|
||||||
public void play(Block block, SoundEvent event) {
|
public SoundObject getSound(SoundEvent event) {
|
||||||
play(block, block.getLocation(), event);
|
return Objects.requireNonNull(sounds.get(event), "Could not find sound for " + event.name());
|
||||||
}
|
}
|
||||||
|
|
||||||
public void play(Block block, Location loc, SoundEvent event) {
|
|
||||||
SoundObject sound = sounds.get(event);
|
|
||||||
if(sound.hasSound())
|
|
||||||
block.getWorld().playSound(loc, sound.getSound(), sound.getVolume(), sound.getPitch());
|
|
||||||
else block.getWorld().playSound(loc, sound.getKey(), sound.getVolume(), sound.getPitch());
|
|
||||||
}
|
|
||||||
|
|
||||||
public void play(Player player, SoundEvent event) {
|
|
||||||
play(player, player.getLocation(), event);
|
|
||||||
}
|
|
||||||
|
|
||||||
public void play(Player player, Location loc, SoundEvent event) {
|
|
||||||
SoundObject sound = sounds.get(event);
|
|
||||||
if(sound.hasSound())
|
|
||||||
player.playSound(loc, sound.getSound(), sound.getVolume(), sound.getPitch());
|
|
||||||
else player.playSound(loc, sound.getKey(), sound.getVolume(), sound.getPitch());
|
|
||||||
}
|
|
||||||
|
|
||||||
public void play(Player player, SoundEvent event, float volume, float pitch) {
|
|
||||||
play(player, player.getLocation(), event, volume, pitch);
|
|
||||||
}
|
|
||||||
|
|
||||||
public void play(Player player, Location loc, SoundEvent event, float volume, float pitch) {
|
|
||||||
SoundObject sound = sounds.get(event);
|
|
||||||
if(sound.hasSound())
|
|
||||||
player.playSound(loc, sound.getSound(), volume, pitch);
|
|
||||||
else player.playSound(loc, sound.getKey(), volume, pitch);
|
|
||||||
}
|
|
||||||
|
|
||||||
public enum SoundEvent {
|
|
||||||
LEVEL_UP,
|
|
||||||
WARP_TELEPORT,
|
|
||||||
WARP_CANCELLED,
|
|
||||||
WARP_CHARGE,
|
|
||||||
WARP_UNLOCK,
|
|
||||||
HOTBAR_SWAP,
|
|
||||||
SPELL_CAST_BEGIN,
|
|
||||||
SPELL_CAST_END,
|
|
||||||
CANT_SELECT_CLASS,
|
|
||||||
SELECT_CLASS,
|
|
||||||
LEVEL_ATTRIBUTE,
|
|
||||||
RESET_ATTRIBUTES,
|
|
||||||
NOT_ENOUGH_POINTS,
|
|
||||||
CANCEL_QUEST,
|
|
||||||
START_QUEST,
|
|
||||||
CLOSE_LOOT_CHEST
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user