First buildable version
Dieser Commit ist enthalten in:
Ursprung
1e731c11f0
Commit
3e75eeacfb
5
pom.xml
5
pom.xml
@ -55,5 +55,10 @@
|
|||||||
<artifactId>SpigotCore</artifactId>
|
<artifactId>SpigotCore</artifactId>
|
||||||
<version>2.0</version>
|
<version>2.0</version>
|
||||||
</dependency>
|
</dependency>
|
||||||
|
<dependency>
|
||||||
|
<groupId>steamwar</groupId>
|
||||||
|
<artifactId>WorldEdit</artifactId>
|
||||||
|
<version>1.15</version>
|
||||||
|
</dependency>
|
||||||
</dependencies>
|
</dependencies>
|
||||||
</project>
|
</project>
|
@ -1,4 +0,0 @@
|
|||||||
Rot ist im süden
|
|
||||||
SpawnEgg name == MissleName (Config)
|
|
||||||
incl Color-Tags, ect
|
|
||||||
Missle-Configs sind für Team Rot
|
|
14
src/ToDo.txt
14
src/ToDo.txt
@ -1,14 +0,0 @@
|
|||||||
Config:
|
|
||||||
Timeout-Time
|
|
||||||
Runden max length
|
|
||||||
shield / platform / ect item on/off
|
|
||||||
give-speed (default: 11)
|
|
||||||
Features
|
|
||||||
Items:
|
|
||||||
shield
|
|
||||||
platform
|
|
||||||
fireball
|
|
||||||
pfeile
|
|
||||||
bridge
|
|
||||||
Item-giver
|
|
||||||
am anfang bogen geben
|
|
@ -1,3 +1,23 @@
|
|||||||
portal:
|
WaitingTime: 600
|
||||||
red: -60
|
ItemTime: 300
|
||||||
blue: 60
|
ShieldFlyTime: 100
|
||||||
|
EndTime: 100
|
||||||
|
|
||||||
|
Arena:
|
||||||
|
MinX: 0
|
||||||
|
MaxX: 0
|
||||||
|
MinY: 0
|
||||||
|
MinZ: 0
|
||||||
|
MaxZ: 0
|
||||||
|
|
||||||
|
Red:
|
||||||
|
PortalZ: -60
|
||||||
|
SpawnX: 0
|
||||||
|
SpawnY: 0
|
||||||
|
SpawnZ: 0
|
||||||
|
|
||||||
|
Blue:
|
||||||
|
PortalZ: 60
|
||||||
|
SpawnX: 0
|
||||||
|
SpawnY: 0
|
||||||
|
SpawnZ: 0
|
||||||
|
61
src/de/steamwar/misslewars/Config.java
Normale Datei
61
src/de/steamwar/misslewars/Config.java
Normale Datei
@ -0,0 +1,61 @@
|
|||||||
|
package de.steamwar.misslewars;
|
||||||
|
|
||||||
|
import org.bukkit.Bukkit;
|
||||||
|
import org.bukkit.Location;
|
||||||
|
import org.bukkit.configuration.ConfigurationSection;
|
||||||
|
import org.bukkit.configuration.file.FileConfiguration;
|
||||||
|
|
||||||
|
import java.io.File;
|
||||||
|
import java.util.logging.Level;
|
||||||
|
|
||||||
|
public class Config {
|
||||||
|
private Config(){}
|
||||||
|
|
||||||
|
public static final int ArenaMinX;
|
||||||
|
public static final int ArenaMaxX;
|
||||||
|
public static final int ArenaMinY;
|
||||||
|
public static final int ArenaMinZ;
|
||||||
|
public static final int ArenaMaxZ;
|
||||||
|
|
||||||
|
public static final Location RedSpawn;
|
||||||
|
public static final int RedPortalZ;
|
||||||
|
public static final Location BlueSpawn;
|
||||||
|
public static final int BluePortalZ;
|
||||||
|
|
||||||
|
public static final int WaitingTime;
|
||||||
|
public static final int ItemTime;
|
||||||
|
public static final int ShieldFlyTime;
|
||||||
|
public static final int EndTime;
|
||||||
|
|
||||||
|
static{
|
||||||
|
if(!new File(MissileWars.getPlugin().getDataFolder(), "config.yml").exists()){
|
||||||
|
MissileWars.getPlugin().saveDefaultConfig();
|
||||||
|
Bukkit.getLogger().log(Level.SEVERE, "Config fehlt!");
|
||||||
|
Bukkit.shutdown();
|
||||||
|
}
|
||||||
|
|
||||||
|
FileConfiguration config = MissileWars.getPlugin().getConfig();
|
||||||
|
WaitingTime = config.getInt("WaitingTime");
|
||||||
|
ItemTime = config.getInt("ItemTime");
|
||||||
|
ShieldFlyTime = config.getInt("ShieldFlyTime");
|
||||||
|
EndTime = config.getInt("EndTime");
|
||||||
|
|
||||||
|
ConfigurationSection arena = config.getConfigurationSection("Arena");
|
||||||
|
assert arena != null;
|
||||||
|
ArenaMinX = arena.getInt("MinX");
|
||||||
|
ArenaMaxX = arena.getInt("MaxX");
|
||||||
|
ArenaMinY = arena.getInt("MinY");
|
||||||
|
ArenaMinZ = arena.getInt("MinZ");
|
||||||
|
ArenaMaxZ = arena.getInt("MaxZ");
|
||||||
|
|
||||||
|
ConfigurationSection red = config.getConfigurationSection("Red");
|
||||||
|
assert red != null;
|
||||||
|
RedPortalZ = red.getInt("PortalZ");
|
||||||
|
RedSpawn = new Location(Bukkit.getWorlds().get(0), red.getDouble("SpawnX"), red.getDouble("SpawnY"), red.getDouble("SpawnZ"));
|
||||||
|
|
||||||
|
ConfigurationSection blue = config.getConfigurationSection("Blue");
|
||||||
|
assert blue != null;
|
||||||
|
BluePortalZ = blue.getInt("PortalZ");
|
||||||
|
BlueSpawn = new Location(Bukkit.getWorlds().get(0), blue.getDouble("SpawnX"), blue.getDouble("SpawnY"), blue.getDouble("SpawnZ"));
|
||||||
|
}
|
||||||
|
}
|
@ -20,7 +20,6 @@ public class FightScoreboard {
|
|||||||
|
|
||||||
static{
|
static{
|
||||||
if(scoreboard.getObjective("AAA") == null)
|
if(scoreboard.getObjective("AAA") == null)
|
||||||
//noinspection deprecation
|
|
||||||
objective = scoreboard.registerNewObjective("AAA", "BBB", "MissleWars");
|
objective = scoreboard.registerNewObjective("AAA", "BBB", "MissleWars");
|
||||||
else
|
else
|
||||||
objective = scoreboard.getObjective("AAA");
|
objective = scoreboard.getObjective("AAA");
|
||||||
@ -29,7 +28,6 @@ public class FightScoreboard {
|
|||||||
public static void init(){
|
public static void init(){
|
||||||
Bukkit.getScheduler().scheduleSyncRepeatingTask(MissileWars.getPlugin(), () -> {
|
Bukkit.getScheduler().scheduleSyncRepeatingTask(MissileWars.getPlugin(), () -> {
|
||||||
objective.unregister();
|
objective.unregister();
|
||||||
//noinspection deprecation
|
|
||||||
scoreboard.registerNewObjective("AAA", "BBB", "MissleWars");
|
scoreboard.registerNewObjective("AAA", "BBB", "MissleWars");
|
||||||
objective.setDisplaySlot(DisplaySlot.SIDEBAR);
|
objective.setDisplaySlot(DisplaySlot.SIDEBAR);
|
||||||
|
|
||||||
|
@ -6,6 +6,7 @@ import org.bukkit.Material;
|
|||||||
import org.bukkit.enchantments.Enchantment;
|
import org.bukkit.enchantments.Enchantment;
|
||||||
import org.bukkit.entity.Player;
|
import org.bukkit.entity.Player;
|
||||||
import org.bukkit.inventory.ItemStack;
|
import org.bukkit.inventory.ItemStack;
|
||||||
|
import org.bukkit.inventory.meta.ItemMeta;
|
||||||
import org.bukkit.scoreboard.Team;
|
import org.bukkit.scoreboard.Team;
|
||||||
|
|
||||||
import java.util.HashSet;
|
import java.util.HashSet;
|
||||||
@ -16,7 +17,10 @@ public class MWTeam {
|
|||||||
private static final ItemStack bow = new ItemStack(Material.BOW);
|
private static final ItemStack bow = new ItemStack(Material.BOW);
|
||||||
|
|
||||||
static {
|
static {
|
||||||
Objects.requireNonNull(bow.getItemMeta()).addEnchant(Enchantment.ARROW_FIRE, 1, false);
|
ItemMeta bowMeta = Objects.requireNonNull(bow.getItemMeta());
|
||||||
|
bowMeta.addEnchant(Enchantment.ARROW_FIRE, 1, false);
|
||||||
|
bowMeta.setUnbreakable(true);
|
||||||
|
bow.setItemMeta(bowMeta);
|
||||||
}
|
}
|
||||||
|
|
||||||
private final ChatColor color;
|
private final ChatColor color;
|
||||||
@ -31,7 +35,7 @@ public class MWTeam {
|
|||||||
return players;
|
return players;
|
||||||
}
|
}
|
||||||
|
|
||||||
public MWTeam(ChatColor color, Location spawn, String teamName, int portalZ) {
|
MWTeam(ChatColor color, Location spawn, String teamName, int portalZ) {
|
||||||
this.teamName = teamName;
|
this.teamName = teamName;
|
||||||
this.color = color;
|
this.color = color;
|
||||||
this.spawn = spawn;
|
this.spawn = spawn;
|
||||||
@ -56,7 +60,7 @@ public class MWTeam {
|
|||||||
public void join (Player p) {
|
public void join (Player p) {
|
||||||
players.add(p);
|
players.add(p);
|
||||||
p.teleport(spawn);
|
p.teleport(spawn);
|
||||||
p.setItemOnCursor(bow);
|
p.getInventory().setItem(0, bow);
|
||||||
sbteam.addPlayer(p);
|
sbteam.addPlayer(p);
|
||||||
p.setDisplayName(color + teamName + " " + p.getName());
|
p.setDisplayName(color + teamName + " " + p.getName());
|
||||||
if (MissileWars.getFightState() == FightState.WAITING && !enemy().getPlayers().isEmpty())
|
if (MissileWars.getFightState() == FightState.WAITING && !enemy().getPlayers().isEmpty())
|
||||||
@ -69,11 +73,11 @@ public class MWTeam {
|
|||||||
|
|
||||||
players.remove(p);
|
players.remove(p);
|
||||||
sbteam.removePlayer(p);
|
sbteam.removePlayer(p);
|
||||||
if (players.isEmpty())
|
if (players.isEmpty() && MissileWars.getFightState() == FightState.FIGHTING)
|
||||||
MissileWars.end(WinReasons.NO_ENEMY, enemy());
|
MissileWars.end(WinReasons.NO_ENEMY, enemy());
|
||||||
}
|
}
|
||||||
|
|
||||||
public MWTeam enemy() {
|
private MWTeam enemy() {
|
||||||
if (this == MissileWars.getRedTeam())
|
if (this == MissileWars.getRedTeam())
|
||||||
return MissileWars.getBlueTeam();
|
return MissileWars.getBlueTeam();
|
||||||
|
|
||||||
|
@ -1,16 +1,19 @@
|
|||||||
package de.steamwar.misslewars;
|
package de.steamwar.misslewars;
|
||||||
|
|
||||||
|
import de.steamwar.misslewars.countdowns.EndCountdown;
|
||||||
|
import de.steamwar.misslewars.countdowns.ItemCountdown;
|
||||||
|
import de.steamwar.misslewars.countdowns.WaitingCountdown;
|
||||||
|
import de.steamwar.misslewars.items.Arrows;
|
||||||
|
import de.steamwar.misslewars.items.Fireball;
|
||||||
|
import de.steamwar.misslewars.items.Missile;
|
||||||
|
import de.steamwar.misslewars.items.Snowball;
|
||||||
import de.steamwar.misslewars.listener.*;
|
import de.steamwar.misslewars.listener.*;
|
||||||
import org.bukkit.Bukkit;
|
import org.bukkit.Bukkit;
|
||||||
import org.bukkit.ChatColor;
|
import org.bukkit.ChatColor;
|
||||||
import org.bukkit.Location;
|
|
||||||
import org.bukkit.entity.Player;
|
import org.bukkit.entity.Player;
|
||||||
import org.bukkit.plugin.java.JavaPlugin;
|
import org.bukkit.plugin.java.JavaPlugin;
|
||||||
import org.bukkit.scheduler.BukkitRunnable;
|
|
||||||
|
|
||||||
public class MissileWars extends JavaPlugin {
|
public class MissileWars extends JavaPlugin {
|
||||||
private static final int END_PHASE_TIME = 600; //gameticks (30s)
|
|
||||||
|
|
||||||
private static MissileWars plugin;
|
private static MissileWars plugin;
|
||||||
private static MWTeam redTeam; //red has South side -> spawns missles towards north
|
private static MWTeam redTeam; //red has South side -> spawns missles towards north
|
||||||
private static MWTeam blueTeam;
|
private static MWTeam blueTeam;
|
||||||
@ -26,34 +29,44 @@ public class MissileWars extends JavaPlugin {
|
|||||||
fightState = FightState.WAITING;
|
fightState = FightState.WAITING;
|
||||||
startTime = System.currentTimeMillis();
|
startTime = System.currentTimeMillis();
|
||||||
|
|
||||||
//TODO: Config
|
redTeam = new MWTeam(ChatColor.RED, Config.RedSpawn, "Rot", Config.RedPortalZ);
|
||||||
redTeam = new MWTeam(ChatColor.RED, new Location(Bukkit.getWorlds().get(0), 0, 0, 0), "Rot", -63);
|
blueTeam = new MWTeam(ChatColor.BLUE, Config.BlueSpawn, "Blau", Config.BluePortalZ);
|
||||||
blueTeam = new MWTeam(ChatColor.BLUE, new Location(Bukkit.getWorlds().get(0), 0, 0, 0), "Blau", 63);
|
|
||||||
MissleSpawnSystem.load();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void onEnable() {
|
public void onEnable() {
|
||||||
new DeathListener();
|
new DeathListener();
|
||||||
new EggClickListener();
|
new ItemListener();
|
||||||
new ArenaListener(arenaMinX, arenaMaxX, arenaMinZ, arenaMaxZ, arenaMinY);
|
new ArenaListener();
|
||||||
new ConnectionListener();
|
new ConnectionListener();
|
||||||
new JoinListener();
|
new JoinListener();
|
||||||
new EndListener();
|
new EndListener();
|
||||||
new PortalDestructListener();
|
new PortalDestructListener();
|
||||||
|
new WaitingListener();
|
||||||
|
new FightListener();
|
||||||
|
|
||||||
//TODO: Wait for players/Auto termination
|
new WaitingCountdown();
|
||||||
BasicListener.setupListeners(fightState);
|
new ItemCountdown();
|
||||||
|
new EndCountdown();
|
||||||
|
|
||||||
|
FightScoreboard.init();
|
||||||
|
|
||||||
|
Missile.init();
|
||||||
|
new Arrows();
|
||||||
|
new Fireball();
|
||||||
|
new Snowball();
|
||||||
|
|
||||||
|
StateDependent.setupState(fightState);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* call to change fightstate from WAITING to INGAME
|
* call to change fightstate from WAITING to INGAME
|
||||||
*/
|
*/
|
||||||
public static void startRound() {
|
static void startRound() {
|
||||||
if (fightState != FightState.WAITING) // anti dual-call
|
if (fightState != FightState.WAITING) // anti dual-call
|
||||||
return;
|
return;
|
||||||
fightState = FightState.FIGHTING;
|
fightState = FightState.FIGHTING;
|
||||||
BasicListener.setupListeners(fightState);
|
StateDependent.setupState(fightState);
|
||||||
|
|
||||||
startTime = System.currentTimeMillis();
|
startTime = System.currentTimeMillis();
|
||||||
}
|
}
|
||||||
@ -67,25 +80,19 @@ public class MissileWars extends JavaPlugin {
|
|||||||
if (fightState == FightState.END) //verhindern dass es mehrfach gecallt wird
|
if (fightState == FightState.END) //verhindern dass es mehrfach gecallt wird
|
||||||
return;
|
return;
|
||||||
fightState = FightState.END;
|
fightState = FightState.END;
|
||||||
BasicListener.setupListeners(fightState);
|
StateDependent.setupState(fightState);
|
||||||
|
|
||||||
switch (reason) {
|
switch (reason) {
|
||||||
|
case PORTAL_DESTROYED:
|
||||||
|
Bukkit.getServer().broadcastMessage(winner.getColoredName() + ChatColor.RESET + " hat das gegnerische Portal zerstört.");
|
||||||
|
break;
|
||||||
case NO_ENEMY:
|
case NO_ENEMY:
|
||||||
|
default:
|
||||||
Bukkit.getServer().broadcastMessage("Ohne Gegner kein Kampf - Team " + winner.getColoredName() + ChatColor.RESET + " hat gewonnen.");
|
Bukkit.getServer().broadcastMessage("Ohne Gegner kein Kampf - Team " + winner.getColoredName() + ChatColor.RESET + " hat gewonnen.");
|
||||||
break;
|
break;
|
||||||
case PORTAL_DESTROYED:
|
|
||||||
Bukkit.getServer().broadcastMessage(winner.getColoredName() + ChatColor.RESET + " hat das gegnerische Portal zerst<73>rt.");
|
|
||||||
break;
|
|
||||||
}
|
}
|
||||||
new BukkitRunnable() {
|
|
||||||
public void run() {
|
|
||||||
Bukkit.getServer().shutdown();
|
|
||||||
}
|
|
||||||
}.runTaskLater(plugin, END_PHASE_TIME);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
public static MissileWars getPlugin() {
|
public static MissileWars getPlugin() {
|
||||||
return plugin;
|
return plugin;
|
||||||
}
|
}
|
||||||
@ -103,9 +110,9 @@ public class MissileWars extends JavaPlugin {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public static MWTeam getTeam(Player p){
|
public static MWTeam getTeam(Player p){
|
||||||
if(blueTeam.getPlayers().contains(p))
|
if(blueTeam.hasPlayer(p))
|
||||||
return blueTeam;
|
return blueTeam;
|
||||||
if(redTeam.getPlayers().contains(p))
|
if(redTeam.hasPlayer(p))
|
||||||
return redTeam;
|
return redTeam;
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
@ -1,143 +0,0 @@
|
|||||||
package de.steamwar.misslewars;
|
|
||||||
|
|
||||||
import org.bukkit.Bukkit;
|
|
||||||
import org.bukkit.Location;
|
|
||||||
import org.bukkit.Material;
|
|
||||||
import org.bukkit.block.Block;
|
|
||||||
import org.bukkit.block.BlockFace;
|
|
||||||
import org.bukkit.block.data.type.Observer;
|
|
||||||
import org.bukkit.block.data.type.Piston;
|
|
||||||
import org.bukkit.configuration.file.FileConfiguration;
|
|
||||||
import org.bukkit.configuration.file.YamlConfiguration;
|
|
||||||
|
|
||||||
import java.io.File;
|
|
||||||
import java.util.ArrayList;
|
|
||||||
|
|
||||||
public class MissleSpawnSystem {
|
|
||||||
|
|
||||||
public static Missile[] missiles;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* load Config, ect
|
|
||||||
*/
|
|
||||||
@SuppressWarnings("unchecked")
|
|
||||||
public static void load() {
|
|
||||||
FileConfiguration c = YamlConfiguration.loadConfiguration(new File(MissileWars.getPlugin().getDataFolder(), "missles.yml"));
|
|
||||||
missiles = (c.getList("missles", new ArrayList<Missile>())).toArray();
|
|
||||||
}
|
|
||||||
|
|
||||||
public static void paste(String missle, boolean red, Location l) {
|
|
||||||
for (Missile m : missiles) {
|
|
||||||
if (m.name == missle)
|
|
||||||
m.paste(l, red, red);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Missle-Schematic
|
|
||||||
*/
|
|
||||||
@SuppressWarnings("unused")
|
|
||||||
private class Missile {
|
|
||||||
public String name;
|
|
||||||
private byte height;
|
|
||||||
private byte depth;
|
|
||||||
private byte width;
|
|
||||||
private MissleBlockTypes[] blocks;
|
|
||||||
|
|
||||||
/**
|
|
||||||
*
|
|
||||||
* @param l Location of the spawning player
|
|
||||||
* @param redTeam for Block-color blue / red
|
|
||||||
* @param north facing north or south?
|
|
||||||
*/
|
|
||||||
public void paste(Location l, boolean redTeam, boolean north) {
|
|
||||||
byte a = 1;
|
|
||||||
if (!north) a = -1;
|
|
||||||
for (int x=0; x < width; x++) {
|
|
||||||
for (int y=height; y > 0; y--) {
|
|
||||||
for (int z=0; z < width; z++) {
|
|
||||||
int i = x+y*width+z*height*width;
|
|
||||||
if (i > blocks.length || i < 0) continue;
|
|
||||||
setBlock(blocks[i], Bukkit.getWorlds().get(0).getBlockAt(l.getBlockX() + x, l.getBlockY() + y, l.getBlockZ() + z * a), north, redTeam);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
//bewusst mit blockupdate, damit observer, ect beim pasten triggern
|
|
||||||
private void setBlock(MissleBlockTypes t, Block b, boolean n, boolean red) {
|
|
||||||
if (t == MissleBlockTypes.GLASS) {
|
|
||||||
if (red)
|
|
||||||
b.setType(Material.RED_STAINED_GLASS);
|
|
||||||
else
|
|
||||||
b.setType(Material.BLUE_STAINED_GLASS);
|
|
||||||
}else if (t == MissleBlockTypes.BLOCK) {
|
|
||||||
if (red)
|
|
||||||
b.setType(Material.RED_CONCRETE);
|
|
||||||
else
|
|
||||||
b.setType(Material.BLUE_CONCRETE);
|
|
||||||
}else if (t == MissleBlockTypes.HONEY_BLOCK) {
|
|
||||||
b.setType(Material.HONEY_BLOCK);
|
|
||||||
}else if (t == MissleBlockTypes.PANE) {
|
|
||||||
if (red)
|
|
||||||
b.setType(Material.RED_STAINED_GLASS_PANE);
|
|
||||||
else
|
|
||||||
b.setType(Material.BLUE_STAINED_GLASS_PANE);
|
|
||||||
}else if (t == MissleBlockTypes.TNT) {
|
|
||||||
b.setType(Material.TNT);
|
|
||||||
}else if (t == MissleBlockTypes.SLIME_BLOCK) {
|
|
||||||
b.setType(Material.SLIME_BLOCK);
|
|
||||||
}else if (t.toString().contains("STICKY_PISTON")) {
|
|
||||||
b.setType(Material.STICKY_PISTON);
|
|
||||||
((Piston) b).setFacing(getFacing(t, n));
|
|
||||||
}else if (t.toString().contains("PISTON")) {
|
|
||||||
b.setType(Material.PISTON);
|
|
||||||
((Piston) b).setFacing(getFacing(t, n));
|
|
||||||
}else if (t.toString().contains("OBSERVER")) {
|
|
||||||
b.setType(Material.OBSERVER);
|
|
||||||
((Observer) b).setFacing(getFacing(t, n));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public BlockFace getFacing(MissleBlockTypes t, boolean north) {
|
|
||||||
String s = t.toString();
|
|
||||||
if (s.contains("UP")) return BlockFace.UP;
|
|
||||||
if (s.contains("DOWN")) return BlockFace.DOWN;
|
|
||||||
if ((s.contains("NORTH") && north) || (s.contains("SOUTH") && !north)) return BlockFace.NORTH;
|
|
||||||
if ((s.contains("NORTH") && !north) || (s.contains("SOUTH") && north)) return BlockFace.SOUTH;
|
|
||||||
if ((s.contains("WEST") && north) || (s.contains("EAST") && !north)) return BlockFace.WEST;
|
|
||||||
return BlockFace.EAST;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* For Config & lowRAM save of missles
|
|
||||||
*/
|
|
||||||
private enum MissleBlockTypes {
|
|
||||||
PISTON_UP,
|
|
||||||
PISTON_DOWN,
|
|
||||||
PISTON_NORTH,
|
|
||||||
PISTON_SOUTH,
|
|
||||||
PISTON_EAST,
|
|
||||||
PISTON_WEST,
|
|
||||||
STICKY_PISTON_UP,
|
|
||||||
STICKY_PISTON_DOWN,
|
|
||||||
STICKY_PISTON_NORTH,
|
|
||||||
STICKY_PISTON_SOUTH,
|
|
||||||
STICKY_PISTON_WEST,
|
|
||||||
STICKY_PISTON_EAST,
|
|
||||||
GLASS, //teamcolored
|
|
||||||
BLOCK, //normal block, teamcolored
|
|
||||||
PANE, //teamcolored (glass-pane)
|
|
||||||
REDSTONE_BLOCK,
|
|
||||||
OBSERVER_UP,
|
|
||||||
OBSERVER_DOWN,
|
|
||||||
OBSERVER_NORTH,
|
|
||||||
OBSERVER_SOUTH,
|
|
||||||
OBSERVER_EAST,
|
|
||||||
OBSERVER_WEST,
|
|
||||||
SLIME_BLOCK,
|
|
||||||
HONEY_BLOCK,
|
|
||||||
TNT
|
|
||||||
}
|
|
||||||
}
|
|
32
src/de/steamwar/misslewars/StateDependent.java
Normale Datei
32
src/de/steamwar/misslewars/StateDependent.java
Normale Datei
@ -0,0 +1,32 @@
|
|||||||
|
package de.steamwar.misslewars;
|
||||||
|
|
||||||
|
import java.util.HashSet;
|
||||||
|
import java.util.Set;
|
||||||
|
|
||||||
|
public abstract class StateDependent {
|
||||||
|
private static Set<StateDependent> listeners = new HashSet<>();
|
||||||
|
|
||||||
|
private final Set<FightState> active;
|
||||||
|
private boolean running;
|
||||||
|
|
||||||
|
public StateDependent(final Set<FightState> active){
|
||||||
|
this.active = active;
|
||||||
|
running = false;
|
||||||
|
listeners.add(this);
|
||||||
|
}
|
||||||
|
|
||||||
|
public abstract void enable();
|
||||||
|
public abstract void disable();
|
||||||
|
|
||||||
|
static void setupState(FightState state){
|
||||||
|
for(StateDependent listener : listeners){
|
||||||
|
if(listener.running && !listener.active.contains(state)){
|
||||||
|
listener.enable();
|
||||||
|
listener.running = false;
|
||||||
|
}else if(!listener.running && listener.active.contains(state)){
|
||||||
|
listener.disable();
|
||||||
|
listener.running = true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
35
src/de/steamwar/misslewars/countdowns/EndCountdown.java
Normale Datei
35
src/de/steamwar/misslewars/countdowns/EndCountdown.java
Normale Datei
@ -0,0 +1,35 @@
|
|||||||
|
package de.steamwar.misslewars.countdowns;
|
||||||
|
|
||||||
|
import de.steamwar.misslewars.Config;
|
||||||
|
import de.steamwar.misslewars.FightState;
|
||||||
|
import de.steamwar.misslewars.MissileWars;
|
||||||
|
import de.steamwar.misslewars.StateDependent;
|
||||||
|
import org.bukkit.Bukkit;
|
||||||
|
import org.bukkit.entity.Player;
|
||||||
|
import org.bukkit.scheduler.BukkitTask;
|
||||||
|
|
||||||
|
import java.util.EnumSet;
|
||||||
|
|
||||||
|
public class EndCountdown extends StateDependent {
|
||||||
|
|
||||||
|
private BukkitTask task;
|
||||||
|
|
||||||
|
public EndCountdown() {
|
||||||
|
super(EnumSet.of(FightState.END));
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void enable() {
|
||||||
|
task = Bukkit.getScheduler().runTaskLater(MissileWars.getPlugin(), () -> {
|
||||||
|
for(Player p : Bukkit.getOnlinePlayers()){
|
||||||
|
p.kickPlayer(null);
|
||||||
|
}
|
||||||
|
}, Config.EndTime);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void disable() {
|
||||||
|
if(!task.isCancelled())
|
||||||
|
task.cancel();
|
||||||
|
}
|
||||||
|
}
|
66
src/de/steamwar/misslewars/countdowns/ItemCountdown.java
Normale Datei
66
src/de/steamwar/misslewars/countdowns/ItemCountdown.java
Normale Datei
@ -0,0 +1,66 @@
|
|||||||
|
package de.steamwar.misslewars.countdowns;
|
||||||
|
|
||||||
|
import de.steamwar.misslewars.*;
|
||||||
|
import de.steamwar.misslewars.items.SpecialItem;
|
||||||
|
import org.bukkit.Bukkit;
|
||||||
|
import org.bukkit.Material;
|
||||||
|
import org.bukkit.entity.Player;
|
||||||
|
import org.bukkit.inventory.Inventory;
|
||||||
|
import org.bukkit.inventory.ItemStack;
|
||||||
|
import org.bukkit.scheduler.BukkitTask;
|
||||||
|
|
||||||
|
import java.util.EnumSet;
|
||||||
|
|
||||||
|
public class ItemCountdown extends StateDependent {
|
||||||
|
|
||||||
|
private BukkitTask task;
|
||||||
|
|
||||||
|
public ItemCountdown() {
|
||||||
|
super(EnumSet.of(FightState.FIGHTING));
|
||||||
|
}
|
||||||
|
|
||||||
|
private void run(){
|
||||||
|
ItemStack item = SpecialItem.getRandomItem();
|
||||||
|
giveTeamItem(MissileWars.getBlueTeam(), item);
|
||||||
|
giveTeamItem(MissileWars.getRedTeam(), item);
|
||||||
|
}
|
||||||
|
|
||||||
|
private void giveTeamItem(MWTeam team, ItemStack item){
|
||||||
|
for(Player p : team.getPlayers()){
|
||||||
|
givePlayerItem(p, item);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private void givePlayerItem(Player p, ItemStack item){
|
||||||
|
Inventory inventory = p.getInventory();
|
||||||
|
for (int i = 0; i <= 35; i++) { //35 is the last normal inventory slot
|
||||||
|
ItemStack itemStack = inventory.getItem(i);
|
||||||
|
if (itemStack != null && itemStack.isSimilar(item) && itemStack.getAmount() != itemStack.getMaxStackSize()) {
|
||||||
|
itemStack.setAmount(itemStack.getAmount() + item.getAmount());
|
||||||
|
inventory.setItem(i, itemStack);
|
||||||
|
p.updateInventory();
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
for (int i = 0; i <= 35; i++) { //35 is the last normal inventory slot
|
||||||
|
ItemStack itemStack = inventory.getItem(i);
|
||||||
|
if (itemStack == null || itemStack.getType().equals(Material.AIR)) {
|
||||||
|
inventory.setItem(i, item);
|
||||||
|
p.updateInventory();
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void enable() {
|
||||||
|
task = Bukkit.getScheduler().runTaskTimer(MissileWars.getPlugin(), this::run, Config.ItemTime, 0);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void disable() {
|
||||||
|
if(!task.isCancelled())
|
||||||
|
task.cancel();
|
||||||
|
}
|
||||||
|
}
|
33
src/de/steamwar/misslewars/countdowns/WaitingCountdown.java
Normale Datei
33
src/de/steamwar/misslewars/countdowns/WaitingCountdown.java
Normale Datei
@ -0,0 +1,33 @@
|
|||||||
|
package de.steamwar.misslewars.countdowns;
|
||||||
|
|
||||||
|
import de.steamwar.misslewars.Config;
|
||||||
|
import de.steamwar.misslewars.FightState;
|
||||||
|
import de.steamwar.misslewars.MissileWars;
|
||||||
|
import de.steamwar.misslewars.StateDependent;
|
||||||
|
import org.bukkit.Bukkit;
|
||||||
|
import org.bukkit.scheduler.BukkitTask;
|
||||||
|
|
||||||
|
import java.util.EnumSet;
|
||||||
|
|
||||||
|
public class WaitingCountdown extends StateDependent {
|
||||||
|
|
||||||
|
private BukkitTask task;
|
||||||
|
|
||||||
|
public WaitingCountdown() {
|
||||||
|
super(EnumSet.of(FightState.WAITING));
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void enable() {
|
||||||
|
task = Bukkit.getScheduler().runTaskLater(MissileWars.getPlugin(), () -> {
|
||||||
|
if(Bukkit.getOnlinePlayers().isEmpty())
|
||||||
|
Bukkit.shutdown();
|
||||||
|
}, Config.WaitingTime);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void disable() {
|
||||||
|
if(!task.isCancelled())
|
||||||
|
task.cancel();
|
||||||
|
}
|
||||||
|
}
|
20
src/de/steamwar/misslewars/items/Arrows.java
Normale Datei
20
src/de/steamwar/misslewars/items/Arrows.java
Normale Datei
@ -0,0 +1,20 @@
|
|||||||
|
package de.steamwar.misslewars.items;
|
||||||
|
|
||||||
|
import org.bukkit.Material;
|
||||||
|
import org.bukkit.entity.Player;
|
||||||
|
import org.bukkit.inventory.ItemStack;
|
||||||
|
|
||||||
|
public class Arrows extends SpecialItem {
|
||||||
|
|
||||||
|
private final ItemStack item = new ItemStack(Material.ARROW, 3);
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public ItemStack getItem() {
|
||||||
|
return item;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean handleUse(Player p) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
22
src/de/steamwar/misslewars/items/Fireball.java
Normale Datei
22
src/de/steamwar/misslewars/items/Fireball.java
Normale Datei
@ -0,0 +1,22 @@
|
|||||||
|
package de.steamwar.misslewars.items;
|
||||||
|
|
||||||
|
import org.bukkit.Material;
|
||||||
|
import org.bukkit.entity.Player;
|
||||||
|
import org.bukkit.inventory.ItemStack;
|
||||||
|
|
||||||
|
public class Fireball extends SpecialItem {
|
||||||
|
|
||||||
|
private final ItemStack item = new ItemStack(Material.FIRE_CHARGE, 1);
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public ItemStack getItem() {
|
||||||
|
return item;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean handleUse(Player p) {
|
||||||
|
org.bukkit.entity.Fireball fb = p.launchProjectile(org.bukkit.entity.Fireball.class);
|
||||||
|
fb.setIsIncendiary(true);
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
}
|
97
src/de/steamwar/misslewars/items/Missile.java
Normale Datei
97
src/de/steamwar/misslewars/items/Missile.java
Normale Datei
@ -0,0 +1,97 @@
|
|||||||
|
package de.steamwar.misslewars.items;
|
||||||
|
|
||||||
|
import com.sk89q.worldedit.EditSession;
|
||||||
|
import com.sk89q.worldedit.WorldEdit;
|
||||||
|
import com.sk89q.worldedit.bukkit.BukkitWorld;
|
||||||
|
import com.sk89q.worldedit.extent.clipboard.Clipboard;
|
||||||
|
import com.sk89q.worldedit.extent.clipboard.io.ClipboardFormat;
|
||||||
|
import com.sk89q.worldedit.extent.clipboard.io.ClipboardFormats;
|
||||||
|
import com.sk89q.worldedit.function.operation.Operations;
|
||||||
|
import com.sk89q.worldedit.math.BlockVector3;
|
||||||
|
import com.sk89q.worldedit.math.transform.AffineTransform;
|
||||||
|
import com.sk89q.worldedit.session.ClipboardHolder;
|
||||||
|
import com.sk89q.worldedit.world.World;
|
||||||
|
import de.steamwar.misslewars.MissileWars;
|
||||||
|
import org.bukkit.Bukkit;
|
||||||
|
import org.bukkit.Location;
|
||||||
|
import org.bukkit.Material;
|
||||||
|
import org.bukkit.entity.Player;
|
||||||
|
import org.bukkit.inventory.ItemStack;
|
||||||
|
import org.bukkit.inventory.meta.ItemMeta;
|
||||||
|
|
||||||
|
import java.io.File;
|
||||||
|
import java.io.FileInputStream;
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.util.Objects;
|
||||||
|
|
||||||
|
public class Missile extends SpecialItem {
|
||||||
|
|
||||||
|
private static final World world = new BukkitWorld(Bukkit.getWorlds().get(0));
|
||||||
|
|
||||||
|
private final Clipboard clipboard;
|
||||||
|
private final ItemStack item;
|
||||||
|
|
||||||
|
private Missile(File missileFile){
|
||||||
|
String name = missileFile.getName().split(".")[0];
|
||||||
|
Material itemType = Material.valueOf(missileFile.getName().split(".")[1]);
|
||||||
|
|
||||||
|
ClipboardFormat format = ClipboardFormats.findByFile(missileFile);
|
||||||
|
|
||||||
|
try {
|
||||||
|
assert format != null;
|
||||||
|
clipboard = format.getReader(new FileInputStream(missileFile)).read();
|
||||||
|
} catch (IOException e) {
|
||||||
|
throw new SecurityException("Corrupt missile");
|
||||||
|
}
|
||||||
|
|
||||||
|
item = new ItemStack(itemType, 1);
|
||||||
|
ItemMeta meta = item.getItemMeta();
|
||||||
|
assert meta != null;
|
||||||
|
meta.setDisplayName(name);
|
||||||
|
item.setItemMeta(meta);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public ItemStack getItem(){
|
||||||
|
return item;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean handleUse(Player p){
|
||||||
|
BlockVector3 dimensions = clipboard.getDimensions();
|
||||||
|
Location location = p.getLocation();
|
||||||
|
BlockVector3 v = BlockVector3.at(location.getBlockX(), location.getBlockY(), location.getBlockZ());
|
||||||
|
BlockVector3 offset = clipboard.getRegion().getMinimumPoint().subtract(clipboard.getOrigin());
|
||||||
|
AffineTransform aT = new AffineTransform();
|
||||||
|
|
||||||
|
double yaw = p.getLocation().getYaw();
|
||||||
|
if(yaw > 45 && yaw <= 135)
|
||||||
|
aT = aT.rotateY(90);
|
||||||
|
else if(yaw > 135 && yaw <= 225)
|
||||||
|
aT = aT.rotateY(180);
|
||||||
|
else if(yaw > 225 && yaw <= 315)
|
||||||
|
aT = aT.rotateY(270);
|
||||||
|
|
||||||
|
v = v.subtract(dimensions.getX()/2, dimensions.getY(), dimensions.getZ()/2 - dimensions.getZ()%2).subtract(offset);
|
||||||
|
|
||||||
|
EditSession e = WorldEdit.getInstance().getEditSessionFactory().getEditSession(world, -1);
|
||||||
|
ClipboardHolder ch = new ClipboardHolder(clipboard);
|
||||||
|
ch.setTransform(aT);
|
||||||
|
Operations.completeBlindly(ch.createPaste(e).to(v).build());
|
||||||
|
e.flushSession();
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void init(){
|
||||||
|
File missileFolder = new File(MissileWars.getPlugin().getDataFolder(), "missiles");
|
||||||
|
if(!missileFolder.exists() || !missileFolder.canRead() || !missileFolder.isDirectory()){
|
||||||
|
throw new SecurityException("Missiles could not be loaded");
|
||||||
|
}
|
||||||
|
for(File missileFile : Objects.requireNonNull(missileFolder.listFiles())){
|
||||||
|
if(!missileFile.canRead() || !missileFile.isFile())
|
||||||
|
continue;
|
||||||
|
|
||||||
|
new Missile(missileFile);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
20
src/de/steamwar/misslewars/items/Snowball.java
Normale Datei
20
src/de/steamwar/misslewars/items/Snowball.java
Normale Datei
@ -0,0 +1,20 @@
|
|||||||
|
package de.steamwar.misslewars.items;
|
||||||
|
|
||||||
|
import org.bukkit.Material;
|
||||||
|
import org.bukkit.entity.Player;
|
||||||
|
import org.bukkit.inventory.ItemStack;
|
||||||
|
|
||||||
|
public class Snowball extends SpecialItem {
|
||||||
|
|
||||||
|
private final ItemStack item = new ItemStack(Material.SNOWBALL, 1);
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public ItemStack getItem() {
|
||||||
|
return item;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean handleUse(Player p) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
33
src/de/steamwar/misslewars/items/SpecialItem.java
Normale Datei
33
src/de/steamwar/misslewars/items/SpecialItem.java
Normale Datei
@ -0,0 +1,33 @@
|
|||||||
|
package de.steamwar.misslewars.items;
|
||||||
|
|
||||||
|
import org.bukkit.entity.Player;
|
||||||
|
import org.bukkit.inventory.ItemStack;
|
||||||
|
|
||||||
|
import java.util.*;
|
||||||
|
|
||||||
|
public abstract class SpecialItem {
|
||||||
|
|
||||||
|
private static final Random random = new Random();
|
||||||
|
|
||||||
|
private static List<SpecialItem> items = new ArrayList<>();
|
||||||
|
|
||||||
|
SpecialItem(){
|
||||||
|
items.add(this);
|
||||||
|
}
|
||||||
|
|
||||||
|
public abstract ItemStack getItem();
|
||||||
|
public abstract boolean handleUse(Player p);
|
||||||
|
|
||||||
|
public static boolean handleUse(ItemStack item, Player player){
|
||||||
|
for(SpecialItem specialItem : items){
|
||||||
|
if(item.isSimilar(specialItem.getItem())){
|
||||||
|
return specialItem.handleUse(player);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
public static ItemStack getRandomItem(){
|
||||||
|
return items.get(random.nextInt(items.size())).getItem();
|
||||||
|
}
|
||||||
|
}
|
@ -1,5 +1,6 @@
|
|||||||
package de.steamwar.misslewars.listener;
|
package de.steamwar.misslewars.listener;
|
||||||
|
|
||||||
|
import de.steamwar.misslewars.Config;
|
||||||
import de.steamwar.misslewars.FightState;
|
import de.steamwar.misslewars.FightState;
|
||||||
import org.bukkit.GameMode;
|
import org.bukkit.GameMode;
|
||||||
import org.bukkit.Location;
|
import org.bukkit.Location;
|
||||||
@ -11,19 +12,8 @@ import java.util.EnumSet;
|
|||||||
|
|
||||||
public class ArenaListener extends BasicListener {
|
public class ArenaListener extends BasicListener {
|
||||||
|
|
||||||
private final int arenaMinX;
|
public ArenaListener() {
|
||||||
private final int arenaMaxX;
|
|
||||||
private final int arenaMinZ;
|
|
||||||
private final int arenaMaxZ;
|
|
||||||
private final int arenaMinY;
|
|
||||||
|
|
||||||
public ArenaListener(int arenaMinX, int arenaMaxX, int arenaMinZ, int arenaMaxZ, int arenaMinY) {
|
|
||||||
super(EnumSet.allOf(FightState.class));
|
super(EnumSet.allOf(FightState.class));
|
||||||
this.arenaMinX = arenaMinX;
|
|
||||||
this.arenaMaxX = arenaMaxX;
|
|
||||||
this.arenaMinZ = arenaMinZ;
|
|
||||||
this.arenaMaxZ = arenaMaxZ;
|
|
||||||
this.arenaMinY = arenaMinY;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@EventHandler
|
@EventHandler
|
||||||
@ -32,16 +22,16 @@ public class ArenaListener extends BasicListener {
|
|||||||
Player p = e.getPlayer();
|
Player p = e.getPlayer();
|
||||||
|
|
||||||
assert location != null;
|
assert location != null;
|
||||||
if(location.getY() < arenaMinY){
|
if(location.getY() < Config.ArenaMinY){
|
||||||
if(p.getGameMode() == GameMode.SPECTATOR)
|
if(p.getGameMode() == GameMode.SPECTATOR)
|
||||||
p.teleport(e.getFrom());
|
p.teleport(e.getFrom());
|
||||||
else
|
else
|
||||||
p.damage(Double.MAX_VALUE);
|
p.damage(Double.MAX_VALUE);
|
||||||
}else if(
|
}else if(
|
||||||
location.getX() < arenaMinX ||
|
location.getX() < Config.ArenaMinX ||
|
||||||
location.getX() > arenaMaxX ||
|
location.getX() > Config.ArenaMaxX ||
|
||||||
location.getZ() < arenaMinZ ||
|
location.getZ() < Config.ArenaMinZ ||
|
||||||
location.getZ() > arenaMaxZ){
|
location.getZ() > Config.ArenaMaxZ){
|
||||||
p.teleport(e.getFrom());
|
p.teleport(e.getFrom());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -2,34 +2,27 @@ package de.steamwar.misslewars.listener;
|
|||||||
|
|
||||||
import de.steamwar.misslewars.FightState;
|
import de.steamwar.misslewars.FightState;
|
||||||
import de.steamwar.misslewars.MissileWars;
|
import de.steamwar.misslewars.MissileWars;
|
||||||
|
import de.steamwar.misslewars.StateDependent;
|
||||||
import org.bukkit.Bukkit;
|
import org.bukkit.Bukkit;
|
||||||
import org.bukkit.event.HandlerList;
|
import org.bukkit.event.HandlerList;
|
||||||
import org.bukkit.event.Listener;
|
import org.bukkit.event.Listener;
|
||||||
|
|
||||||
import java.util.HashSet;
|
|
||||||
import java.util.Set;
|
import java.util.Set;
|
||||||
|
|
||||||
public abstract class BasicListener implements Listener {
|
public abstract class BasicListener extends StateDependent implements Listener {
|
||||||
private static Set<BasicListener> listeners = new HashSet<>();
|
|
||||||
|
|
||||||
private final Set<FightState> active;
|
|
||||||
private boolean running;
|
|
||||||
|
|
||||||
BasicListener(final Set<FightState> active){
|
BasicListener(final Set<FightState> active){
|
||||||
this.active = active;
|
super(active);
|
||||||
running = false;
|
|
||||||
listeners.add(this);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public static void setupListeners(FightState state){
|
@Override
|
||||||
for(BasicListener listener : listeners){
|
public void enable(){
|
||||||
if(listener.running && !listener.active.contains(state)){
|
Bukkit.getPluginManager().registerEvents(this, MissileWars.getPlugin());
|
||||||
HandlerList.unregisterAll(listener);
|
}
|
||||||
listener.running = false;
|
|
||||||
}else if(!listener.running && listener.active.contains(state)){
|
@Override
|
||||||
Bukkit.getPluginManager().registerEvents(listener, MissileWars.getPlugin());
|
public void disable(){
|
||||||
listener.running = true;
|
HandlerList.unregisterAll(this);
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1,24 +0,0 @@
|
|||||||
package de.steamwar.misslewars.listener;
|
|
||||||
|
|
||||||
import de.steamwar.misslewars.FightState;
|
|
||||||
import de.steamwar.misslewars.MissileWars;
|
|
||||||
import de.steamwar.misslewars.MissleSpawnSystem;
|
|
||||||
import org.bukkit.event.EventHandler;
|
|
||||||
import org.bukkit.event.player.PlayerInteractEvent;
|
|
||||||
|
|
||||||
import java.util.EnumSet;
|
|
||||||
|
|
||||||
public class EggClickListener extends BasicListener {
|
|
||||||
public EggClickListener() {
|
|
||||||
super(EnumSet.of(FightState.FIGHTING));
|
|
||||||
}
|
|
||||||
|
|
||||||
@EventHandler
|
|
||||||
public void onItemClick(PlayerInteractEvent e) {
|
|
||||||
if (e.getItem() == null || !e.getItem().getType().toString().contains("SPAWN_EGG"))
|
|
||||||
return;
|
|
||||||
MissleSpawnSystem.paste(e.getItem().getItemMeta().getDisplayName() , MissileWars.getRedTeam().hasPlayer(e.getPlayer()), e.getPlayer().getLocation());
|
|
||||||
e.getItem().setAmount(e.getItem().getAmount()-1);
|
|
||||||
e.setCancelled(true);
|
|
||||||
}
|
|
||||||
}
|
|
28
src/de/steamwar/misslewars/listener/FightListener.java
Normale Datei
28
src/de/steamwar/misslewars/listener/FightListener.java
Normale Datei
@ -0,0 +1,28 @@
|
|||||||
|
package de.steamwar.misslewars.listener;
|
||||||
|
|
||||||
|
import de.steamwar.misslewars.FightState;
|
||||||
|
import de.steamwar.misslewars.MissileWars;
|
||||||
|
import org.bukkit.entity.Player;
|
||||||
|
import org.bukkit.event.EventHandler;
|
||||||
|
import org.bukkit.event.entity.EntityDamageByEntityEvent;
|
||||||
|
|
||||||
|
import java.util.EnumSet;
|
||||||
|
|
||||||
|
public class FightListener extends BasicListener {
|
||||||
|
|
||||||
|
public FightListener() {
|
||||||
|
super(EnumSet.of(FightState.FIGHTING));
|
||||||
|
}
|
||||||
|
|
||||||
|
@EventHandler
|
||||||
|
public void onDamage(EntityDamageByEntityEvent e){
|
||||||
|
if(!(e.getDamager() instanceof Player && e.getEntity() instanceof Player))
|
||||||
|
return;
|
||||||
|
|
||||||
|
Player damager = (Player)e.getDamager();
|
||||||
|
Player reciever = (Player)e.getEntity();
|
||||||
|
|
||||||
|
if(MissileWars.getTeam(damager) == MissileWars.getTeam(reciever))
|
||||||
|
e.setCancelled(true);
|
||||||
|
}
|
||||||
|
}
|
77
src/de/steamwar/misslewars/listener/ItemListener.java
Normale Datei
77
src/de/steamwar/misslewars/listener/ItemListener.java
Normale Datei
@ -0,0 +1,77 @@
|
|||||||
|
package de.steamwar.misslewars.listener;
|
||||||
|
|
||||||
|
import com.sk89q.worldedit.EditSession;
|
||||||
|
import com.sk89q.worldedit.WorldEdit;
|
||||||
|
import com.sk89q.worldedit.bukkit.BukkitWorld;
|
||||||
|
import com.sk89q.worldedit.extent.clipboard.Clipboard;
|
||||||
|
import com.sk89q.worldedit.extent.clipboard.io.ClipboardFormats;
|
||||||
|
import com.sk89q.worldedit.function.operation.Operations;
|
||||||
|
import com.sk89q.worldedit.math.BlockVector3;
|
||||||
|
import com.sk89q.worldedit.session.ClipboardHolder;
|
||||||
|
import com.sk89q.worldedit.world.World;
|
||||||
|
import de.steamwar.misslewars.Config;
|
||||||
|
import de.steamwar.misslewars.FightState;
|
||||||
|
import de.steamwar.misslewars.MissileWars;
|
||||||
|
import de.steamwar.misslewars.items.SpecialItem;
|
||||||
|
import org.bukkit.Bukkit;
|
||||||
|
import org.bukkit.Location;
|
||||||
|
import org.bukkit.entity.Snowball;
|
||||||
|
import org.bukkit.event.EventHandler;
|
||||||
|
import org.bukkit.event.entity.ProjectileLaunchEvent;
|
||||||
|
import org.bukkit.event.player.PlayerInteractEvent;
|
||||||
|
import org.bukkit.inventory.ItemStack;
|
||||||
|
|
||||||
|
import java.io.File;
|
||||||
|
import java.io.FileInputStream;
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.util.EnumSet;
|
||||||
|
import java.util.Objects;
|
||||||
|
|
||||||
|
public class ItemListener extends BasicListener {
|
||||||
|
|
||||||
|
private static final File shield = new File(de.steamwar.misslewars.MissileWars.getPlugin().getDataFolder(), "shield.schematic");
|
||||||
|
private static final World world = new BukkitWorld(Bukkit.getWorlds().get(0));
|
||||||
|
private static final Clipboard clipboard;
|
||||||
|
private static final BlockVector3 offset;
|
||||||
|
|
||||||
|
static {
|
||||||
|
try {
|
||||||
|
clipboard = Objects.requireNonNull(ClipboardFormats.findByFile(shield)).getReader(new FileInputStream(shield)).read();
|
||||||
|
} catch (IOException e) {
|
||||||
|
throw new SecurityException("Could not load shield", e);
|
||||||
|
}
|
||||||
|
|
||||||
|
offset = clipboard.getRegion().getMinimumPoint().subtract(clipboard.getOrigin()).add(clipboard.getDimensions().divide(2));
|
||||||
|
}
|
||||||
|
|
||||||
|
public ItemListener() {
|
||||||
|
super(EnumSet.of(FightState.FIGHTING));
|
||||||
|
}
|
||||||
|
|
||||||
|
@EventHandler
|
||||||
|
public void onItemClick(PlayerInteractEvent e) {
|
||||||
|
ItemStack item = e.getItem();
|
||||||
|
if (item == null)
|
||||||
|
return;
|
||||||
|
|
||||||
|
if(SpecialItem.handleUse(item, e.getPlayer())){
|
||||||
|
item.setAmount(item.getAmount()-1);
|
||||||
|
e.getPlayer().updateInventory();
|
||||||
|
e.setCancelled(true);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@EventHandler
|
||||||
|
public void onThrow(ProjectileLaunchEvent e) {
|
||||||
|
if (e.getEntity() instanceof Snowball) {
|
||||||
|
Bukkit.getScheduler().runTaskLater(MissileWars.getPlugin(), () -> {
|
||||||
|
Location l = e.getEntity().getLocation();
|
||||||
|
BlockVector3 paste = BlockVector3.at(l.getX(), l.getY(), l.getZ()).subtract(offset);
|
||||||
|
|
||||||
|
EditSession editSession = WorldEdit.getInstance().getEditSessionFactory().getEditSession(world, -1);
|
||||||
|
Operations.completeBlindly(new ClipboardHolder(clipboard).createPaste(editSession).to(paste).build());
|
||||||
|
editSession.flushSession();
|
||||||
|
}, Config.ShieldFlyTime);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
26
src/de/steamwar/misslewars/listener/WaitingListener.java
Normale Datei
26
src/de/steamwar/misslewars/listener/WaitingListener.java
Normale Datei
@ -0,0 +1,26 @@
|
|||||||
|
package de.steamwar.misslewars.listener;
|
||||||
|
|
||||||
|
import de.steamwar.misslewars.FightState;
|
||||||
|
import org.bukkit.Bukkit;
|
||||||
|
import org.bukkit.event.EventHandler;
|
||||||
|
import org.bukkit.event.entity.EntityDamageEvent;
|
||||||
|
import org.bukkit.event.player.PlayerQuitEvent;
|
||||||
|
|
||||||
|
import java.util.EnumSet;
|
||||||
|
|
||||||
|
public class WaitingListener extends BasicListener {
|
||||||
|
public WaitingListener() {
|
||||||
|
super(EnumSet.of(FightState.WAITING));
|
||||||
|
}
|
||||||
|
|
||||||
|
@EventHandler
|
||||||
|
public void onDisconnect(PlayerQuitEvent e){
|
||||||
|
if(Bukkit.getOnlinePlayers().isEmpty())
|
||||||
|
Bukkit.shutdown();
|
||||||
|
}
|
||||||
|
|
||||||
|
@EventHandler
|
||||||
|
public void onDamage(EntityDamageEvent e){
|
||||||
|
e.setCancelled(true);
|
||||||
|
}
|
||||||
|
}
|
In neuem Issue referenzieren
Einen Benutzer sperren