Package org.djutils.draw.point
Class Point3d
- java.lang.Object
- 
- org.djutils.draw.point.Point3d
 
- 
- All Implemented Interfaces:
- Serializable,- Drawable<Point3d,Space3d>,- Drawable3d,- Point<Point3d,Space3d>
 - Direct Known Subclasses:
- OrientedPoint3d,- Ray3d
 
 public class Point3d extends Object implements Drawable3d, Point<Point3d,Space3d> A Point3d is an immutable point with an x, y, and z coordinate, stored with double precision. It differs from many Point implementations by being immutable.Copyright (c) 2020-2021 Delft University of Technology, PO Box 5, 2600 AA, Delft, the Netherlands. All rights reserved. 
 BSD-style license. See DJUTILS License.- Author:
- Alexander Verbraeck, Peter Knoppers
- See Also:
- Serialized Form
 
- 
- 
Constructor SummaryConstructors Constructor Description Point3d(double[] xyz)Create a new Point with just an x, y and z coordinate, stored with double precision.Point3d(double x, double y, double z)Create a new Point with just an x, y and z coordinate, stored with double precision.Point3d(Point2D point, double z)Create an immutable point with just three values, x, y and z, stored with double precision from an AWT Point2D and z.Point3d(Point2d point, double z)Create an immutable point with just three values, x, y and z, stored with double precision from a Point2d and z.
 - 
Method SummaryAll Methods Instance Methods Concrete Methods Modifier and Type Method Description Point3dabs()Return a new Point with absolute coordinate values.Point3dclosestPointOnLine(Ray3d ray)Closest point on a ray.Point3dclosestPointOnLine(Point3d linePoint1, Point3d linePoint2)Project a point on a line.Point3dclosestPointOnSegment(Point3d segmentPoint1, Point3d segmentPoint2)Project a point on a line segment.doubledistance(Point3d otherPoint)Return the distance to another point.doubledistanceSquared(Point3d otherPoint)Return the squared distance between this point and the provided point.booleanepsilonEquals(Point3d other, double epsilon)A comparison with another point that returns true of each of the coordinates is less than epsilon apart.booleanequals(Object obj)Bounds3dgetBounds()Retrieve the bounding box of the object.Iterator<? extends Point3d>getPoints()Retrieve, or generate all points that make up the object.doublegetX()Return the x-coordinate.doublegetY()Return the y-coordinate.doublegetZ()Return the z-coordinate.inthashCode()(package private) doublehorizontalDirection()Return the direction of the point in radians with respect to the origin, ignoring the z-coordinate.(package private) doublehorizontalDirection(Point3d point)Return the direction to another point, in radians, ignoring the z-coordinate.(package private) doublehorizontalDistance(Point3d point)Return the Euclidean distance between this point and the provided point, ignoring the z-coordinate.(package private) doublehorizontalDistanceSquared(Point3d point)Return the squared distance between the coordinates of this point and the provided point, ignoring the z-coordinate.Point3dinterpolate(Point3d point, double fraction)Interpolate towards another Point with a fraction.Point3dneg()Return a new Point with negated coordinate values.Point3dnormalize()Return a new Point with a distance of 1 to the origin.Point2dproject()Project the object onto the z=0 plane.Point3dscale(double factor)Return a new Point with the coordinates of this point scaled by the provided factor.intsize()Retrieve the number of points that make up the object.StringtoString()Return a string representation of the point.StringtoString(int fractionDigits)Return a string representation of the point with a certain number of fraction digits for the coordinates.Point3dtranslate(double dx, double dy)Return a new Point with a translation by the provided dx and dy.Point3dtranslate(double dx, double dy, double dz)Return a new Point3d with a translation by the provided dx, dy and dz.
 
- 
- 
- 
Constructor Detail- 
Point3dpublic Point3d(double x, double y, double z)Create a new Point with just an x, y and z coordinate, stored with double precision.- Parameters:
- x- double; the x coordinate
- y- double; the y coordinate
- z- double; the z coordinate
- Throws:
- IllegalArgumentException- when x or y is NaN
 
 - 
Point3dpublic Point3d(double[] xyz) throws NullPointerException, IllegalArgumentExceptionCreate a new Point with just an x, y and z coordinate, stored with double precision.- Parameters:
- xyz- double[]; the x, y and z coordinate
- Throws:
- NullPointerException- when xyz is null
- IllegalArgumentException- when the dimension of xyz is not 3, or a coordinate is NaN
 
 - 
