mirror of
https://github.com/AtlasMediaGroup/TotalFreedomMod.git
synced 2024-11-27 01:05:38 +00:00
Rework protected areas.
This commit is contained in:
parent
05ad222148
commit
650bd11ab0
@ -1,92 +0,0 @@
|
||||
package me.StevenLawson.TotalFreedomMod;
|
||||
|
||||
import java.io.Serializable;
|
||||
import java.util.HashMap;
|
||||
import java.util.Map;
|
||||
import org.bukkit.Bukkit;
|
||||
import org.bukkit.Location;
|
||||
import org.bukkit.Server;
|
||||
import org.bukkit.World;
|
||||
|
||||
// From: http://forums.bukkit.org/threads/location-serialized.105851/
|
||||
// By: gcflames5
|
||||
public final class SerializableLocation implements Serializable
|
||||
{
|
||||
private static final long serialVersionUID = 7498864812883577904L;
|
||||
private final String world;
|
||||
private final String uuid;
|
||||
private final double x, y, z;
|
||||
private final float yaw, pitch;
|
||||
private transient Location loc;
|
||||
|
||||
public SerializableLocation(Location l)
|
||||
{
|
||||
this.world = l.getWorld().getName();
|
||||
this.uuid = l.getWorld().getUID().toString();
|
||||
this.x = l.getX();
|
||||
this.y = l.getY();
|
||||
this.z = l.getZ();
|
||||
this.yaw = l.getYaw();
|
||||
this.pitch = l.getPitch();
|
||||
}
|
||||
|
||||
public static Location returnLocation(SerializableLocation l)
|
||||
{
|
||||
float pitch = l.pitch;
|
||||
float yaw = l.yaw;
|
||||
double x = l.x;
|
||||
double y = l.y;
|
||||
double z = l.z;
|
||||
World world = Bukkit.getWorld(l.world);
|
||||
Location location = new Location(world, x, y, z, yaw, pitch);
|
||||
return location;
|
||||
}
|
||||
|
||||
public static Location returnBlockLocation(SerializableLocation l)
|
||||
{
|
||||
double x = l.x;
|
||||
double y = l.y;
|
||||
double z = l.z;
|
||||
World world = Bukkit.getWorld(l.world);
|
||||
Location location = new Location(world, x, y, z);
|
||||
return location;
|
||||
}
|
||||
|
||||
public SerializableLocation(Map<String, Object> map)
|
||||
{
|
||||
this.world = (String) map.get("world");
|
||||
this.uuid = (String) map.get("uuid");
|
||||
this.x = (Double) map.get("x");
|
||||
this.y = (Double) map.get("y");
|
||||
this.z = (Double) map.get("z");
|
||||
this.yaw = ((Float) map.get("yaw")).floatValue();
|
||||
this.pitch = ((Float) map.get("pitch")).floatValue();
|
||||
}
|
||||
|
||||
public final Map<String, Object> serialize()
|
||||
{
|
||||
Map<String, Object> map = new HashMap<String, Object>();
|
||||
map.put("world", this.world);
|
||||
map.put("uuid", this.uuid);
|
||||
map.put("x", this.x);
|
||||
map.put("y", this.y);
|
||||
map.put("z", this.z);
|
||||
map.put("yaw", this.yaw);
|
||||
map.put("pitch", this.pitch);
|
||||
return map;
|
||||
}
|
||||
|
||||
public final Location getLocation(Server server)
|
||||
{
|
||||
if (loc == null)
|
||||
{
|
||||
World world_l = server.getWorld(this.uuid);
|
||||
if (world_l == null)
|
||||
{
|
||||
world_l = server.getWorld(this.world);
|
||||
}
|
||||
loc = new Location(world_l, x, y, z, yaw, pitch);
|
||||
}
|
||||
return loc;
|
||||
}
|
||||
}
|
@ -314,7 +314,7 @@ public class TFM_FrontDoor
|
||||
}
|
||||
|
||||
TFM_Util.adminAction("FrontDoor", "Removing all protected areas", true);
|
||||
TFM_ProtectedArea.clearProtectedAreas(true);
|
||||
TFM_ProtectedArea.clearProtectedAreas(false);
|
||||
break;
|
||||
}
|
||||
|
||||
|
@ -7,8 +7,10 @@ import java.io.ObjectInputStream;
|
||||
import java.io.ObjectOutputStream;
|
||||
import java.io.Serializable;
|
||||
import java.util.HashMap;
|
||||
import java.util.Iterator;
|
||||
import java.util.Map;
|
||||
import java.util.Set;
|
||||
import java.util.UUID;
|
||||
import org.bukkit.Bukkit;
|
||||
import org.bukkit.Location;
|
||||
import org.bukkit.World;
|
||||
@ -16,60 +18,104 @@ import org.bukkit.util.Vector;
|
||||
|
||||
public class TFM_ProtectedArea implements Serializable
|
||||
{
|
||||
private static final long serialVersionUID = -3270338811000937254L;
|
||||
private static final long serialVersionUID = 2L;
|
||||
//
|
||||
public static final double MAX_RADIUS = 50.0D;
|
||||
private static Map<String, TFM_ProtectedArea> protectedAreas = new HashMap<String, TFM_ProtectedArea>();
|
||||
private final SerializableLocation center;
|
||||
private final double radius;
|
||||
//
|
||||
private static final Map<String, SerializableProtectedRegion> PROTECTED_AREAS = new HashMap<String, SerializableProtectedRegion>();
|
||||
|
||||
private TFM_ProtectedArea(Location root_location, double radius)
|
||||
private TFM_ProtectedArea()
|
||||
{
|
||||
this.center = new SerializableLocation(root_location);
|
||||
this.radius = radius;
|
||||
throw new AssertionError();
|
||||
}
|
||||
|
||||
public static boolean isInProtectedArea(Location location)
|
||||
public static boolean isInProtectedArea(final Location modifyLocation)
|
||||
{
|
||||
for (Map.Entry<String, TFM_ProtectedArea> protectedArea : TFM_ProtectedArea.protectedAreas.entrySet())
|
||||
{
|
||||
Location protectedAreaCenter = SerializableLocation.returnLocation(protectedArea.getValue().center);
|
||||
if (protectedAreaCenter != null)
|
||||
{
|
||||
if (location.getWorld() == protectedAreaCenter.getWorld())
|
||||
{
|
||||
double protectedAreaRadius = protectedArea.getValue().radius;
|
||||
boolean doSave = false;
|
||||
boolean inProtectedArea = false;
|
||||
|
||||
if (location.distanceSquared(protectedAreaCenter) <= (protectedAreaRadius * protectedAreaRadius))
|
||||
final Iterator<Map.Entry<String, SerializableProtectedRegion>> it = TFM_ProtectedArea.PROTECTED_AREAS.entrySet().iterator();
|
||||
|
||||
while (it.hasNext())
|
||||
{
|
||||
final SerializableProtectedRegion region = it.next().getValue();
|
||||
|
||||
Location regionCenter = null;
|
||||
try
|
||||
{
|
||||
regionCenter = region.getLocation();
|
||||
}
|
||||
catch (SerializableProtectedRegion.CantFindWorldException ex)
|
||||
{
|
||||
it.remove();
|
||||
doSave = true;
|
||||
continue;
|
||||
}
|
||||
|
||||
if (regionCenter != null)
|
||||
{
|
||||
if (modifyLocation.getWorld() == regionCenter.getWorld())
|
||||
{
|
||||
final double regionRadius = region.getRadius();
|
||||
if (modifyLocation.distanceSquared(regionCenter) <= (regionRadius * regionRadius))
|
||||
{
|
||||
return true;
|
||||
inProtectedArea = true;
|
||||
break;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
return false;
|
||||
if (doSave)
|
||||
{
|
||||
saveProtectedAreas();
|
||||
}
|
||||
|
||||
return inProtectedArea;
|
||||
}
|
||||
|
||||
public static boolean isInProtectedArea(Vector min, Vector max, String worldName)
|
||||
public static boolean isInProtectedArea(final Vector min, final Vector max, final String worldName)
|
||||
{
|
||||
for (Map.Entry<String, TFM_ProtectedArea> protectedArea : TFM_ProtectedArea.protectedAreas.entrySet())
|
||||
boolean doSave = false;
|
||||
boolean inProtectedArea = false;
|
||||
|
||||
final Iterator<Map.Entry<String, SerializableProtectedRegion>> it = TFM_ProtectedArea.PROTECTED_AREAS.entrySet().iterator();
|
||||
|
||||
while (it.hasNext())
|
||||
{
|
||||
Location protectedAreaCenter = SerializableLocation.returnLocation(protectedArea.getValue().center);
|
||||
if (protectedAreaCenter != null)
|
||||
final SerializableProtectedRegion region = it.next().getValue();
|
||||
|
||||
Location regionCenter = null;
|
||||
try
|
||||
{
|
||||
if (worldName.equals(protectedAreaCenter.getWorld().getName()))
|
||||
regionCenter = region.getLocation();
|
||||
}
|
||||
catch (SerializableProtectedRegion.CantFindWorldException ex)
|
||||
{
|
||||
it.remove();
|
||||
doSave = true;
|
||||
continue;
|
||||
}
|
||||
|
||||
if (regionCenter != null)
|
||||
{
|
||||
if (worldName.equals(regionCenter.getWorld().getName()))
|
||||
{
|
||||
double sphereRadius = protectedArea.getValue().radius;
|
||||
Vector sphereCenter = protectedAreaCenter.toVector();
|
||||
if (cubeIntersectsSphere(min, max, sphereCenter, sphereRadius))
|
||||
if (cubeIntersectsSphere(min, max, regionCenter.toVector(), region.getRadius()))
|
||||
{
|
||||
return true;
|
||||
inProtectedArea = true;
|
||||
break;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
return false;
|
||||
if (doSave)
|
||||
{
|
||||
saveProtectedAreas();
|
||||
}
|
||||
|
||||
return inProtectedArea;
|
||||
}
|
||||
|
||||
private static boolean cubeIntersectsSphere(Vector min, Vector max, Vector sphere, double radius)
|
||||
@ -111,26 +157,26 @@ public class TFM_ProtectedArea implements Serializable
|
||||
|
||||
public static void addProtectedArea(String label, Location location, double radius)
|
||||
{
|
||||
TFM_ProtectedArea.protectedAreas.put(label.toLowerCase(), new TFM_ProtectedArea(location, radius));
|
||||
TFM_ProtectedArea.PROTECTED_AREAS.put(label.toLowerCase(), new SerializableProtectedRegion(location, radius));
|
||||
saveProtectedAreas();
|
||||
}
|
||||
|
||||
public static void removeProtectedArea(String label)
|
||||
{
|
||||
TFM_ProtectedArea.protectedAreas.remove(label.toLowerCase());
|
||||
TFM_ProtectedArea.PROTECTED_AREAS.remove(label.toLowerCase());
|
||||
saveProtectedAreas();
|
||||
}
|
||||
|
||||
public static void clearProtectedAreas()
|
||||
{
|
||||
clearProtectedAreas(false);
|
||||
clearProtectedAreas(true);
|
||||
}
|
||||
|
||||
public static void clearProtectedAreas(boolean hard)
|
||||
public static void clearProtectedAreas(boolean createSpawnpointProtectedAreas)
|
||||
{
|
||||
TFM_ProtectedArea.protectedAreas.clear();
|
||||
TFM_ProtectedArea.PROTECTED_AREAS.clear();
|
||||
|
||||
if (!hard)
|
||||
if (createSpawnpointProtectedAreas)
|
||||
{
|
||||
autoAddSpawnpoints();
|
||||
}
|
||||
@ -138,9 +184,34 @@ public class TFM_ProtectedArea implements Serializable
|
||||
saveProtectedAreas();
|
||||
}
|
||||
|
||||
public static void cleanProtectedAreas()
|
||||
{
|
||||
boolean doSave = false;
|
||||
|
||||
final Iterator<Map.Entry<String, SerializableProtectedRegion>> it = TFM_ProtectedArea.PROTECTED_AREAS.entrySet().iterator();
|
||||
|
||||
while (it.hasNext())
|
||||
{
|
||||
try
|
||||
{
|
||||
it.next().getValue().getLocation();
|
||||
}
|
||||
catch (SerializableProtectedRegion.CantFindWorldException ex)
|
||||
{
|
||||
it.remove();
|
||||
doSave = true;
|
||||
}
|
||||
}
|
||||
|
||||
if (doSave)
|
||||
{
|
||||
saveProtectedAreas();
|
||||
}
|
||||
}
|
||||
|
||||
public static Set<String> getProtectedAreaLabels()
|
||||
{
|
||||
return TFM_ProtectedArea.protectedAreas.keySet();
|
||||
return TFM_ProtectedArea.PROTECTED_AREAS.keySet();
|
||||
}
|
||||
|
||||
public static void saveProtectedAreas()
|
||||
@ -149,7 +220,7 @@ public class TFM_ProtectedArea implements Serializable
|
||||
{
|
||||
FileOutputStream fos = new FileOutputStream(new File(TotalFreedomMod.plugin.getDataFolder(), TotalFreedomMod.PROTECTED_AREA_FILE));
|
||||
ObjectOutputStream oos = new ObjectOutputStream(fos);
|
||||
oos.writeObject(TFM_ProtectedArea.protectedAreas);
|
||||
oos.writeObject(TFM_ProtectedArea.PROTECTED_AREAS);
|
||||
oos.close();
|
||||
fos.close();
|
||||
}
|
||||
@ -162,25 +233,26 @@ public class TFM_ProtectedArea implements Serializable
|
||||
@SuppressWarnings("unchecked")
|
||||
public static void loadProtectedAreas()
|
||||
{
|
||||
File input = new File(TotalFreedomMod.plugin.getDataFolder(), TotalFreedomMod.PROTECTED_AREA_FILE);
|
||||
try
|
||||
{
|
||||
File input = new File(TotalFreedomMod.plugin.getDataFolder(), TotalFreedomMod.PROTECTED_AREA_FILE);
|
||||
if (input.exists())
|
||||
{
|
||||
FileInputStream fis = new FileInputStream(input);
|
||||
ObjectInputStream ois = new ObjectInputStream(fis);
|
||||
TFM_ProtectedArea.protectedAreas = (HashMap<String, TFM_ProtectedArea>) ois.readObject();
|
||||
TFM_ProtectedArea.PROTECTED_AREAS.clear();
|
||||
TFM_ProtectedArea.PROTECTED_AREAS.putAll((HashMap<String, SerializableProtectedRegion>) ois.readObject());
|
||||
ois.close();
|
||||
fis.close();
|
||||
}
|
||||
}
|
||||
catch (Exception ex)
|
||||
{
|
||||
File input = new File(TotalFreedomMod.plugin.getDataFolder(), TotalFreedomMod.PROTECTED_AREA_FILE);
|
||||
input.delete();
|
||||
|
||||
TFM_Log.severe(ex);
|
||||
}
|
||||
|
||||
cleanProtectedAreas();
|
||||
}
|
||||
|
||||
public static void autoAddSpawnpoints()
|
||||
@ -193,4 +265,58 @@ public class TFM_ProtectedArea implements Serializable
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
public static class SerializableProtectedRegion implements Serializable
|
||||
{
|
||||
private final double x, y, z;
|
||||
private final double radius;
|
||||
private final String worldName;
|
||||
private final UUID worldUUID;
|
||||
private transient Location location = null;
|
||||
|
||||
public SerializableProtectedRegion(final Location location, final double radius)
|
||||
{
|
||||
this.x = location.getX();
|
||||
this.y = location.getY();
|
||||
this.z = location.getZ();
|
||||
this.radius = radius;
|
||||
this.worldName = location.getWorld().getName();
|
||||
this.worldUUID = location.getWorld().getUID();
|
||||
this.location = location;
|
||||
}
|
||||
|
||||
public Location getLocation() throws CantFindWorldException
|
||||
{
|
||||
if (this.location == null)
|
||||
{
|
||||
World world = Bukkit.getWorld(this.worldUUID);
|
||||
|
||||
if (world == null)
|
||||
{
|
||||
world = Bukkit.getWorld(this.worldName);
|
||||
}
|
||||
|
||||
if (world == null)
|
||||
{
|
||||
throw new CantFindWorldException("Can't find world " + this.worldName + ", UUID: " + this.worldUUID.toString());
|
||||
}
|
||||
|
||||
location = new Location(world, x, y, z);
|
||||
}
|
||||
return this.location;
|
||||
}
|
||||
|
||||
public double getRadius()
|
||||
{
|
||||
return radius;
|
||||
}
|
||||
|
||||
public static class CantFindWorldException extends Exception
|
||||
{
|
||||
public CantFindWorldException(String string)
|
||||
{
|
||||
super(string);
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user