2010-12-27 02:11:52 +00:00
|
|
|
|
|
|
|
package org.bukkit;
|
|
|
|
|
2011-02-18 16:28:42 +00:00
|
|
|
import org.bukkit.block.Block;
|
2011-01-15 13:43:09 -08:00
|
|
|
import org.bukkit.util.Vector;
|
|
|
|
|
2010-12-27 02:11:52 +00:00
|
|
|
/**
|
|
|
|
* Represents a 3-dimensional position in a world
|
|
|
|
*/
|
2010-12-29 03:19:12 +00:00
|
|
|
public class Location implements Cloneable {
|
2010-12-27 02:11:52 +00:00
|
|
|
private World world;
|
|
|
|
private double x;
|
|
|
|
private double y;
|
|
|
|
private double z;
|
2010-12-28 16:59:25 +00:00
|
|
|
private float pitch;
|
|
|
|
private float yaw;
|
2010-12-27 02:11:52 +00:00
|
|
|
|
|
|
|
public Location(final World world, final double x, final double y, final double z) {
|
2010-12-28 16:59:25 +00:00
|
|
|
this(world, x, y, z, 0, 0);
|
|
|
|
}
|
|
|
|
|
2010-12-29 01:15:16 +00:00
|
|
|
public Location(final World world, final double x, final double y, final double z, final float yaw, final float pitch) {
|
2010-12-27 02:11:52 +00:00
|
|
|
this.world = world;
|
|
|
|
this.x = x;
|
|
|
|
this.y = y;
|
|
|
|
this.z = z;
|
2010-12-28 16:59:25 +00:00
|
|
|
this.pitch = pitch;
|
|
|
|
this.yaw = yaw;
|
2010-12-27 02:11:52 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Sets the world that this location resides in
|
|
|
|
*
|
|
|
|
* @param world New world that this location resides in
|
|
|
|
*/
|
|
|
|
public void setWorld(World world) {
|
|
|
|
this.world = world;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Gets the world that this location resides in
|
|
|
|
*
|
|
|
|
* @return World that contains this location
|
|
|
|
*/
|
|
|
|
public World getWorld() {
|
|
|
|
return world;
|
|
|
|
}
|
|
|
|
|
2011-02-18 16:28:42 +00:00
|
|
|
/**
|
|
|
|
* Gets the block at the represented location
|
|
|
|
*
|
|
|
|
* @return Block at the represented location
|
|
|
|
*/
|
|
|
|
public Block getBlock() {
|
2011-02-18 16:34:49 +00:00
|
|
|
return world.getBlockAt(this);
|
2011-02-18 16:28:42 +00:00
|
|
|
}
|
|
|
|
|
2010-12-27 02:11:52 +00:00
|
|
|
/**
|
|
|
|
* Sets the x-coordinate of this location
|
|
|
|
*
|
|
|
|
* @param x X-coordinate
|
|
|
|
*/
|
|
|
|
public void setX(double x) {
|
|
|
|
this.x = x;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Gets the x-coordinate of this location
|
|
|
|
*
|
|
|
|
* @return x-coordinate
|
|
|
|
*/
|
|
|
|
public double getX() {
|
|
|
|
return x;
|
|
|
|
}
|
2011-02-02 00:02:08 +01:00
|
|
|
|
2011-01-02 10:42:13 -08:00
|
|
|
/**
|
|
|
|
* Gets the floored value of the X component, indicating the block that
|
|
|
|
* this location is contained with.
|
2011-02-02 00:02:08 +01:00
|
|
|
*
|
2011-01-02 10:42:13 -08:00
|
|
|
* @return block X
|
|
|
|
*/
|
|
|
|
public int getBlockX() {
|
|
|
|
return (int)Math.floor(x);
|
|
|
|
}
|
2010-12-27 02:11:52 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Sets the y-coordinate of this location
|
|
|
|
*
|
|
|
|
* @param y y-coordinate
|
|
|
|
*/
|
|
|
|
public void setY(double y) {
|
|
|
|
this.y = y;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Gets the y-coordinate of this location
|
|
|
|
*
|
|
|
|
* @return y-coordinate
|
|
|
|
*/
|
|
|
|
public double getY() {
|
|
|
|
return y;
|
|
|
|
}
|
|
|
|
|
2011-01-02 10:42:13 -08:00
|
|
|
/**
|
|
|
|
* Gets the floored value of the Y component, indicating the block that
|
|
|
|
* this location is contained with.
|
2011-02-02 00:02:08 +01:00
|
|
|
*
|
2011-01-02 10:42:13 -08:00
|
|
|
* @return block y
|
|
|
|
*/
|
|
|
|
public int getBlockY() {
|
|
|
|
return (int)Math.floor(y);
|
|
|
|
}
|
|
|
|
|
2010-12-27 02:11:52 +00:00
|
|
|
/**
|
|
|
|
* Sets the z-coordinate of this location
|
|
|
|
*
|
|
|
|
* @param z z-coordinate
|
|
|
|
*/
|
|
|
|
public void setZ(double z) {
|
|
|
|
this.z = z;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Gets the z-coordinate of this location
|
|
|
|
*
|
|
|
|
* @return z-coordinate
|
|
|
|
*/
|
|
|
|
public double getZ() {
|
|
|
|
return z;
|
|
|
|
}
|
|
|
|
|
2011-01-02 10:42:13 -08:00
|
|
|
/**
|
|
|
|
* Gets the floored value of the Z component, indicating the block that
|
|
|
|
* this location is contained with.
|
2011-02-02 00:02:08 +01:00
|
|
|
*
|
2011-01-02 10:42:13 -08:00
|
|
|
* @return block z
|
|
|
|
*/
|
|
|
|
public int getBlockZ() {
|
|
|
|
return (int)Math.floor(z);
|
|
|
|
}
|
|
|
|
|
2010-12-28 16:59:25 +00:00
|
|
|
/**
|
|
|
|
* Sets the yaw of this location
|
|
|
|
*
|
|
|
|
* @param yaw New yaw
|
|
|
|
*/
|
|
|
|
public void setYaw(float yaw) {
|
|
|
|
this.yaw = yaw;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Gets the yaw of this location
|
|
|
|
*
|
|
|
|
* @return Yaw
|
|
|
|
*/
|
|
|
|
public float getYaw() {
|
|
|
|
return yaw;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Sets the pitch of this location
|
|
|
|
*
|
|
|
|
* @param pitch New pitch
|
|
|
|
*/
|
|
|
|
public void setPitch(float pitch) {
|
|
|
|
this.pitch = pitch;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Gets the pitch of this location
|
|
|
|
*
|
|
|
|
* @return Pitch
|
|
|
|
*/
|
|
|
|
public float getPitch() {
|
|
|
|
return pitch;
|
|
|
|
}
|
|
|
|
|
2011-02-13 17:03:57 +00:00
|
|
|
/**
|
|
|
|
* Gets a Vector pointing in the direction that this Location is facing
|
|
|
|
*
|
|
|
|
* @return Vector
|
|
|
|
*/
|
|
|
|
public Vector getDirection() {
|
|
|
|
Vector vector = new Vector();
|
|
|
|
|
|
|
|
double rotX = this.getYaw();
|
|
|
|
double rotY = this.getPitch();
|
|
|
|
|
|
|
|
vector.setY(-Math.sin(Math.toRadians(rotY)));
|
|
|
|
|
|
|
|
double h = Math.cos(Math.toRadians(rotY));
|
|
|
|
vector.setX(-h*Math.sin(Math.toRadians(rotX)));
|
|
|
|
vector.setZ(h*Math.cos(Math.toRadians(rotX)));
|
|
|
|
|
|
|
|
return vector;
|
|
|
|
}
|
|
|
|
|
2010-12-27 02:11:52 +00:00
|
|
|
@Override
|
|
|
|
public boolean equals(Object obj) {
|
|
|
|
if (obj == null) {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
if (getClass() != obj.getClass()) {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
final Location other = (Location) obj;
|
|
|
|
if (this.world != other.world && (this.world == null || !this.world.equals(other.world))) {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
if (Double.doubleToLongBits(this.x) != Double.doubleToLongBits(other.x)) {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
if (Double.doubleToLongBits(this.y) != Double.doubleToLongBits(other.y)) {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
if (Double.doubleToLongBits(this.z) != Double.doubleToLongBits(other.z)) {
|
|
|
|
return false;
|
|
|
|
}
|
2010-12-28 16:59:25 +00:00
|
|
|
if (Float.floatToIntBits(this.pitch) != Float.floatToIntBits(other.pitch)) {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
if (Float.floatToIntBits(this.yaw) != Float.floatToIntBits(other.yaw)) {
|
|
|
|
return false;
|
|
|
|
}
|
2010-12-27 02:11:52 +00:00
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public int hashCode() {
|
2010-12-28 16:59:25 +00:00
|
|
|
int hash = 3;
|
|
|
|
hash = 19 * hash + (this.world != null ? this.world.hashCode() : 0);
|
|
|
|
hash = 19 * hash + (int) (Double.doubleToLongBits(this.x) ^ (Double.doubleToLongBits(this.x) >>> 32));
|
|
|
|
hash = 19 * hash + (int) (Double.doubleToLongBits(this.y) ^ (Double.doubleToLongBits(this.y) >>> 32));
|
|
|
|
hash = 19 * hash + (int) (Double.doubleToLongBits(this.z) ^ (Double.doubleToLongBits(this.z) >>> 32));
|
|
|
|
hash = 19 * hash + Float.floatToIntBits(this.pitch);
|
|
|
|
hash = 19 * hash + Float.floatToIntBits(this.yaw);
|
2010-12-27 02:11:52 +00:00
|
|
|
return hash;
|
|
|
|
}
|
2010-12-28 16:59:25 +00:00
|
|
|
|
|
|
|
@Override
|
|
|
|
public String toString() {
|
|
|
|
return "Location{" + "world=" + world + "x=" + x + "y=" + y + "z=" + z + "pitch=" + pitch + "yaw=" + yaw + '}';
|
|
|
|
}
|
2011-02-02 00:02:08 +01:00
|
|
|
|
2011-01-02 16:23:56 +08:00
|
|
|
public Vector toVector() {
|
|
|
|
return new Vector(x, y, z);
|
|
|
|
}
|
2010-12-29 03:19:12 +00:00
|
|
|
|
|
|
|
@Override
|
2011-01-08 12:39:54 -08:00
|
|
|
public Location clone() {
|
2010-12-29 03:19:12 +00:00
|
|
|
return new Location(world, x, y, z, yaw, pitch);
|
|
|
|
}
|
2010-12-27 02:11:52 +00:00
|
|
|
}
|