Point3dpublic Point3d(Point2d point, double z) throws NullPointerException, IllegalArgumentException Create an immutable point with just three values, x, y and z, stored with double precision from a Point2d and z.- Parameters:
- point- Point2d; a Point2d
- z- double; the z coordinate
- Throws:
- NullPointerException- when point is null
- IllegalArgumentException- when z is NaN
 
 - 
Point3dpublic Point3d(Point2D point, double z) throws NullPointerException, IllegalArgumentException Create an immutable point with just three values, x, y and z, stored with double precision from an AWT Point2D and z.- Parameters:
- point- Point2D; an AWT Point2D
- z- double; the z coordinate
- Throws:
- NullPointerException- when point is null
- IllegalArgumentException- when point has a NaN coordinate, or z is NaN
 
 
- 
 - 
Method Detail- 
getXpublic final double getX() Return the x-coordinate. When the point is not in Cartesian space, a calculation to Cartesian space has to be made.
 - 
getYpublic final double getY() Return the y-coordinate. When the point is not in Cartesian space, a calculation to Cartesian space has to be made.
 - 
getZpublic final double getZ() Return the z-coordinate.- Returns:
- double; the z-coordinate
 
 - 
distanceSquaredpublic double distanceSquared(Point3d otherPoint) throws NullPointerException Return the squared distance between this point and the provided point.- Specified by:
- distanceSquaredin interface- Point<Point3d,Space3d>
- Parameters:
- otherPoint- P; the other point
- Returns:
- double; the squared distance between this point and the other point
- Throws:
- NullPointerException- when otherPoint is null
 
 - 
distancepublic double distance(Point3d otherPoint) throws NullPointerException Return the distance to another point.- Specified by:
- distancein interface- Point<Point3d,Space3d>
- Parameters:
- otherPoint- P; P the other point
- Returns:
- double; the distance (2d or 3d as applicable) to the other point
- Throws:
- NullPointerException
 
 - 
sizepublic int size() Retrieve the number of points that make up the object.
 - 
getPointspublic Iterator<? extends Point3d> getPoints() Retrieve, or generate all points that make up the object.
 - 
projectpublic Point2d project() throws DrawRuntimeException Project the object onto the z=0 plane.- Specified by:
- projectin interface- Drawable3d
- Returns:
- Drawable2d; the projected object
- Throws:
- DrawRuntimeException- when projecting onto the z=0 plane results in an invalid object. E.g. a Line3d that consists of points that all have the exact same x and y coordinates cannot be a line after projecting on the z=0 plane.
 
 - 
translatepublic Point3d translate(double dx, double dy) throws IllegalArgumentException Return a new Point with a translation by the provided dx and dy.- Parameters:
- dx- double; the horizontal translation
- dy- double; the vertical translation
- Returns:
- Point3D; a new point with the translated coordinates
- Throws:
- IllegalArgumentException- when dx, or dy is NaN
 
 - 
translatepublic Point3d translate(double dx, double dy, double dz) throws IllegalArgumentException Return a new Point3d with a translation by the provided dx, dy and dz.- Parameters:
- dx- double; the x translation
- dy- double; the y translation
- dz- double; the z translation
- Returns:
- Point3d; a new point with the translated coordinates
- Throws:
- IllegalArgumentException- when dx, dy, or dz is NaN
 
 - 
scalepublic Point3d scale(double factor) throws IllegalArgumentException Return a new Point with the coordinates of this point scaled by the provided factor.- Specified by:
- scalein interface- Point<Point3d,Space3d>
- Parameters:
- factor- double; the scale factor
- Returns:
- Point; a new point with the coordinates of this point scaled by the provided factor
- Throws:
- IllegalArgumentException- when factor is NaN
 
 - 
negpublic Point3d neg() Return a new Point with negated coordinate values.
 - 
abspublic Point3d abs() Return a new Point with absolute coordinate values.
 - 
normalizepublic Point3d normalize() throws DrawRuntimeException Return a new Point with a distance of 1 to the origin.- Specified by:
- normalizein interface- Point<Point3d,Space3d>
- Returns:
- Point; the normalized point
- Throws:
- DrawRuntimeException- when point is the origin, and no length can be established for scaling
 
 - 
