mirror of
https://github.com/DRE2N/DungeonsXL.git
synced 2025-02-12 18:31:54 +01:00
Added TeleportSign
This commit is contained in:
parent
1b6ed7432a
commit
479935f007
@ -45,7 +45,8 @@ public enum DSignTypeDefault implements DSignType {
|
||||
SOUND_MESSAGE("SoundMSG", "soundmsg", false, SoundMessageSign.class),
|
||||
START("Start", "start", true, StartSign.class),
|
||||
TRIGGER("Trigger", "trigger", true, TriggerSign.class),
|
||||
WAVE("Wave", "wave", false, WaveSign.class);
|
||||
WAVE("Wave", "wave", false, WaveSign.class),
|
||||
TELEPORT("Teleport", "teleport", false, TeleportSign.class);
|
||||
|
||||
private String name;
|
||||
private String buildPermission;
|
||||
|
109
src/main/java/io/github/dre2n/dungeonsxl/sign/TeleportSign.java
Normal file
109
src/main/java/io/github/dre2n/dungeonsxl/sign/TeleportSign.java
Normal file
@ -0,0 +1,109 @@
|
||||
package io.github.dre2n.dungeonsxl.sign;
|
||||
|
||||
import io.github.dre2n.dungeonsxl.world.GameWorld;
|
||||
import org.bukkit.Location;
|
||||
import org.bukkit.Material;
|
||||
import org.bukkit.block.Sign;
|
||||
import org.bukkit.entity.Player;
|
||||
|
||||
public class TeleportSign extends DSign {
|
||||
|
||||
private DSignType type = DSignTypeDefault.TELEPORT;
|
||||
|
||||
private Location location;
|
||||
|
||||
public TeleportSign(Sign sign, GameWorld gameWorld) {
|
||||
super(sign, gameWorld);
|
||||
}
|
||||
|
||||
@SuppressWarnings("ResultOfMethodCallIgnored")
|
||||
@Override
|
||||
public boolean check() {
|
||||
String lines[] = getSign().getLines();
|
||||
for (int i = 1; i <= 2; i++) {
|
||||
if (!lines[i].isEmpty()) {
|
||||
if (lines[i].equalsIgnoreCase("N") || lines[i].equalsIgnoreCase("E") || lines[i].equalsIgnoreCase("S") || lines[i].equalsIgnoreCase("W")) {
|
||||
continue;
|
||||
} else {
|
||||
String[] loc = lines[i].split(",");
|
||||
if (loc.length != 3) {
|
||||
return false;
|
||||
}
|
||||
try {
|
||||
Double.parseDouble(loc[0]);
|
||||
Double.parseDouble(loc[1]);
|
||||
Double.parseDouble(loc[2]);
|
||||
} catch (NumberFormatException e) {
|
||||
return false;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
return true;
|
||||
}
|
||||
|
||||
@Override
|
||||
public void onInit() {
|
||||
location = getSign().getLocation().add(0.5, 0, 0.5);
|
||||
String lines[] = getSign().getLines();
|
||||
for (int i = 1; i <= 2; i++) {
|
||||
if (!lines[i].isEmpty()) {
|
||||
if (lines[i].equalsIgnoreCase("S")) {
|
||||
location.setYaw(0);
|
||||
} else if (lines[i].equalsIgnoreCase("W")) {
|
||||
location.setYaw(90);
|
||||
} else if (lines[i].equalsIgnoreCase("N")) {
|
||||
location.setYaw(180);
|
||||
} else if (lines[i].equalsIgnoreCase("E")) {
|
||||
location.setYaw(-90);
|
||||
} else {
|
||||
String[] loc = lines[i].split(",");
|
||||
if (loc.length == 3) {
|
||||
try {
|
||||
double x = Double.parseDouble(loc[0]);
|
||||
double y = Double.parseDouble(loc[1]);
|
||||
double z = Double.parseDouble(loc[2]);
|
||||
|
||||
// If round number, add 0.5 to tp to middle of block
|
||||
try {
|
||||
x = Integer.parseInt(loc[0]) + 0.5;
|
||||
} catch (NumberFormatException ignored) {}
|
||||
try {
|
||||
z = Integer.parseInt(loc[2]) + 0.5;
|
||||
} catch (NumberFormatException ignored) {}
|
||||
|
||||
location.setX(x);
|
||||
location.setY(y);
|
||||
location.setZ(z);
|
||||
} catch (NumberFormatException e) {
|
||||
e.printStackTrace();
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
getSign().getBlock().setType(Material.AIR);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void onTrigger() {
|
||||
if (location != null) {
|
||||
for (Player player : getGameWorld().getWorld().getPlayers()) {
|
||||
player.teleport(location);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
public boolean onPlayerTrigger(Player player) {
|
||||
if (location != null) {
|
||||
player.teleport(location);
|
||||
}
|
||||
return true;
|
||||
}
|
||||
|
||||
@Override
|
||||
public DSignType getType() {
|
||||
return type;
|
||||
}
|
||||
}
|
Loading…
Reference in New Issue
Block a user