Interface Point<P extends Point<P>>

Type Parameters:
P - The point type
All Superinterfaces:
Drawable<P>, Serializable
All Known Implementing Classes:
DirectedPoint2d, DirectedPoint3d, OrientedPoint3d, Point2d, Point3d, Ray2d, Ray3d

public interface Point<P extends Point<P>> extends Drawable<P>, Serializable
Point is the interface for the Point2d and Point3d implementations, standardizing as many of the methods as possible.

Copyright (c) 2020-2024 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
  • Method Summary

    Modifier and Type
    Method
    Description
    abs()
    Return a new Point with absolute coordinate values.
    closestPointOnLine(P linePoint1, P linePoint2)
    Project a point on a line.
    closestPointOnSegment(P segmentPoint1, P segmentPoint2)
    Project a point on a line segment.
    double
    distance(P otherPoint)
    Return the distance to another point.
    double
    distanceSquared(P otherPoint)
    Return the squared distance between this point and the provided point.
    boolean
    epsilonEquals(P otherPoint, double epsilon)
    A comparison with another point that returns true of each of the coordinates is less than epsilon apart.
    double
    Return the x-coordinate.
    double
    Return the y-coordinate.
    interpolate(P otherPoint, double fraction)
    Interpolate towards another Point with a fraction.
    neg()
    Return a new Point with negated coordinate values.
    Return a new Point with a distance of 1 to the origin.
    scale(double factor)
    Return a new Point with the coordinates of this point scaled by the provided factor.

    Methods inherited from interface org.djutils.draw.Drawable

    getDimensions, getPointList, getPoints, size, toString, toString, toString, toString
  • Method Details

    • getX

      double getX()
      Return the x-coordinate. When the point is not in Cartesian space, a calculation to Cartesian space has to be made.
      Returns:
      double; the x-coordinate
    • getY

      double getY()
      Return the y-coordinate. When the point is not in Cartesian space, a calculation to Cartesian space has to be made.
      Returns:
      double; the y-coordinate
    • scale

      P scale(double factor) throws IllegalArgumentException
      Return a new Point with the coordinates of this point scaled by the provided factor.
      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
    • neg

      P neg()
      Return a new Point with negated coordinate values. If this is a DirectedPoint, dirY and dirZ are negated.
      Returns:
      Point; a new point with negated coordinate values
    • abs

      P abs()
      Return a new Point with absolute coordinate values. If this is a DirectedPoint, dirY and dirZ are copied unchanged.
      Returns:
      Point; a new point with absolute coordinate values
    • normalize

      P normalize() throws DrawRuntimeException
      Return a new Point with a distance of 1 to the origin.
      Returns:
      Point; the normalized point
      Throws:
      DrawRuntimeException - when point is the origin, and no length can be established for scaling
    • distance

      double distance(P otherPoint)
      Return the distance to another point.
      Parameters:
      otherPoint - P; P the other point
      Returns:
      double; the distance (2d or 3d as applicable) to the other point
    • distanceSquared

      double distanceSquared(P otherPoint) throws NullPointerException
      Return the squared distance between this point and the provided point.
      Parameters:
      otherPoint - P; the other point
      Returns:
      double; the squared distance between this point and the other point
      Throws:
      NullPointerException - when otherPoint is null
    • interpolate

      P interpolate(P otherPoint, 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.
      Parameters:
      otherPoint - 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 fraction is 0; this Point is returned; if fraction is 1, the other point is returned
      Returns:
      P; the point that is fraction away on the line between this point and the other point
      Throws:
      NullPointerException - when point is null
      IllegalArgumentException - when fraction is NaN
    • closestPointOnSegment

      P closestPointOnSegment(P segmentPoint1, P segmentPoint2) throws NullPointerException
      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.
      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.
      Throws:
      NullPointerException - when segmentPoint2, or segmentPoint2 is null
    • closestPointOnLine

      P closestPointOnLine(P linePoint1, P linePoint2) throws NullPointerException, DrawRuntimeException
      Project a point on a line.
      Adapted from example code provided by Paul Bourke.
      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:
      NullPointerException - when linePoint1 is null, or linePoint2 is null
      DrawRuntimeException - when linePoint1 is at the same location as linePoint2
    • epsilonEquals

      boolean epsilonEquals(P otherPoint, double epsilon) throws NullPointerException
      A comparison with another point that returns true of each of the coordinates is less than epsilon apart.
      Parameters:
      otherPoint - 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
      Throws:
      NullPointerException - when other is null