2021-09-18 21:51:29 +02:00
|
|
|
package net.knarcraft.stargate.container;
|
2021-02-07 03:37:25 +01:00
|
|
|
|
|
|
|
/**
|
2021-02-16 21:58:31 +01:00
|
|
|
* This stores a block location as a vector relative to a position
|
2021-02-12 00:26:47 +01:00
|
|
|
*
|
2021-02-16 21:58:31 +01:00
|
|
|
* <p>A relative block vector stores a vector relative to some origin. The origin in this plugin is usually the
|
2021-02-22 17:01:47 +01:00
|
|
|
* top-left block of a gate (top-left when looking at the side with the sign). The right is therefore the distance
|
|
|
|
* from the top-left corner towards the top-right corner. Depth is the distance from the top-left corner to the
|
|
|
|
* bottom-left corner. Distance is the distance outward from the gate.</p>
|
2021-02-07 03:37:25 +01:00
|
|
|
*/
|
|
|
|
public class RelativeBlockVector {
|
|
|
|
|
2021-09-09 15:25:08 +02:00
|
|
|
private final int right;
|
|
|
|
private final int depth;
|
|
|
|
private final int distance;
|
2021-02-07 03:37:25 +01:00
|
|
|
|
2021-10-08 18:23:42 +02:00
|
|
|
public enum Property {RIGHT, DEPTH, DISTANCE}
|
|
|
|
|
2021-02-12 00:26:47 +01:00
|
|
|
/**
|
|
|
|
* Instantiates a new relative block vector
|
2021-02-20 13:57:04 +01:00
|
|
|
*
|
|
|
|
* @param right <p>The distance to the right relative to the origin</p>
|
|
|
|
* @param depth <p>The distance downward relative to the origin</p>
|
2021-02-16 21:58:31 +01:00
|
|
|
* @param distance <p>The distance outward relative to the origin</p>
|
2021-02-12 00:26:47 +01:00
|
|
|
*/
|
2021-02-07 03:37:25 +01:00
|
|
|
public RelativeBlockVector(int right, int depth, int distance) {
|
|
|
|
this.right = right;
|
|
|
|
this.depth = depth;
|
|
|
|
this.distance = distance;
|
|
|
|
}
|
|
|
|
|
2021-10-08 18:23:42 +02:00
|
|
|
/**
|
|
|
|
* Adds a value to one of the properties of this relative block vector
|
|
|
|
*
|
2021-10-13 14:08:38 +02:00
|
|
|
* @param propertyToAddTo <p>The property to add to</p>
|
|
|
|
* @param valueToAdd <p>The value to add to the property (negative to move in the opposite direction)</p>
|
2021-10-08 18:23:42 +02:00
|
|
|
* @return <p>A new relative block vector with the property altered</p>
|
|
|
|
*/
|
|
|
|
public RelativeBlockVector addToVector(Property propertyToAddTo, int valueToAdd) {
|
|
|
|
switch (propertyToAddTo) {
|
|
|
|
case RIGHT:
|
|
|
|
return new RelativeBlockVector(this.right + valueToAdd, this.depth, this.distance);
|
|
|
|
case DEPTH:
|
|
|
|
return new RelativeBlockVector(this.right, this.depth + valueToAdd, this.distance);
|
|
|
|
case DISTANCE:
|
|
|
|
return new RelativeBlockVector(this.right, this.depth, this.distance + valueToAdd);
|
|
|
|
default:
|
|
|
|
throw new IllegalArgumentException("Invalid relative block vector property given");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Gets a relative block vector which is this inverted (pointing in the opposite direction)
|
|
|
|
*
|
|
|
|
* @return <p>This vector, but inverted</p>
|
|
|
|
*/
|
|
|
|
public RelativeBlockVector invert() {
|
|
|
|
return new RelativeBlockVector(-this.right, -this.depth, -this.distance);
|
|
|
|
}
|
|
|
|
|
2021-02-16 21:58:31 +01:00
|
|
|
/**
|
|
|
|
* Gets the distance to the right relative to the origin
|
2021-02-20 13:57:04 +01:00
|
|
|
*
|
2021-10-13 14:08:38 +02:00
|
|
|
* @return <p>The distance to the right relative to the origin</p>
|
2021-02-16 21:58:31 +01:00
|
|
|
*/
|
2021-02-07 03:37:25 +01:00
|
|
|
public int getRight() {
|
|
|
|
return right;
|
|
|
|
}
|
|
|
|
|
2021-02-16 21:58:31 +01:00
|
|
|
/**
|
|
|
|
* Gets the distance downward relative to the origin
|
2021-02-20 13:57:04 +01:00
|
|
|
*
|
2021-10-13 14:08:38 +02:00
|
|
|
* @return <p>The distance downward relative to the origin</p>
|
2021-02-16 21:58:31 +01:00
|
|
|
*/
|
2021-02-07 03:37:25 +01:00
|
|
|
public int getDepth() {
|
|
|
|
return depth;
|
|
|
|
}
|
|
|
|
|
2021-02-16 21:58:31 +01:00
|
|
|
/**
|
|
|
|
* Gets the distance outward relative to the origin
|
2021-02-20 13:57:04 +01:00
|
|
|
*
|
2021-10-13 14:08:38 +02:00
|
|
|
* @return <p>The distance outward relative to the origin</p>
|
2021-02-16 21:58:31 +01:00
|
|
|
*/
|
2021-02-07 03:37:25 +01:00
|
|
|
public int getDistance() {
|
|
|
|
return distance;
|
|
|
|
}
|
|
|
|
|
2021-02-22 15:49:44 +01:00
|
|
|
@Override
|
|
|
|
public String toString() {
|
2021-02-22 17:01:47 +01:00
|
|
|
return String.format("(right = %d, depth = %d, distance = %d)", right, depth, distance);
|
2021-02-22 15:49:44 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public boolean equals(Object other) {
|
2021-02-22 17:01:47 +01:00
|
|
|
if (other == this) {
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
if (other == null || this.getClass() != other.getClass()) {
|
2021-02-22 15:49:44 +01:00
|
|
|
return false;
|
|
|
|
}
|
|
|
|
RelativeBlockVector otherVector = (RelativeBlockVector) other;
|
|
|
|
return this.right == otherVector.right && this.depth == otherVector.depth &&
|
|
|
|
this.distance == otherVector.distance;
|
|
|
|
}
|
|
|
|
|
2021-02-07 03:37:25 +01:00
|
|
|
}
|