本文整理匯總了Java中org.bukkit.Location.toVector方法的典型用法代碼示例。如果您正苦於以下問題:Java Location.toVector方法的具體用法?Java Location.toVector怎麽用?Java Location.toVector使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類org.bukkit.Location
的用法示例。
在下文中一共展示了Location.toVector方法的4個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。
示例1: Region
import org.bukkit.Location; //導入方法依賴的package包/類
public Region(Location pointA, Location pointB) {
Validate.isTrue(pointA.getWorld().equals(pointB.getWorld()), "Two worlds are different.");
double minX = Math.min(pointA.getBlockX(), pointB.getBlockX());
double maxX = Math.max(pointA.getBlockX(), pointB.getBlockX()) + 1;
double minY = Math.min(pointA.getBlockY(), pointB.getBlockY());
double maxY = Math.max(pointA.getBlockY(), pointB.getBlockY());
double minZ = Math.min(pointA.getBlockZ(), pointB.getBlockZ());
double maxZ = Math.max(pointA.getBlockZ(), pointB.getBlockZ()) + 1;
pointA.setX(minX);
pointA.setY(minY);
pointA.setZ(minZ);
pointB.setX(maxX);
pointB.setY(maxY);
pointB.setZ(maxZ);
this.world = pointA.getWorld().getName();
this.min = pointA.toVector();
this.max = pointB.toVector();
}
示例2: getYawBetween
import org.bukkit.Location; //導入方法依賴的package包/類
public static double getYawBetween(Location from, Location to) {
final Location change = from.clone();
final Vector start = change.toVector();
final Vector target = to.toVector();
// Get the difference between the two locations and set this as the
// direction (the direct line from location to location).
change.setDirection(target.subtract(start));
return change.getYaw();
}
示例3: shouldReload
import org.bukkit.Location; //導入方法依賴的package包/類
private boolean shouldReload(Location from, Location to, Player player) {
if (from.getWorld() != to.getWorld()) {
return true;
}
Vector fvec = from.toVector();
Vector tvec = to.toVector();
double distance = fvec.distance(tvec);
if (distance < 6) {
return false;
}
return true;
}
示例4: run
import org.bukkit.Location; //導入方法依賴的package包/類
@Override
public void run()
{
final Location playerLocation = player.getLocation();
// Checks if the player is still on the line
Vector position = playerLocation.toVector();
Vector origin = getStart().toVector();
Vector director = yodel.getAngleVector();
double k;
if (isZero(origin)) origin = getEnd().toVector();
try
{
k = director.getX() * (position.getX() - origin.getX())
+ director.getY() * (position.getY() - origin.getY())
+ director.getZ() * (position.getZ() - origin.getZ());
k /= NumberConversions.square(director.getX())
+ NumberConversions.square(director.getY())
+ NumberConversions.square(director.getZ());
}
catch (ArithmeticException e)
{
this.hub.getLogger().log(Level.SEVERE, "Division by zero while checking route on yodel, remains unfixed", e);
return;
}
Vector projection = origin.add(director.multiply(k));
if (projection.distanceSquared(position) > 4)
{
player.teleport(projection.toLocation(playerLocation.getWorld()).setDirection(playerLocation.getDirection()));
}
// Updates the velocity
player.setVelocity(velocityStep);
player.setFallDistance(0);
// Checks if the line is finished (either we are on the finish zone, or out of the path if for some
// reason the landing zone was not entered)
if (playerLocation.distanceSquared(getEnd()) < 6
|| playerLocation.distanceSquared(getStart()) > yodel.getLength() + 10)
{
this.yodel.stop(player);
}
}