mirror of
https://github.com/taoneill/war.git
synced 2025-01-07 00:08:25 +01:00
Drop Spoutcraft support
Spout has been dead for 5 years
This commit is contained in:
parent
81f839a0a2
commit
6b90371fce
@ -17,7 +17,6 @@ Features
|
|||||||
- Other game types: capture points and explosive-based objectives
|
- Other game types: capture points and explosive-based objectives
|
||||||
- Up to 16 teams!
|
- Up to 16 teams!
|
||||||
- Tons of customizable game rules, item loadouts and options (see [Instructions](http://war.tommytony.com/instructions))
|
- Tons of customizable game rules, item loadouts and options (see [Instructions](http://war.tommytony.com/instructions))
|
||||||
- SpoutPlugin integration for an enriched UI experience during combat for Spoutcraft users (http://spout.org)
|
|
||||||
|
|
||||||
Downloads
|
Downloads
|
||||||
---------
|
---------
|
||||||
|
@ -102,13 +102,6 @@
|
|||||||
</resources>
|
</resources>
|
||||||
</build>
|
</build>
|
||||||
<dependencies>
|
<dependencies>
|
||||||
<dependency>
|
|
||||||
<groupId>org.spout</groupId>
|
|
||||||
<artifactId>spoutplugin</artifactId>
|
|
||||||
<version>1.5.2-R1.0</version>
|
|
||||||
<scope>compile</scope>
|
|
||||||
<type>jar</type>
|
|
||||||
</dependency>
|
|
||||||
<dependency>
|
<dependency>
|
||||||
<groupId>junit</groupId>
|
<groupId>junit</groupId>
|
||||||
<artifactId>junit</artifactId>
|
<artifactId>junit</artifactId>
|
||||||
|
@ -1,7 +1,6 @@
|
|||||||
package com.tommytony.war;
|
package com.tommytony.war;
|
||||||
|
|
||||||
import com.tommytony.war.config.*;
|
import com.tommytony.war.config.*;
|
||||||
import com.tommytony.war.spout.SpoutDisplayer;
|
|
||||||
import com.tommytony.war.utility.Direction;
|
import com.tommytony.war.utility.Direction;
|
||||||
import com.tommytony.war.volume.Volume;
|
import com.tommytony.war.volume.Volume;
|
||||||
import org.apache.commons.lang.Validate;
|
import org.apache.commons.lang.Validate;
|
||||||
@ -15,8 +14,6 @@ import org.bukkit.block.BlockState;
|
|||||||
import org.bukkit.entity.Player;
|
import org.bukkit.entity.Player;
|
||||||
import org.bukkit.inventory.ItemStack;
|
import org.bukkit.inventory.ItemStack;
|
||||||
import org.bukkit.material.Sign;
|
import org.bukkit.material.Sign;
|
||||||
import org.getspout.spoutapi.SpoutManager;
|
|
||||||
import org.getspout.spoutapi.player.SpoutPlayer;
|
|
||||||
import org.kitteh.tag.TagAPI;
|
import org.kitteh.tag.TagAPI;
|
||||||
|
|
||||||
import java.io.File;
|
import java.io.File;
|
||||||
@ -341,10 +338,6 @@ public class Team {
|
|||||||
}
|
}
|
||||||
block.update(true);
|
block.update(true);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (War.war.isSpoutServer()) {
|
|
||||||
War.war.getSpoutDisplayer().updateStats(this.warzone);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private void setBlock(int x, int y, int z, TeamKind kind) {
|
private void setBlock(int x, int y, int z, TeamKind kind) {
|
||||||
@ -395,18 +388,8 @@ public class Team {
|
|||||||
|
|
||||||
public void teamcast(String message, boolean isNotification) {
|
public void teamcast(String message, boolean isNotification) {
|
||||||
for (Player player : this.players) {
|
for (Player player : this.players) {
|
||||||
if (War.war.isSpoutServer()) {
|
|
||||||
SpoutPlayer sp = SpoutManager.getPlayer(player);
|
|
||||||
if (sp.isSpoutCraftEnabled() && isNotification) {
|
|
||||||
// team notifications go to the top left for Spout players to lessen War spam in chat box
|
|
||||||
War.war.getSpoutDisplayer().msg(sp, message);
|
|
||||||
} else {
|
|
||||||
War.war.msg(player, message);
|
War.war.msg(player, message);
|
||||||
}
|
}
|
||||||
} else {
|
|
||||||
War.war.msg(player, message);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public void teamcast(String message, Object... args) {
|
public void teamcast(String message, Object... args) {
|
||||||
@ -416,18 +399,8 @@ public class Team {
|
|||||||
|
|
||||||
public void teamcast(String message, boolean isNotification, Object... args) {
|
public void teamcast(String message, boolean isNotification, Object... args) {
|
||||||
for (Player player : this.players) {
|
for (Player player : this.players) {
|
||||||
if (War.war.isSpoutServer()) {
|
|
||||||
SpoutPlayer sp = SpoutManager.getPlayer(player);
|
|
||||||
if (sp.isSpoutCraftEnabled() && isNotification) {
|
|
||||||
// team notifications go to the top left for Spout players to lessen War spam in chat box
|
|
||||||
War.war.getSpoutDisplayer().msg(sp, MessageFormat.format(message, args));
|
|
||||||
} else {
|
|
||||||
War.war.msg(player, message, args);
|
War.war.msg(player, message, args);
|
||||||
}
|
}
|
||||||
} else {
|
|
||||||
War.war.msg(player, message, args);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -439,16 +412,6 @@ public class Team {
|
|||||||
* @param ticks Duration the achievement should be displayed
|
* @param ticks Duration the achievement should be displayed
|
||||||
*/
|
*/
|
||||||
public void sendAchievement(String line1, String line2, ItemStack icon, int ticks) {
|
public void sendAchievement(String line1, String line2, ItemStack icon, int ticks) {
|
||||||
if (!War.war.isSpoutServer())
|
|
||||||
return;
|
|
||||||
line1 = SpoutDisplayer.cleanForNotification(line1);
|
|
||||||
line2 = SpoutDisplayer.cleanForNotification(line2);
|
|
||||||
for (Player player : this.players) {
|
|
||||||
SpoutPlayer spoutPlayer = SpoutManager.getPlayer(player);
|
|
||||||
if (!spoutPlayer.isSpoutCraftEnabled())
|
|
||||||
continue;
|
|
||||||
spoutPlayer.sendNotification(line1, line2, icon, ticks);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public String getName() {
|
public String getName() {
|
||||||
@ -468,9 +431,6 @@ public class Team {
|
|||||||
if (War.war.isTagServer()) {
|
if (War.war.isTagServer()) {
|
||||||
TagAPI.refreshPlayer(thePlayer);
|
TagAPI.refreshPlayer(thePlayer);
|
||||||
}
|
}
|
||||||
if (War.war.isSpoutServer()) {
|
|
||||||
War.war.getSpoutDisplayer().updateStats(thePlayer);
|
|
||||||
}
|
|
||||||
thePlayer.setFireTicks(0);
|
thePlayer.setFireTicks(0);
|
||||||
thePlayer.setRemainingAir(300);
|
thePlayer.setRemainingAir(300);
|
||||||
if (!this.warzone.getReallyDeadFighters().contains(thePlayer.getName())) {
|
if (!this.warzone.getReallyDeadFighters().contains(thePlayer.getName())) {
|
||||||
|
@ -2,14 +2,15 @@ package com.tommytony.war;
|
|||||||
|
|
||||||
import com.tommytony.war.command.WarCommandHandler;
|
import com.tommytony.war.command.WarCommandHandler;
|
||||||
import com.tommytony.war.config.*;
|
import com.tommytony.war.config.*;
|
||||||
import com.tommytony.war.event.*;
|
import com.tommytony.war.event.WarBlockListener;
|
||||||
|
import com.tommytony.war.event.WarEntityListener;
|
||||||
|
import com.tommytony.war.event.WarPlayerListener;
|
||||||
|
import com.tommytony.war.event.WarTagListener;
|
||||||
import com.tommytony.war.job.CapturePointTimer;
|
import com.tommytony.war.job.CapturePointTimer;
|
||||||
import com.tommytony.war.job.HelmetProtectionTask;
|
import com.tommytony.war.job.HelmetProtectionTask;
|
||||||
import com.tommytony.war.job.ScoreboardSwitchTimer;
|
import com.tommytony.war.job.ScoreboardSwitchTimer;
|
||||||
import com.tommytony.war.job.SpoutFadeOutMessageJob;
|
|
||||||
import com.tommytony.war.mapper.WarYmlMapper;
|
import com.tommytony.war.mapper.WarYmlMapper;
|
||||||
import com.tommytony.war.mapper.WarzoneYmlMapper;
|
import com.tommytony.war.mapper.WarzoneYmlMapper;
|
||||||
import com.tommytony.war.spout.SpoutDisplayer;
|
|
||||||
import com.tommytony.war.structure.*;
|
import com.tommytony.war.structure.*;
|
||||||
import com.tommytony.war.ui.UIManager;
|
import com.tommytony.war.ui.UIManager;
|
||||||
import com.tommytony.war.utility.*;
|
import com.tommytony.war.utility.*;
|
||||||
@ -65,11 +66,9 @@ public class War extends JavaPlugin {
|
|||||||
private WarPlayerListener playerListener = new WarPlayerListener();
|
private WarPlayerListener playerListener = new WarPlayerListener();
|
||||||
private WarEntityListener entityListener = new WarEntityListener();
|
private WarEntityListener entityListener = new WarEntityListener();
|
||||||
private WarBlockListener blockListener = new WarBlockListener();
|
private WarBlockListener blockListener = new WarBlockListener();
|
||||||
private WarServerListener serverListener = new WarServerListener();
|
|
||||||
private WarCommandHandler commandHandler = new WarCommandHandler();
|
private WarCommandHandler commandHandler = new WarCommandHandler();
|
||||||
private PluginDescriptionFile desc = null;
|
private PluginDescriptionFile desc = null;
|
||||||
private boolean loaded = false;
|
private boolean loaded = false;
|
||||||
private boolean isSpoutServer = false;
|
|
||||||
private boolean tagServer = false;
|
private boolean tagServer = false;
|
||||||
// Zones and hub
|
// Zones and hub
|
||||||
private List<Warzone> warzones = new ArrayList<Warzone>();
|
private List<Warzone> warzones = new ArrayList<Warzone>();
|
||||||
@ -78,7 +77,6 @@ public class War extends JavaPlugin {
|
|||||||
private KillstreakReward killstreakReward;
|
private KillstreakReward killstreakReward;
|
||||||
private MySQLConfig mysqlConfig;
|
private MySQLConfig mysqlConfig;
|
||||||
private Economy econ = null;
|
private Economy econ = null;
|
||||||
private SpoutDisplayer spoutMessenger = null;
|
|
||||||
private HubLobbyMaterials warhubMaterials = new HubLobbyMaterials(
|
private HubLobbyMaterials warhubMaterials = new HubLobbyMaterials(
|
||||||
new ItemStack(Material.GLASS), new ItemStack(Material.OAK_WOOD),
|
new ItemStack(Material.GLASS), new ItemStack(Material.OAK_WOOD),
|
||||||
new ItemStack(Material.OBSIDIAN), new ItemStack(Material.GLOWSTONE));
|
new ItemStack(Material.OBSIDIAN), new ItemStack(Material.GLOWSTONE));
|
||||||
@ -121,14 +119,6 @@ public class War extends JavaPlugin {
|
|||||||
this.setLoaded(true);
|
this.setLoaded(true);
|
||||||
this.desc = this.getDescription();
|
this.desc = this.getDescription();
|
||||||
|
|
||||||
// Spout server detection
|
|
||||||
try {
|
|
||||||
Class.forName("org.getspout.spoutapi.player.SpoutPlayer");
|
|
||||||
isSpoutServer = true;
|
|
||||||
spoutMessenger = new SpoutDisplayer();
|
|
||||||
} catch (ClassNotFoundException e) {
|
|
||||||
isSpoutServer = false;
|
|
||||||
}
|
|
||||||
try {
|
try {
|
||||||
Class.forName("org.sqlite.JDBC").newInstance();
|
Class.forName("org.sqlite.JDBC").newInstance();
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
@ -143,7 +133,6 @@ public class War extends JavaPlugin {
|
|||||||
pm.registerEvents(this.playerListener, this);
|
pm.registerEvents(this.playerListener, this);
|
||||||
pm.registerEvents(this.entityListener, this);
|
pm.registerEvents(this.entityListener, this);
|
||||||
pm.registerEvents(this.blockListener, this);
|
pm.registerEvents(this.blockListener, this);
|
||||||
pm.registerEvents(this.serverListener, this);
|
|
||||||
pm.registerEvents(this.UIManager, this);
|
pm.registerEvents(this.UIManager, this);
|
||||||
if (pm.isPluginEnabled("TagAPI")) {
|
if (pm.isPluginEnabled("TagAPI")) {
|
||||||
try {
|
try {
|
||||||
@ -269,10 +258,6 @@ public class War extends JavaPlugin {
|
|||||||
ScoreboardSwitchTimer sst = new ScoreboardSwitchTimer();
|
ScoreboardSwitchTimer sst = new ScoreboardSwitchTimer();
|
||||||
sst.runTaskTimer(this, 500, 20 * 60);
|
sst.runTaskTimer(this, 500, 20 * 60);
|
||||||
|
|
||||||
if (this.isSpoutServer) {
|
|
||||||
SpoutFadeOutMessageJob fadeOutMessagesTask = new SpoutFadeOutMessageJob();
|
|
||||||
this.getServer().getScheduler().scheduleSyncRepeatingTask(this, fadeOutMessagesTask, 100, 100);
|
|
||||||
}
|
|
||||||
if (this.mysqlConfig.isEnabled()) {
|
if (this.mysqlConfig.isEnabled()) {
|
||||||
try {
|
try {
|
||||||
Class.forName("com.mysql.jdbc.Driver").newInstance();
|
Class.forName("com.mysql.jdbc.Driver").newInstance();
|
||||||
@ -1167,10 +1152,6 @@ public class War extends JavaPlugin {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public boolean isSpoutServer() {
|
|
||||||
return this.isSpoutServer;
|
|
||||||
}
|
|
||||||
|
|
||||||
public Warzone zoneOfZoneWallAtProximity(Location location) {
|
public Warzone zoneOfZoneWallAtProximity(Location location) {
|
||||||
for (Warzone zone : this.warzones) {
|
for (Warzone zone : this.warzones) {
|
||||||
if (zone.getWorld() == location.getWorld() && zone.isNearWall(location)) {
|
if (zone.getWorld() == location.getWorld() && zone.isNearWall(location)) {
|
||||||
@ -1248,10 +1229,6 @@ public class War extends JavaPlugin {
|
|||||||
return this.warConfig;
|
return this.warConfig;
|
||||||
}
|
}
|
||||||
|
|
||||||
public SpoutDisplayer getSpoutDisplayer() {
|
|
||||||
return this.spoutMessenger ;
|
|
||||||
}
|
|
||||||
|
|
||||||
public HubLobbyMaterials getWarhubMaterials() {
|
public HubLobbyMaterials getWarhubMaterials() {
|
||||||
return this.warhubMaterials;
|
return this.warhubMaterials;
|
||||||
}
|
}
|
||||||
|
@ -14,7 +14,6 @@ import com.tommytony.war.job.ZoneTimeJob;
|
|||||||
import com.tommytony.war.mapper.LoadoutYmlMapper;
|
import com.tommytony.war.mapper.LoadoutYmlMapper;
|
||||||
import com.tommytony.war.mapper.VolumeMapper;
|
import com.tommytony.war.mapper.VolumeMapper;
|
||||||
import com.tommytony.war.mapper.ZoneVolumeMapper;
|
import com.tommytony.war.mapper.ZoneVolumeMapper;
|
||||||
import com.tommytony.war.spout.SpoutDisplayer;
|
|
||||||
import com.tommytony.war.structure.*;
|
import com.tommytony.war.structure.*;
|
||||||
import com.tommytony.war.utility.*;
|
import com.tommytony.war.utility.*;
|
||||||
import com.tommytony.war.volume.Volume;
|
import com.tommytony.war.volume.Volume;
|
||||||
@ -44,8 +43,6 @@ import org.bukkit.potion.PotionEffectType;
|
|||||||
import org.bukkit.scoreboard.DisplaySlot;
|
import org.bukkit.scoreboard.DisplaySlot;
|
||||||
import org.bukkit.scoreboard.Objective;
|
import org.bukkit.scoreboard.Objective;
|
||||||
import org.bukkit.scoreboard.Scoreboard;
|
import org.bukkit.scoreboard.Scoreboard;
|
||||||
import org.getspout.spoutapi.SpoutManager;
|
|
||||||
import org.getspout.spoutapi.player.SpoutPlayer;
|
|
||||||
|
|
||||||
import java.sql.Connection;
|
import java.sql.Connection;
|
||||||
import java.sql.PreparedStatement;
|
import java.sql.PreparedStatement;
|
||||||
@ -529,11 +526,6 @@ public class Warzone {
|
|||||||
this.getLoadoutSelections().get(player.getName()).setStillInSpawn(true);
|
this.getLoadoutSelections().get(player.getName()).setStillInSpawn(true);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Spout
|
|
||||||
if (War.war.isSpoutServer()) {
|
|
||||||
SpoutManager.getPlayer(player).setTitle(team.getKind().getColor() + player.getName());
|
|
||||||
}
|
|
||||||
|
|
||||||
War.war.getKillstreakReward().getAirstrikePlayers().remove(player.getName());
|
War.war.getKillstreakReward().getAirstrikePlayers().remove(player.getName());
|
||||||
|
|
||||||
final LoadoutResetJob job = new LoadoutResetJob(this, team, player, isFirstRespawn, false);
|
final LoadoutResetJob job = new LoadoutResetJob(this, team, player, isFirstRespawn, false);
|
||||||
@ -641,9 +633,6 @@ public class Warzone {
|
|||||||
ItemStack[] contents = inventory.getContents();
|
ItemStack[] contents = inventory.getContents();
|
||||||
|
|
||||||
String playerTitle = player.getName();
|
String playerTitle = player.getName();
|
||||||
if (War.war.isSpoutServer()) {
|
|
||||||
playerTitle = SpoutManager.getPlayer(player).getTitle();
|
|
||||||
}
|
|
||||||
|
|
||||||
this.playerStates.put(
|
this.playerStates.put(
|
||||||
player.getName(),
|
player.getName(),
|
||||||
@ -675,9 +664,6 @@ public class Warzone {
|
|||||||
player.setExp(originalState.getExp());
|
player.setExp(originalState.getExp());
|
||||||
player.setAllowFlight(originalState.canFly());
|
player.setAllowFlight(originalState.canFly());
|
||||||
|
|
||||||
if (War.war.isSpoutServer()) {
|
|
||||||
SpoutManager.getPlayer(player).setTitle(originalState.getPlayerTitle());
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
player.setScoreboard(Bukkit.getScoreboardManager().getMainScoreboard());
|
player.setScoreboard(Bukkit.getScoreboardManager().getMainScoreboard());
|
||||||
}
|
}
|
||||||
@ -1508,19 +1494,6 @@ public class Warzone {
|
|||||||
War.war.getServer().getPluginManager().callEvent(event1);
|
War.war.getServer().getPluginManager().callEvent(event1);
|
||||||
|
|
||||||
for (Team t : this.getTeams()) {
|
for (Team t : this.getTeams()) {
|
||||||
if (War.war.isSpoutServer()) {
|
|
||||||
for (Player p : t.getPlayers()) {
|
|
||||||
SpoutPlayer sp = SpoutManager.getPlayer(p);
|
|
||||||
if (sp.isSpoutCraftEnabled()) {
|
|
||||||
sp.sendNotification(
|
|
||||||
SpoutDisplayer.cleanForNotification("Match won! " + ChatColor.WHITE + "Winners:"),
|
|
||||||
SpoutDisplayer.cleanForNotification(SpoutDisplayer.addMissingColor(winnersStr, this)),
|
|
||||||
Material.CAKE,
|
|
||||||
(short)0,
|
|
||||||
10000);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
String winnersStrAndExtra = "Score cap reached. Game is over! Winning team(s): " + winnersStr;
|
String winnersStrAndExtra = "Score cap reached. Game is over! Winning team(s): " + winnersStr;
|
||||||
winnersStrAndExtra += ". Resetting warzone and your inventory...";
|
winnersStrAndExtra += ". Resetting warzone and your inventory...";
|
||||||
t.teamcast(winnersStrAndExtra);
|
t.teamcast(winnersStrAndExtra);
|
||||||
@ -1777,9 +1750,6 @@ public class Warzone {
|
|||||||
playerItems.put(103, originalState.getHelmet());
|
playerItems.put(103, originalState.getHelmet());
|
||||||
}
|
}
|
||||||
|
|
||||||
if (War.war.isSpoutServer()) {
|
|
||||||
SpoutManager.getPlayer(player).setTitle(originalState.getPlayerTitle());
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return playerItems;
|
return playerItems;
|
||||||
|
@ -6,9 +6,6 @@ import org.bukkit.Material;
|
|||||||
import org.bukkit.block.BlockState;
|
import org.bukkit.block.BlockState;
|
||||||
import org.bukkit.inventory.ItemStack;
|
import org.bukkit.inventory.ItemStack;
|
||||||
import org.bukkit.inventory.meta.LeatherArmorMeta;
|
import org.bukkit.inventory.meta.LeatherArmorMeta;
|
||||||
import org.bukkit.material.MaterialData;
|
|
||||||
import org.bukkit.material.Wool;
|
|
||||||
import org.getspout.spoutapi.gui.Color;
|
|
||||||
|
|
||||||
public enum TeamKind {
|
public enum TeamKind {
|
||||||
WHITE (DyeColor.WHITE, Material.WHITE_WOOL, ChatColor.WHITE, 450),
|
WHITE (DyeColor.WHITE, Material.WHITE_WOOL, ChatColor.WHITE, 450),
|
||||||
@ -77,17 +74,6 @@ public enum TeamKind {
|
|||||||
return this.chatColor;
|
return this.chatColor;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* Get the color of this team in the Spout client GUI.
|
|
||||||
*
|
|
||||||
* @return spout chat GUI color
|
|
||||||
*/
|
|
||||||
public Color getSpoutColor() {
|
|
||||||
return new org.getspout.spoutapi.gui.Color(
|
|
||||||
dyeColor.getColor().getRed(), dyeColor.getColor().getGreen(),
|
|
||||||
dyeColor.getColor().getBlue());
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Get the color of the wool block as a bukkit color.
|
* Get the color of the wool block as a bukkit color.
|
||||||
*
|
*
|
||||||
|
@ -6,7 +6,6 @@ import com.tommytony.war.Warzone;
|
|||||||
import com.tommytony.war.config.TeamConfig;
|
import com.tommytony.war.config.TeamConfig;
|
||||||
import com.tommytony.war.config.WarConfig;
|
import com.tommytony.war.config.WarConfig;
|
||||||
import com.tommytony.war.config.WarzoneConfig;
|
import com.tommytony.war.config.WarzoneConfig;
|
||||||
import com.tommytony.war.spout.SpoutDisplayer;
|
|
||||||
import com.tommytony.war.structure.Bomb;
|
import com.tommytony.war.structure.Bomb;
|
||||||
import com.tommytony.war.structure.Cake;
|
import com.tommytony.war.structure.Cake;
|
||||||
import com.tommytony.war.structure.Monument;
|
import com.tommytony.war.structure.Monument;
|
||||||
@ -25,8 +24,6 @@ import org.bukkit.event.block.*;
|
|||||||
import org.bukkit.event.world.StructureGrowEvent;
|
import org.bukkit.event.world.StructureGrowEvent;
|
||||||
import org.bukkit.inventory.EquipmentSlot;
|
import org.bukkit.inventory.EquipmentSlot;
|
||||||
import org.bukkit.inventory.ItemStack;
|
import org.bukkit.inventory.ItemStack;
|
||||||
import org.getspout.spoutapi.SpoutManager;
|
|
||||||
import org.getspout.spoutapi.player.SpoutPlayer;
|
|
||||||
|
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
@ -57,19 +54,6 @@ public class WarBlockListener implements Listener {
|
|||||||
Monument monument = zone.getMonumentFromCenterBlock(block);
|
Monument monument = zone.getMonumentFromCenterBlock(block);
|
||||||
if (monument != null && !monument.hasOwner()) {
|
if (monument != null && !monument.hasOwner()) {
|
||||||
monument.capture(team);
|
monument.capture(team);
|
||||||
if (War.war.isSpoutServer()) {
|
|
||||||
for (Player p : team.getPlayers()) {
|
|
||||||
SpoutPlayer sp = SpoutManager.getPlayer(p);
|
|
||||||
if (sp.isSpoutCraftEnabled()) {
|
|
||||||
sp.sendNotification(
|
|
||||||
SpoutDisplayer.cleanForNotification("Monument " + ChatColor.WHITE + monument.getName()),
|
|
||||||
SpoutDisplayer.cleanForNotification(ChatColor.YELLOW + "capped by " + team.getKind().getColor() + player.getName() + ChatColor.YELLOW + "!"),
|
|
||||||
team.getKind().getMaterial(),
|
|
||||||
team.getKind().getData(),
|
|
||||||
10000);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
zone.broadcast("zone.monument.capture", monument.getName(), team.getName());
|
zone.broadcast("zone.monument.capture", monument.getName(), team.getName());
|
||||||
event.setCancelled(false);
|
event.setCancelled(false);
|
||||||
return; // important otherwise cancelled down a few line by isImportantblock
|
return; // important otherwise cancelled down a few line by isImportantblock
|
||||||
@ -257,19 +241,6 @@ public class WarBlockListener implements Listener {
|
|||||||
Monument monument = warzone.getMonumentFromCenterBlock(block);
|
Monument monument = warzone.getMonumentFromCenterBlock(block);
|
||||||
if (monument.hasOwner()) {
|
if (monument.hasOwner()) {
|
||||||
Team ownerTeam = monument.getOwnerTeam();
|
Team ownerTeam = monument.getOwnerTeam();
|
||||||
if (War.war.isSpoutServer()) {
|
|
||||||
for (Player p : team.getPlayers()) {
|
|
||||||
SpoutPlayer sp = SpoutManager.getPlayer(p);
|
|
||||||
if (sp.isSpoutCraftEnabled()) {
|
|
||||||
sp.sendNotification(
|
|
||||||
SpoutDisplayer.cleanForNotification("Monument " + ChatColor.WHITE + monument.getName()),
|
|
||||||
SpoutDisplayer.cleanForNotification(ChatColor.YELLOW + "freed by " + team.getKind().getColor() + player.getName() + ChatColor.YELLOW + "!"),
|
|
||||||
ownerTeam.getKind().getMaterial(),
|
|
||||||
ownerTeam.getKind().getData(),
|
|
||||||
10000);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
warzone.broadcast("zone.monument.lose", ownerTeam.getName(), monument.getName());
|
warzone.broadcast("zone.monument.lose", ownerTeam.getName(), monument.getName());
|
||||||
monument.uncapture();
|
monument.uncapture();
|
||||||
}
|
}
|
||||||
@ -309,19 +280,6 @@ public class WarBlockListener implements Listener {
|
|||||||
for (Team t : warzone.getTeams()) {
|
for (Team t : warzone.getTeams()) {
|
||||||
t.teamcast("zone.steal.flag.broadcast", team.getKind().getColor() + player.getName() + ChatColor.WHITE, lostFlagTeam.getName());
|
t.teamcast("zone.steal.flag.broadcast", team.getKind().getColor() + player.getName() + ChatColor.WHITE, lostFlagTeam.getName());
|
||||||
if (t.getName().equals(lostFlagTeam.getName())) {
|
if (t.getName().equals(lostFlagTeam.getName())) {
|
||||||
if (War.war.isSpoutServer()) {
|
|
||||||
for (Player p : t.getPlayers()) {
|
|
||||||
SpoutPlayer sp = SpoutManager.getPlayer(p);
|
|
||||||
if (sp.isSpoutCraftEnabled()) {
|
|
||||||
sp.sendNotification(
|
|
||||||
SpoutDisplayer.cleanForNotification(team.getKind().getColor() + player.getName() + ChatColor.YELLOW + " stole"),
|
|
||||||
SpoutDisplayer.cleanForNotification(ChatColor.YELLOW + "your flag!"),
|
|
||||||
lostFlagTeam.getKind().getMaterial(),
|
|
||||||
lostFlagTeam.getKind().getData(),
|
|
||||||
5000);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
t.teamcast("zone.steal.flag.prevent", team.getKind().getColor() + player.getName() + ChatColor.WHITE, team.getName());
|
t.teamcast("zone.steal.flag.prevent", team.getKind().getColor() + player.getName() + ChatColor.WHITE, team.getName());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -349,19 +307,6 @@ public class WarBlockListener implements Listener {
|
|||||||
block.setType(Material.AIR);
|
block.setType(Material.AIR);
|
||||||
for (Team t : warzone.getTeams()) {
|
for (Team t : warzone.getTeams()) {
|
||||||
t.teamcast("zone.steal.bomb.broadcast", team.getKind().getColor() + player.getName() + ChatColor.WHITE, ChatColor.GREEN + bomb.getName() + ChatColor.WHITE);
|
t.teamcast("zone.steal.bomb.broadcast", team.getKind().getColor() + player.getName() + ChatColor.WHITE, ChatColor.GREEN + bomb.getName() + ChatColor.WHITE);
|
||||||
if (War.war.isSpoutServer()) {
|
|
||||||
for (Player p : t.getPlayers()) {
|
|
||||||
SpoutPlayer sp = SpoutManager.getPlayer(p);
|
|
||||||
if (sp.isSpoutCraftEnabled()) {
|
|
||||||
sp.sendNotification(
|
|
||||||
SpoutDisplayer.cleanForNotification(team.getKind().getColor() + player.getName() + ChatColor.YELLOW + " has "),
|
|
||||||
SpoutDisplayer.cleanForNotification(ChatColor.YELLOW + "bomb " + ChatColor.GREEN + bomb.getName() + ChatColor.YELLOW + "!"),
|
|
||||||
Material.TNT,
|
|
||||||
(short)0,
|
|
||||||
5000);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
t.teamcast("zone.steal.bomb.prevent", team.getKind().getColor() + player.getName() + ChatColor.WHITE);
|
t.teamcast("zone.steal.bomb.prevent", team.getKind().getColor() + player.getName() + ChatColor.WHITE);
|
||||||
}
|
}
|
||||||
War.war.msg(player, "zone.steal.bomb.notice", bomb.getName());
|
War.war.msg(player, "zone.steal.bomb.notice", bomb.getName());
|
||||||
@ -385,19 +330,6 @@ public class WarBlockListener implements Listener {
|
|||||||
block.setType(Material.AIR);
|
block.setType(Material.AIR);
|
||||||
for (Team t : warzone.getTeams()) {
|
for (Team t : warzone.getTeams()) {
|
||||||
t.teamcast("zone.steal.cake.broadcast", team.getKind().getColor() + player.getName() + ChatColor.WHITE, ChatColor.GREEN + cake.getName() + ChatColor.WHITE);
|
t.teamcast("zone.steal.cake.broadcast", team.getKind().getColor() + player.getName() + ChatColor.WHITE, ChatColor.GREEN + cake.getName() + ChatColor.WHITE);
|
||||||
if (War.war.isSpoutServer()) {
|
|
||||||
for (Player p : t.getPlayers()) {
|
|
||||||
SpoutPlayer sp = SpoutManager.getPlayer(p);
|
|
||||||
if (sp.isSpoutCraftEnabled()) {
|
|
||||||
sp.sendNotification(
|
|
||||||
SpoutDisplayer.cleanForNotification(team.getKind().getColor() + player.getName() + ChatColor.YELLOW + " has "),
|
|
||||||
SpoutDisplayer.cleanForNotification(ChatColor.YELLOW + "cake " + ChatColor.GREEN + cake.getName() + ChatColor.YELLOW + "!"),
|
|
||||||
Material.CAKE,
|
|
||||||
(short)0,
|
|
||||||
5000);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
t.teamcast("zone.steal.cake.prevent", team.getKind().getColor() + player.getName() + ChatColor.WHITE);
|
t.teamcast("zone.steal.cake.prevent", team.getKind().getColor() + player.getName() + ChatColor.WHITE);
|
||||||
}
|
}
|
||||||
War.war.msg(player, "zone.steal.cake.notice", cake.getName());
|
War.war.msg(player, "zone.steal.cake.notice", cake.getName());
|
||||||
|
@ -1,16 +1,24 @@
|
|||||||
package com.tommytony.war.event;
|
package com.tommytony.war.event;
|
||||||
|
|
||||||
import java.util.HashMap;
|
import com.tommytony.war.Team;
|
||||||
import java.util.List;
|
import com.tommytony.war.War;
|
||||||
|
import com.tommytony.war.Warzone;
|
||||||
|
import com.tommytony.war.Warzone.LeaveCause;
|
||||||
|
import com.tommytony.war.command.ZoneSetter;
|
||||||
|
import com.tommytony.war.config.FlagReturn;
|
||||||
|
import com.tommytony.war.config.TeamConfig;
|
||||||
import com.tommytony.war.config.WarConfig;
|
import com.tommytony.war.config.WarConfig;
|
||||||
|
import com.tommytony.war.config.WarzoneConfig;
|
||||||
|
import com.tommytony.war.structure.Bomb;
|
||||||
|
import com.tommytony.war.structure.Cake;
|
||||||
|
import com.tommytony.war.structure.WarHub;
|
||||||
|
import com.tommytony.war.structure.ZoneLobby;
|
||||||
|
import com.tommytony.war.utility.Direction;
|
||||||
|
import com.tommytony.war.utility.Loadout;
|
||||||
|
import com.tommytony.war.utility.LoadoutSelection;
|
||||||
|
import com.tommytony.war.volume.Volume;
|
||||||
import org.apache.commons.lang.Validate;
|
import org.apache.commons.lang.Validate;
|
||||||
import org.bukkit.ChatColor;
|
import org.bukkit.*;
|
||||||
import org.bukkit.Effect;
|
|
||||||
import org.bukkit.Location;
|
|
||||||
import org.bukkit.Material;
|
|
||||||
import org.bukkit.Sound;
|
|
||||||
import org.bukkit.block.BlockFace;
|
import org.bukkit.block.BlockFace;
|
||||||
import org.bukkit.block.Sign;
|
import org.bukkit.block.Sign;
|
||||||
import org.bukkit.entity.Item;
|
import org.bukkit.entity.Item;
|
||||||
@ -26,29 +34,11 @@ import org.bukkit.event.inventory.InventoryType;
|
|||||||
import org.bukkit.event.player.*;
|
import org.bukkit.event.player.*;
|
||||||
import org.bukkit.inventory.InventoryHolder;
|
import org.bukkit.inventory.InventoryHolder;
|
||||||
import org.bukkit.inventory.ItemStack;
|
import org.bukkit.inventory.ItemStack;
|
||||||
import org.getspout.spoutapi.SpoutManager;
|
|
||||||
import org.getspout.spoutapi.player.SpoutPlayer;
|
|
||||||
|
|
||||||
import com.tommytony.war.Team;
|
|
||||||
import com.tommytony.war.War;
|
|
||||||
import com.tommytony.war.Warzone;
|
|
||||||
import com.tommytony.war.Warzone.LeaveCause;
|
|
||||||
import com.tommytony.war.command.ZoneSetter;
|
|
||||||
import com.tommytony.war.config.FlagReturn;
|
|
||||||
import com.tommytony.war.config.TeamConfig;
|
|
||||||
import com.tommytony.war.config.WarzoneConfig;
|
|
||||||
import com.tommytony.war.spout.SpoutDisplayer;
|
|
||||||
import com.tommytony.war.structure.Bomb;
|
|
||||||
import com.tommytony.war.structure.Cake;
|
|
||||||
import com.tommytony.war.structure.WarHub;
|
|
||||||
import com.tommytony.war.structure.ZoneLobby;
|
|
||||||
import com.tommytony.war.utility.Direction;
|
|
||||||
import com.tommytony.war.utility.Loadout;
|
|
||||||
import com.tommytony.war.utility.LoadoutSelection;
|
|
||||||
import com.tommytony.war.volume.Volume;
|
|
||||||
|
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
|
import java.util.HashMap;
|
||||||
import java.util.Iterator;
|
import java.util.Iterator;
|
||||||
|
import java.util.List;
|
||||||
import java.util.logging.Level;
|
import java.util.logging.Level;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -636,19 +626,6 @@ public class WarPlayerListener implements Listener {
|
|||||||
|
|
||||||
// Notify everyone
|
// Notify everyone
|
||||||
for (Team t : playerWarzone.getTeams()) {
|
for (Team t : playerWarzone.getTeams()) {
|
||||||
if (War.war.isSpoutServer()) {
|
|
||||||
for (Player p : t.getPlayers()) {
|
|
||||||
SpoutPlayer sp = SpoutManager.getPlayer(p);
|
|
||||||
if (sp.isSpoutCraftEnabled()) {
|
|
||||||
sp.sendNotification(
|
|
||||||
SpoutDisplayer.cleanForNotification(playerTeam.getKind().getColor() + player.getName() + ChatColor.YELLOW + " captured"),
|
|
||||||
SpoutDisplayer.cleanForNotification(victim.getKind().getColor() + victim.getName() + ChatColor.YELLOW + " flag!"),
|
|
||||||
victim.getKind().getMaterial(),
|
|
||||||
victim.getKind().getData(),
|
|
||||||
10000);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
t.teamcast("zone.flagcapture.broadcast", playerTeam.getKind().getColor() + player.getName() + ChatColor.WHITE,
|
t.teamcast("zone.flagcapture.broadcast", playerTeam.getKind().getColor() + player.getName() + ChatColor.WHITE,
|
||||||
victim.getName(), playerTeam.getName());
|
victim.getName(), playerTeam.getName());
|
||||||
}
|
}
|
||||||
@ -716,19 +693,6 @@ public class WarPlayerListener implements Listener {
|
|||||||
|
|
||||||
// Notify everyone
|
// Notify everyone
|
||||||
for (Team t : playerWarzone.getTeams()) {
|
for (Team t : playerWarzone.getTeams()) {
|
||||||
if (War.war.isSpoutServer()) {
|
|
||||||
for (Player p : t.getPlayers()) {
|
|
||||||
SpoutPlayer sp = SpoutManager.getPlayer(p);
|
|
||||||
if (sp.isSpoutCraftEnabled()) {
|
|
||||||
sp.sendNotification(
|
|
||||||
SpoutDisplayer.cleanForNotification(playerTeam.getKind().getColor() + player.getName() + ChatColor.YELLOW + " blew up "),
|
|
||||||
SpoutDisplayer.cleanForNotification(victim.getKind().getColor() + victim.getName() + ChatColor.YELLOW + "'s spawn!"),
|
|
||||||
victim.getKind().getMaterial(),
|
|
||||||
victim.getKind().getData(),
|
|
||||||
10000);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
t.teamcast("zone.bomb.broadcast", playerTeam.getKind().getColor() + player.getName() + ChatColor.WHITE,
|
t.teamcast("zone.bomb.broadcast", playerTeam.getKind().getColor() + player.getName() + ChatColor.WHITE,
|
||||||
victim.getName(), playerTeam.getName());
|
victim.getName(), playerTeam.getName());
|
||||||
}
|
}
|
||||||
@ -801,19 +765,6 @@ public class WarPlayerListener implements Listener {
|
|||||||
|
|
||||||
// Notify everyone
|
// Notify everyone
|
||||||
for (Team t : playerWarzone.getTeams()) {
|
for (Team t : playerWarzone.getTeams()) {
|
||||||
if (War.war.isSpoutServer()) {
|
|
||||||
for (Player p : t.getPlayers()) {
|
|
||||||
SpoutPlayer sp = SpoutManager.getPlayer(p);
|
|
||||||
if (sp.isSpoutCraftEnabled()) {
|
|
||||||
sp.sendNotification(
|
|
||||||
SpoutDisplayer.cleanForNotification(playerTeam.getKind().getColor() + player.getName() + ChatColor.YELLOW + " captured"),
|
|
||||||
SpoutDisplayer.cleanForNotification(ChatColor.YELLOW + "cake " + ChatColor.GREEN + cake.getName() + ChatColor.YELLOW + "!"),
|
|
||||||
playerTeam.getKind().getMaterial(),
|
|
||||||
playerTeam.getKind().getData(),
|
|
||||||
10000);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
t.teamcast("zone.cake.broadcast", playerTeam.getKind().getColor() + player.getName() + ChatColor.WHITE,
|
t.teamcast("zone.cake.broadcast", playerTeam.getKind().getColor() + player.getName() + ChatColor.WHITE,
|
||||||
ChatColor.GREEN + cake.getName() + ChatColor.WHITE, playerTeam.getName());
|
ChatColor.GREEN + cake.getName() + ChatColor.WHITE, playerTeam.getName());
|
||||||
}
|
}
|
||||||
|
@ -1,28 +0,0 @@
|
|||||||
package com.tommytony.war.event;
|
|
||||||
|
|
||||||
import org.bukkit.entity.Player;
|
|
||||||
import org.bukkit.event.EventHandler;
|
|
||||||
import org.bukkit.event.Listener;
|
|
||||||
import org.bukkit.event.server.PluginDisableEvent;
|
|
||||||
import org.getspout.spoutapi.SpoutManager;
|
|
||||||
import org.getspout.spoutapi.player.SpoutPlayer;
|
|
||||||
|
|
||||||
import com.tommytony.war.War;
|
|
||||||
|
|
||||||
public class WarServerListener implements Listener {
|
|
||||||
|
|
||||||
@EventHandler
|
|
||||||
public void onPluginDisable(final PluginDisableEvent event) {
|
|
||||||
if (event.getPlugin().getDataFolder().getName().equals("Spout")) {
|
|
||||||
if (War.war.isSpoutServer()) {
|
|
||||||
for (Player player : War.war.getServer().getOnlinePlayers()) {
|
|
||||||
SpoutPlayer sp = SpoutManager.getPlayer(player);
|
|
||||||
if (sp.isSpoutCraftEnabled()) {
|
|
||||||
sp.getMainScreen().removeWidgets(War.war);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
War.war.getSpoutDisplayer().clearAll();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,21 +1,18 @@
|
|||||||
package com.tommytony.war.job;
|
package com.tommytony.war.job;
|
||||||
|
|
||||||
import java.io.IOException;
|
|
||||||
import java.sql.SQLException;
|
|
||||||
import java.util.List;
|
|
||||||
import java.util.logging.Level;
|
|
||||||
import java.util.Locale;
|
|
||||||
|
|
||||||
import com.tommytony.war.War;
|
import com.tommytony.war.War;
|
||||||
import com.tommytony.war.Warzone;
|
import com.tommytony.war.Warzone;
|
||||||
import com.tommytony.war.config.WarzoneConfig;
|
import com.tommytony.war.config.WarzoneConfig;
|
||||||
import com.tommytony.war.mapper.WarzoneYmlMapper;
|
import com.tommytony.war.mapper.WarzoneYmlMapper;
|
||||||
|
|
||||||
import org.bukkit.Bukkit;
|
import org.bukkit.Bukkit;
|
||||||
|
|
||||||
import org.mcstats.Metrics;
|
import org.mcstats.Metrics;
|
||||||
import org.mcstats.Metrics.Graph;
|
import org.mcstats.Metrics.Graph;
|
||||||
|
|
||||||
|
import java.sql.SQLException;
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.Locale;
|
||||||
|
import java.util.logging.Level;
|
||||||
|
|
||||||
public class RestoreYmlWarzonesJob implements Runnable {
|
public class RestoreYmlWarzonesJob implements Runnable {
|
||||||
|
|
||||||
private final List<String> warzones;
|
private final List<String> warzones;
|
||||||
@ -63,9 +60,6 @@ public class RestoreYmlWarzonesJob implements Runnable {
|
|||||||
}
|
}
|
||||||
language.addPlotter(new PlotterEnabled(langName));
|
language.addPlotter(new PlotterEnabled(langName));
|
||||||
Graph plugins = metrics.createGraph("Extensions");
|
Graph plugins = metrics.createGraph("Extensions");
|
||||||
if (War.war.isSpoutServer()) {
|
|
||||||
plugins.addPlotter(new PlotterEnabled("Spout"));
|
|
||||||
}
|
|
||||||
if (War.war.isTagServer()) {
|
if (War.war.isTagServer()) {
|
||||||
plugins.addPlotter(new PlotterEnabled("TagAPI"));
|
plugins.addPlotter(new PlotterEnabled("TagAPI"));
|
||||||
}
|
}
|
||||||
|
@ -1,14 +0,0 @@
|
|||||||
package com.tommytony.war.job;
|
|
||||||
|
|
||||||
import com.tommytony.war.War;
|
|
||||||
|
|
||||||
public class SpoutFadeOutMessageJob implements Runnable {
|
|
||||||
|
|
||||||
public SpoutFadeOutMessageJob() {
|
|
||||||
}
|
|
||||||
|
|
||||||
public void run() {
|
|
||||||
War.war.getSpoutDisplayer().fadeOutOldMessages();
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
@ -1,20 +0,0 @@
|
|||||||
package com.tommytony.war.spout;
|
|
||||||
|
|
||||||
public class PlayerMessage {
|
|
||||||
|
|
||||||
private final String message;
|
|
||||||
private final long sendTime;
|
|
||||||
|
|
||||||
public PlayerMessage(String message) {
|
|
||||||
this.message = message;
|
|
||||||
this.sendTime = System.currentTimeMillis();
|
|
||||||
}
|
|
||||||
|
|
||||||
public String getMessage() {
|
|
||||||
return message;
|
|
||||||
}
|
|
||||||
|
|
||||||
public long getSendTime() {
|
|
||||||
return sendTime;
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,396 +0,0 @@
|
|||||||
package com.tommytony.war.spout;
|
|
||||||
|
|
||||||
import java.util.ArrayList;
|
|
||||||
import java.util.HashMap;
|
|
||||||
import java.util.List;
|
|
||||||
import java.util.Map;
|
|
||||||
|
|
||||||
import org.bukkit.ChatColor;
|
|
||||||
import org.bukkit.entity.Player;
|
|
||||||
import org.getspout.spoutapi.SpoutManager;
|
|
||||||
import org.getspout.spoutapi.gui.Color;
|
|
||||||
import org.getspout.spoutapi.gui.GenericGradient;
|
|
||||||
import org.getspout.spoutapi.gui.GenericLabel;
|
|
||||||
import org.getspout.spoutapi.gui.WidgetAnchor;
|
|
||||||
import org.getspout.spoutapi.player.SpoutPlayer;
|
|
||||||
|
|
||||||
|
|
||||||
import com.tommytony.war.Team;
|
|
||||||
import com.tommytony.war.War;
|
|
||||||
import com.tommytony.war.Warzone;
|
|
||||||
import com.tommytony.war.config.TeamConfig;
|
|
||||||
import com.tommytony.war.config.TeamKind;
|
|
||||||
|
|
||||||
public class SpoutDisplayer {
|
|
||||||
|
|
||||||
private static int LINE_HEIGHT = 5;
|
|
||||||
private static int LINE_HEIGHT_WITH_MARGIN = 8;
|
|
||||||
|
|
||||||
Map<String, List<PlayerMessage>> playerMessages = new HashMap<String, List<PlayerMessage>>();
|
|
||||||
|
|
||||||
public void msg(SpoutPlayer sp, String message) {
|
|
||||||
if (!playerMessages.containsKey(sp.getName())) {
|
|
||||||
playerMessages.put(sp.getName(), new ArrayList<PlayerMessage>());
|
|
||||||
}
|
|
||||||
List<PlayerMessage> messages = playerMessages.get(sp.getName());
|
|
||||||
messages.add(new PlayerMessage(message));
|
|
||||||
|
|
||||||
// prevent huge stack of messages, 5 max
|
|
||||||
if (messages.size() > 5) {
|
|
||||||
// remove first
|
|
||||||
messages.remove(0);
|
|
||||||
}
|
|
||||||
|
|
||||||
List<Integer> statsOffset = new ArrayList<Integer>();
|
|
||||||
List<GenericLabel> lines = getStatsLines(Warzone.getZoneByPlayerName(sp.getName()), statsOffset);
|
|
||||||
|
|
||||||
drawMessages(sp.getName(), lines, statsOffset);
|
|
||||||
}
|
|
||||||
|
|
||||||
public void fadeOutOldMessages() {
|
|
||||||
for (String playerName : playerMessages.keySet()) {
|
|
||||||
List<PlayerMessage> messages = playerMessages.get(playerName);
|
|
||||||
List<PlayerMessage> toRemove = new ArrayList<PlayerMessage>();
|
|
||||||
|
|
||||||
for (PlayerMessage message : messages) {
|
|
||||||
if (System.currentTimeMillis() - message.getSendTime() > 15000) {
|
|
||||||
|
|
||||||
toRemove.add(message);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
for (PlayerMessage removing : toRemove) {
|
|
||||||
messages.remove(removing);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (toRemove.size() > 0) {
|
|
||||||
List<Integer> statsOffset = new ArrayList<Integer>();
|
|
||||||
List<GenericLabel> lines = getStatsLines(Warzone.getZoneByPlayerName(playerName), statsOffset);
|
|
||||||
drawMessages(playerName, lines, statsOffset);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
private void clear(SpoutPlayer player) {
|
|
||||||
player.getMainScreen().removeWidgets(War.war);
|
|
||||||
}
|
|
||||||
|
|
||||||
public void clearAll() {
|
|
||||||
List<String> namesToRemove = new ArrayList<String>();
|
|
||||||
for (String name : playerMessages.keySet()) {
|
|
||||||
Player player = War.war.getServer().getPlayer(name);
|
|
||||||
if (player != null && playerMessages.containsKey(name)) {
|
|
||||||
clear(SpoutManager.getPlayer(player));
|
|
||||||
}
|
|
||||||
|
|
||||||
namesToRemove.add(name);
|
|
||||||
}
|
|
||||||
|
|
||||||
for (String toRemove : namesToRemove) {
|
|
||||||
playerMessages.remove(toRemove);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public static String cleanForNotification(String toNotify) {
|
|
||||||
if (toNotify.length() > 26) {
|
|
||||||
return toNotify.substring(0, 25);
|
|
||||||
}
|
|
||||||
|
|
||||||
return toNotify;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void updateStats(Warzone zone) {
|
|
||||||
List<Integer> statsOffset = new ArrayList<Integer>();
|
|
||||||
List<GenericLabel> statsLines = getStatsLines(zone, statsOffset);
|
|
||||||
for (Team t : zone.getTeams()) {
|
|
||||||
for (Player p : t.getPlayers()) {
|
|
||||||
SpoutPlayer sp = SpoutManager.getPlayer(p);
|
|
||||||
if (sp.isSpoutCraftEnabled()) {
|
|
||||||
drawMessages(sp.getName(), statsLines, statsOffset);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
public void updateStats(Player player) {
|
|
||||||
SpoutPlayer sp = SpoutManager.getPlayer(player);
|
|
||||||
if (sp.isSpoutCraftEnabled()) {
|
|
||||||
List<Integer> statsOffset = new ArrayList<Integer>();
|
|
||||||
Warzone zone = Warzone.getZoneByPlayerName(player.getName());
|
|
||||||
List<GenericLabel> statsLines = getStatsLines(zone, statsOffset);
|
|
||||||
drawMessages(sp.getName(), statsLines, statsOffset);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
private static List<GenericLabel> getStatsLines(Warzone zone, List<Integer> offset) {
|
|
||||||
List<GenericLabel> lines = new ArrayList<GenericLabel>();
|
|
||||||
offset.add(0);
|
|
||||||
offset.add(0);
|
|
||||||
|
|
||||||
if (zone != null) {
|
|
||||||
offset.clear();
|
|
||||||
|
|
||||||
List<GenericLabel> teamlines = new ArrayList<GenericLabel>();
|
|
||||||
List<GenericLabel> playerlines = new ArrayList<GenericLabel>();
|
|
||||||
List<GenericLabel> scorelines = new ArrayList<GenericLabel>();
|
|
||||||
List<GenericLabel> lifelines = new ArrayList<GenericLabel>();
|
|
||||||
int teamMax = 0, scoreMax = 0, lifeMax = 0;
|
|
||||||
GenericLabel line;
|
|
||||||
|
|
||||||
GenericLabel teamsHeader = new GenericLabel(ChatColor.GRAY + "War> " + ChatColor.WHITE + zone.getName());
|
|
||||||
int teamsHeaderWidth = GenericLabel.getStringWidth(teamsHeader.getText()) + 1;
|
|
||||||
teamsHeader.setAnchor(WidgetAnchor.TOP_LEFT)
|
|
||||||
.setX(3)
|
|
||||||
.setY(2)
|
|
||||||
.setWidth(teamsHeaderWidth)
|
|
||||||
.setHeight(LINE_HEIGHT);
|
|
||||||
lines.add(teamsHeader);
|
|
||||||
|
|
||||||
// First, we collect all the team names
|
|
||||||
int lineCounter = 1;
|
|
||||||
for (Team t : zone.getTeams()) {
|
|
||||||
// team name
|
|
||||||
String teamStr = t.getName() + " (" + t.getPlayers().size() + "/" + t.getTeamConfig().resolveInt(TeamConfig.TEAMSIZE) + ")";
|
|
||||||
line = new GenericLabel(teamStr);
|
|
||||||
if (t.getPlayers().size() == 0) {
|
|
||||||
line.setTextColor(new Color(100,100,100));
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
line.setText(t.getKind().getColor() + teamStr.replace("(", ChatColor.GRAY + "(" + ChatColor.WHITE).replace(")", ChatColor.GRAY + ")" + ChatColor.WHITE));
|
|
||||||
}
|
|
||||||
line.setAnchor(WidgetAnchor.TOP_LEFT)
|
|
||||||
.setX(3)
|
|
||||||
.setY(4 + lineCounter * LINE_HEIGHT_WITH_MARGIN)
|
|
||||||
.setWidth(GenericLabel.getStringWidth(line.getText()))
|
|
||||||
.setHeight(LINE_HEIGHT);
|
|
||||||
teamlines.add(line);
|
|
||||||
lineCounter++;
|
|
||||||
}
|
|
||||||
|
|
||||||
// We need to find the longest name
|
|
||||||
for (GenericLabel l : teamlines) {
|
|
||||||
if (GenericLabel.getStringWidth(l.getText()) > teamMax) {
|
|
||||||
teamMax = GenericLabel.getStringWidth(l.getText());
|
|
||||||
}
|
|
||||||
if (teamsHeaderWidth > teamMax) {
|
|
||||||
teamMax = teamsHeaderWidth;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// points header
|
|
||||||
GenericLabel pointsHeader = new GenericLabel(ChatColor.GRAY + "score");
|
|
||||||
int pointsHeaderWidth = GenericLabel.getStringWidth(pointsHeader.getText());
|
|
||||||
pointsHeader.setAnchor(WidgetAnchor.TOP_LEFT)
|
|
||||||
.setX(3 + teamMax + 2)
|
|
||||||
.setY(2)
|
|
||||||
.setWidth(pointsHeaderWidth)
|
|
||||||
.setHeight(LINE_HEIGHT);
|
|
||||||
lines.add(pointsHeader);
|
|
||||||
|
|
||||||
|
|
||||||
lineCounter = 1;
|
|
||||||
for (Team t : zone.getTeams()) {
|
|
||||||
// scores
|
|
||||||
line = new GenericLabel(t.getPoints() + "/" + t.getTeamConfig().resolveInt(TeamConfig.MAXSCORE));
|
|
||||||
if (t.getPlayers().size() == 0) line.setTextColor(new Color(100, 100, 100));
|
|
||||||
line.setAnchor(WidgetAnchor.TOP_LEFT)
|
|
||||||
.setX(3 + teamMax + 4)
|
|
||||||
.setY(4 + lineCounter * LINE_HEIGHT_WITH_MARGIN)
|
|
||||||
.setWidth(GenericLabel.getStringWidth(line.getText()))
|
|
||||||
.setHeight(LINE_HEIGHT);
|
|
||||||
scorelines.add(line);
|
|
||||||
lineCounter++;
|
|
||||||
}
|
|
||||||
|
|
||||||
for (GenericLabel l : scorelines) {
|
|
||||||
if (GenericLabel.getStringWidth(l.getText()) > scoreMax) {
|
|
||||||
scoreMax = GenericLabel.getStringWidth(l.getText());
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if (pointsHeaderWidth > scoreMax) {
|
|
||||||
scoreMax = pointsHeaderWidth;
|
|
||||||
}
|
|
||||||
|
|
||||||
// lifepool header
|
|
||||||
GenericLabel livesHeader = new GenericLabel(ChatColor.GRAY + "lives");
|
|
||||||
int livesHeaderWidth = GenericLabel.getStringWidth(livesHeader.getText());
|
|
||||||
livesHeader.setAnchor(WidgetAnchor.TOP_LEFT)
|
|
||||||
.setX(3 + teamMax + 4 + scoreMax + 2)
|
|
||||||
.setY(2)
|
|
||||||
.setWidth(livesHeaderWidth)
|
|
||||||
.setHeight(LINE_HEIGHT);
|
|
||||||
lines.add(livesHeader);
|
|
||||||
|
|
||||||
|
|
||||||
// and finally, lives.
|
|
||||||
lineCounter = 1;
|
|
||||||
for (Team t : zone.getTeams()) {
|
|
||||||
line = new GenericLabel(t.getRemainingLives() + "/" + t.getTeamConfig().resolveInt(TeamConfig.LIFEPOOL));
|
|
||||||
if (t.getPlayers().size() == 0) line.setTextColor(new Color(100, 100, 100));
|
|
||||||
line.setAnchor(WidgetAnchor.TOP_LEFT)
|
|
||||||
.setX(3 + teamMax + 4 + scoreMax + 4)
|
|
||||||
.setY(4 + lineCounter * LINE_HEIGHT_WITH_MARGIN)
|
|
||||||
.setWidth(GenericLabel.getStringWidth(line.getText()))
|
|
||||||
.setHeight(LINE_HEIGHT);
|
|
||||||
lifelines.add(line);
|
|
||||||
lineCounter++;
|
|
||||||
}
|
|
||||||
|
|
||||||
for (GenericLabel l : lifelines) {
|
|
||||||
if (GenericLabel.getStringWidth(l.getText()) > lifeMax) {
|
|
||||||
lifeMax = GenericLabel.getStringWidth(l.getText());
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if (livesHeaderWidth > lifeMax) {
|
|
||||||
lifeMax = livesHeaderWidth;
|
|
||||||
}
|
|
||||||
|
|
||||||
for (GenericLabel l : teamlines) { lines.add(l); }
|
|
||||||
for (GenericLabel l : playerlines) { lines.add(l); }
|
|
||||||
for (GenericLabel l : scorelines) { lines.add(l); }
|
|
||||||
for (GenericLabel l : lifelines) { lines.add(l); }
|
|
||||||
|
|
||||||
offset.add(3 + teamMax + 1 + scoreMax + 1 + lifeMax + 5);
|
|
||||||
offset.add(4 + lineCounter * LINE_HEIGHT_WITH_MARGIN);
|
|
||||||
|
|
||||||
}
|
|
||||||
return lines;
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
private static void drawStats(SpoutPlayer sp, List<GenericLabel> lines) {
|
|
||||||
for (GenericLabel l : lines) {
|
|
||||||
sp.getMainScreen().attachWidget(War.war, l.copy());
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
private void drawMessages(String playerName, List<GenericLabel> statsLines, List<Integer> statsOffset) {
|
|
||||||
Player bukkitPlayer = War.war.getServer().getPlayer(playerName);
|
|
||||||
if (bukkitPlayer != null) {
|
|
||||||
SpoutPlayer player = SpoutManager.getPlayer(bukkitPlayer);
|
|
||||||
List<PlayerMessage> messages = playerMessages.get(playerName);
|
|
||||||
|
|
||||||
// remove old widgets
|
|
||||||
clear(player);
|
|
||||||
|
|
||||||
// add bg
|
|
||||||
GenericGradient gradient = new GenericGradient();
|
|
||||||
gradient.setAnchor(WidgetAnchor.TOP_LEFT);
|
|
||||||
gradient.setTopColor(new Color(0.0F, 0.0F, 0.0F, 0.4F)); // (order is Red, Green, Blue, Alpha)
|
|
||||||
gradient.setBottomColor(new Color(0.0F, 0.0F, 0.0F, 0.0F));
|
|
||||||
gradient.setHeight(statsOffset.get(1) + 4).setWidth((int)(statsOffset.get(0)));
|
|
||||||
|
|
||||||
player.getMainScreen().attachWidget(War.war, gradient);
|
|
||||||
|
|
||||||
// border in color of team
|
|
||||||
GenericGradient teamGradient = new GenericGradient();
|
|
||||||
teamGradient.setAnchor(WidgetAnchor.TOP_LEFT);
|
|
||||||
|
|
||||||
Team team = Team.getTeamByPlayerName(playerName);
|
|
||||||
|
|
||||||
Color spoutColor = new Color(250.0F, 250.0F, 250.0F, 1.0F);
|
|
||||||
if (team != null) {
|
|
||||||
spoutColor = team.getKind().getSpoutColor();
|
|
||||||
}
|
|
||||||
spoutColor.setAlpha(0.5F);
|
|
||||||
|
|
||||||
teamGradient.setY(2 + LINE_HEIGHT_WITH_MARGIN);
|
|
||||||
teamGradient.setTopColor(spoutColor);
|
|
||||||
teamGradient.setBottomColor(new Color(256, 256, 256, 1.0F));
|
|
||||||
teamGradient.setHeight(2).setWidth((int)(statsOffset.get(0)));
|
|
||||||
|
|
||||||
player.getMainScreen().attachWidget(War.war, teamGradient);
|
|
||||||
|
|
||||||
// update stats panel
|
|
||||||
drawStats(player, statsLines);
|
|
||||||
|
|
||||||
// finally messages
|
|
||||||
if (messages != null && messages.size() > 0) {
|
|
||||||
Warzone zone = Warzone.getZoneByPlayerName(playerName);
|
|
||||||
int verticalOffset = statsOffset.get(1) + 4;
|
|
||||||
|
|
||||||
for (PlayerMessage message : messages) {
|
|
||||||
int horizontalOffset = 2;
|
|
||||||
|
|
||||||
String messageStr = ChatColor.GRAY + ">" + ChatColor.WHITE + " " + message.getMessage();
|
|
||||||
String[] words = messageStr.split(" ");
|
|
||||||
|
|
||||||
for (String word : words) {
|
|
||||||
|
|
||||||
if (horizontalOffset > 160) {
|
|
||||||
horizontalOffset = 2;
|
|
||||||
verticalOffset += LINE_HEIGHT_WITH_MARGIN;
|
|
||||||
}
|
|
||||||
|
|
||||||
word = addMissingColor(word, zone);
|
|
||||||
|
|
||||||
GenericLabel label = new GenericLabel(word);
|
|
||||||
int width = GenericLabel.getStringWidth(word);
|
|
||||||
label.setAnchor(WidgetAnchor.TOP_LEFT);
|
|
||||||
label.setWidth(width);
|
|
||||||
label.setHeight(LINE_HEIGHT);
|
|
||||||
label.setX(horizontalOffset);
|
|
||||||
label.setY(verticalOffset);
|
|
||||||
|
|
||||||
player.getMainScreen().attachWidget(War.war, label);
|
|
||||||
|
|
||||||
horizontalOffset += width + 2;
|
|
||||||
}
|
|
||||||
|
|
||||||
verticalOffset += LINE_HEIGHT_WITH_MARGIN + 1;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public static String addMissingColor(String word, Warzone zone) {
|
|
||||||
if (zone != null) {
|
|
||||||
for (Team team : zone.getTeams()) {
|
|
||||||
for (Player player : team.getPlayers()) {
|
|
||||||
if (word.startsWith(player.getName())) {
|
|
||||||
return team.getKind().getColor() + word + ChatColor.WHITE;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
for (TeamKind kind : TeamKind.values()) {
|
|
||||||
if (word.startsWith(kind.toString())) {
|
|
||||||
return kind.getColor() + word + ChatColor.WHITE;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (word.equals("War>")) {
|
|
||||||
return ChatColor.GRAY + word + ChatColor.WHITE;
|
|
||||||
}
|
|
||||||
|
|
||||||
// white by default
|
|
||||||
return word;
|
|
||||||
}
|
|
||||||
|
|
||||||
// private Color getWordColor(String word, Warzone zone) {
|
|
||||||
// if (zone != null) {
|
|
||||||
// for (Team team : zone.getTeams()) {
|
|
||||||
// for (Player player : team.getPlayers()) {
|
|
||||||
// if (word.startsWith(player.getName())) {
|
|
||||||
// return team.getKind().getSpoutColor();
|
|
||||||
// }
|
|
||||||
// }
|
|
||||||
// }
|
|
||||||
// }
|
|
||||||
//
|
|
||||||
// for (TeamKind kind : TeamKind.values()) {
|
|
||||||
// if (word.startsWith(kind.toString())) {
|
|
||||||
// return kind.getSpoutColor();
|
|
||||||
// }
|
|
||||||
// }
|
|
||||||
//
|
|
||||||
// if (word.equals("War>")) {
|
|
||||||
// return new Color(200,200,200);
|
|
||||||
// }
|
|
||||||
//
|
|
||||||
// // white by default
|
|
||||||
// return new Color(255,255,255);
|
|
||||||
// }
|
|
||||||
}
|
|
Loading…
Reference in New Issue
Block a user