Dieser Commit ist enthalten in:
Ursprung
a2dafd7a1a
Commit
04ef766fb4
@ -4,6 +4,9 @@ ShieldFlyTime: 100
|
|||||||
PlatformTime: 30
|
PlatformTime: 30
|
||||||
EndTime: 200
|
EndTime: 200
|
||||||
|
|
||||||
|
# Special
|
||||||
|
Barrier: true
|
||||||
|
|
||||||
Arena:
|
Arena:
|
||||||
MinX: 0
|
MinX: 0
|
||||||
MaxX: 0
|
MaxX: 0
|
||||||
|
@ -56,6 +56,8 @@ public class Config {
|
|||||||
|
|
||||||
private static final int EventKampfID;
|
private static final int EventKampfID;
|
||||||
|
|
||||||
|
public static final boolean Barrier;
|
||||||
|
|
||||||
static {
|
static {
|
||||||
File configfile = new File(Bukkit.getWorlds().get(0).getWorldFolder(), "config.yml");
|
File configfile = new File(Bukkit.getWorlds().get(0).getWorldFolder(), "config.yml");
|
||||||
if (!configfile.exists()) {
|
if (!configfile.exists()) {
|
||||||
@ -102,6 +104,8 @@ public class Config {
|
|||||||
RedLeader = null;
|
RedLeader = null;
|
||||||
|
|
||||||
EventKampfID = Integer.parseInt(System.getProperty("fightID", "0"));
|
EventKampfID = Integer.parseInt(System.getProperty("fightID", "0"));
|
||||||
|
|
||||||
|
Barrier = config.getBoolean("Barrier", false);
|
||||||
}
|
}
|
||||||
|
|
||||||
public static boolean isChallenge() {
|
public static boolean isChallenge() {
|
||||||
|
@ -28,6 +28,7 @@ import de.steamwar.misslewars.countdowns.WaitingCountdown;
|
|||||||
import de.steamwar.misslewars.items.CustomItem;
|
import de.steamwar.misslewars.items.CustomItem;
|
||||||
import de.steamwar.misslewars.items.Missile;
|
import de.steamwar.misslewars.items.Missile;
|
||||||
import de.steamwar.misslewars.listener.*;
|
import de.steamwar.misslewars.listener.*;
|
||||||
|
import de.steamwar.misslewars.listener.special.BarrierListener;
|
||||||
import de.steamwar.misslewars.slowmo.SlowMoRunner;
|
import de.steamwar.misslewars.slowmo.SlowMoRunner;
|
||||||
import org.bukkit.Bukkit;
|
import org.bukkit.Bukkit;
|
||||||
import org.bukkit.ChatColor;
|
import org.bukkit.ChatColor;
|
||||||
@ -92,6 +93,8 @@ public class MissileWars extends JavaPlugin {
|
|||||||
|
|
||||||
StateDependent.setupState(fightState);
|
StateDependent.setupState(fightState);
|
||||||
|
|
||||||
|
new BarrierListener();
|
||||||
|
|
||||||
Bukkit.getScheduler().runTaskTimer(this, new FightInfoPacketSender(), 20, 20);
|
Bukkit.getScheduler().runTaskTimer(this, new FightInfoPacketSender(), 20, 20);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -31,7 +31,7 @@ import java.util.Set;
|
|||||||
public abstract class BasicListener extends StateDependent implements Listener {
|
public abstract class BasicListener extends StateDependent implements Listener {
|
||||||
|
|
||||||
|
|
||||||
BasicListener(final Set<FightState> active){
|
protected BasicListener(final Set<FightState> active){
|
||||||
super(active);
|
super(active);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
58
src/de/steamwar/misslewars/listener/special/BarrierListener.java
Normale Datei
58
src/de/steamwar/misslewars/listener/special/BarrierListener.java
Normale Datei
@ -0,0 +1,58 @@
|
|||||||
|
/*
|
||||||
|
*
|
||||||
|
* This file is a part of the SteamWar software.
|
||||||
|
*
|
||||||
|
* Copyright (C) 2020 SteamWar.de-Serverteam
|
||||||
|
*
|
||||||
|
* This program is free software: you can redistribute it and/or modify
|
||||||
|
* it under the terms of the GNU Affero General Public License as published by
|
||||||
|
* the Free Software Foundation, either version 3 of the License, or
|
||||||
|
* (at your option) any later version.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful,
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
* GNU Affero General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU Affero General Public License
|
||||||
|
* along with this program. If not, see <https://www.gnu.org/licenses/>.
|
||||||
|
* /
|
||||||
|
*/
|
||||||
|
|
||||||
|
package de.steamwar.misslewars.listener.special;
|
||||||
|
|
||||||
|
import de.steamwar.misslewars.Config;
|
||||||
|
import de.steamwar.misslewars.FightState;
|
||||||
|
import de.steamwar.misslewars.listener.BasicListener;
|
||||||
|
import org.bukkit.Material;
|
||||||
|
import org.bukkit.block.Block;
|
||||||
|
import org.bukkit.event.EventHandler;
|
||||||
|
import org.bukkit.event.block.BlockPhysicsEvent;
|
||||||
|
|
||||||
|
import java.util.EnumSet;
|
||||||
|
|
||||||
|
public class BarrierListener extends BasicListener {
|
||||||
|
|
||||||
|
public BarrierListener() {
|
||||||
|
super(EnumSet.allOf(FightState.class));
|
||||||
|
}
|
||||||
|
|
||||||
|
private int middle = Config.ArenaMinZ + (Config.ArenaMaxZ - Config.ArenaMinZ) / 2;
|
||||||
|
|
||||||
|
@EventHandler
|
||||||
|
public void onBlockPhysics(BlockPhysicsEvent event) {
|
||||||
|
if (!Config.Barrier) return;
|
||||||
|
Block block = event.getBlock();
|
||||||
|
if (block.getZ() > middle - 10 && block.getZ() < middle + 10) {
|
||||||
|
switch (block.getType()) {
|
||||||
|
case SLIME_BLOCK:
|
||||||
|
case HONEY_BLOCK:
|
||||||
|
case TNT:
|
||||||
|
block.setType(Material.AIR);
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
In neuem Issue referenzieren
Einen Benutzer sperren