interpolatepublic Point3d interpolate(Point3d point, double fraction) Interpolate towards another Point with a fraction. It is allowed for fraction to be less than zero or larger than 1. In that case the interpolation turns into an extrapolation.- Specified by:
- interpolatein interface- Point<Point3d,Space3d>
- Parameters:
- point- P; the other point
- fraction- double; the factor for interpolation towards the other point. When <code>fraction</code> is between 0 and 1, it is an interpolation, otherwise an extrapolation. If- fractionis 0;- thisPoint is returned; if- fractionis 1, the other- pointis returned
- Returns:
- P; the point that is fractionaway on the line between this point and the other point
 
 - 
epsilonEqualspublic boolean epsilonEquals(Point3d other, double epsilon) A comparison with another point that returns true of each of the coordinates is less than epsilon apart.- Specified by:
- epsilonEqualsin interface- Point<Point3d,Space3d>
- Parameters:
- other- P; the point to compare with
- epsilon- double; the upper bound of difference for one of the coordinates
- Returns:
- boolean; true if both x, y and z (if a Point3d) are less than epsilon apart, otherwise false
 
 - 
getBoundspublic Bounds3d getBounds() Retrieve the bounding box of the object.- Specified by:
- getBoundsin interface- Drawable3d
- Returns:
- Bounds3d; the bounding box of the object
 
 - 
closestPointOnSegmentpublic final Point3d closestPointOnSegment(Point3d segmentPoint1, Point3d segmentPoint2) Project a point on a line segment. If the the projected points lies outside the line segment, the nearest end point of the line segment is returned. Otherwise the returned point lies between the end points of the line segment.
 Adapted from example code provided by Paul Bourke.- Specified by:
- closestPointOnSegmentin interface- Point<Point3d,Space3d>
- Parameters:
- segmentPoint1- P; start of line segment
- segmentPoint2- P; end of line segment
- Returns:
- P; either segmentPoint1, or segmentPoint2 or a new Point2d that lies somewhere in between those two.
 
 - 
closestPointOnLinepublic final Point3d closestPointOnLine(Point3d linePoint1, Point3d linePoint2) throws DrawRuntimeException Project a point on a line.
 Adapted from example code provided by Paul Bourke.- Specified by:
- closestPointOnLinein interface- Point<Point3d,Space3d>
- Parameters:
- linePoint1- P; point on the line
- linePoint2- P; another point on the line
- Returns:
- Point2d; a point on the line that goes through linePoint1 and linePoint2
- Throws:
- DrawRuntimeException- when linePoint1 is at the same location as linePoint2
 
 - 
closestPointOnLinepublic final Point3d closestPointOnLine(Ray3d ray) Closest point on a ray.- Parameters:
- ray- Ray3d; a point through which the line passes in the direction
- Returns:
- Point3d; the point on the line that is closest to this
 
 - 
horizontalDirectionfinal double horizontalDirection() Return the direction of the point in radians with respect to the origin, ignoring the z-coordinate.- Returns:
- double; the direction of the projection of the point in the x-y plane with respect to the origin, in radians
 
 - 
horizontalDirectionfinal double horizontalDirection(Point3d point) throws NullPointerException Return the direction to another point, in radians, ignoring the z-coordinate.- Parameters:
- point- Point3d; the other point
- Returns:
- double; the direction of the projection of the point in the x-y plane to another point, in radians
- Throws:
- NullPointerException- when- pointis null
 
 - 
horizontalDistanceSquaredfinal double horizontalDistanceSquared(Point3d point) Return the squared distance between the coordinates of this point and the provided point, ignoring the z-coordinate.- Parameters:
- point- Point3d; the other point
- Returns:
- double; the squared distance between this point and the other point, ignoring the z-coordinate
- Throws:
- NullPointerException- when point is null
 
 - 
horizontalDistancefinal double horizontalDistance(Point3d point) Return the Euclidean distance between this point and the provided point, ignoring the z-coordinate.- Parameters:
- point- Point3d; the other point
- Returns:
- double; the Euclidean distance between this point and the other point, ignoring the z-coordinate
- Throws:
- NullPointerException- when point is null
 
 - 
toStringpublic String toString() Return a string representation of the point.
 - 
toStringpublic String toString(int fractionDigits) Return a string representation of the point with a certain number of fraction digits for the coordinates.
 
- 
 
-