FileDocCategorySizeDatePackage
Point2D.javaAPI DocJava SE 5 API10442Fri Aug 26 14:56:52 BST 2005java.awt.geom

Point2D.java

/*
 * @(#)Point2D.java	1.18 03/12/19
 *
 * Copyright 2004 Sun Microsystems, Inc. All rights reserved.
 * SUN PROPRIETARY/CONFIDENTIAL. Use is subject to license terms.
 */

package java.awt.geom;

/**
 * The <code>Point2D</code> class defines a point representing a location
 * in (x, y) coordinate space.
 * <p>
 * This class is only the abstract superclass for all objects that
 * store a 2D coordinate.
 * The actual storage representation of the coordinates is left to
 * the subclass.
 *
 * @version 	1.18, 12/19/03
 * @author	Jim Graham
 */
public abstract class Point2D implements Cloneable {
    /**
     * The <code>Float</code> class defines a point specified in float
     * precision.
     */
    public static class Float extends Point2D {
	/**
	 * The X coordinate of this <code>Point2D</code>.
	 * @since 1.2
	 */
	public float x;

	/**
	 * The Y coordinate of this <code>Point2D</code>.
	 * @since 1.2
	 */
	public float y;

	/**
	 * Constructs and initializes a <code>Point2D</code> with
         * coordinates (0, 0).
	 * @since 1.2
	 */
	public Float() {
	}

	/**
	 * Constructs and initializes a <code>Point2D</code> with 
         * the specified coordinates.
         * @param x, y the coordinates to which to set the newly
         * constructed <code>Point2D</code>
	 * @since 1.2
	 */
	public Float(float x, float y) {
	    this.x = x;
	    this.y = y;
	}

	/**
	 * Returns the X coordinate of this <code>Point2D</code> in 
         * <code>double</code> precision.
         * @return the X coordinate of this <code>Point2D</code>.
	 * @since 1.2
	 */
	public double getX() {
	    return (double) x;
	}

	/**
	 * Returns the Y coordinate of this <code>Point2D</code> in 
         * <code>double</code> precision.
         * @return the Y coordinate of this <code>Point2D</code>.
	 * @since 1.2
	 */
	public double getY() {
	    return (double) y;
	}

	/**
	 * Sets the location of this <code>Point2D</code> to the 
         * specified <code>double</code> coordinates.
         * @param x, y the coordinates to which to set this
         * <code>Point2D</code>
	 * @since 1.2
	 */
	public void setLocation(double x, double y) {
	    this.x = (float) x;
	    this.y = (float) y;
	}

	/**
	 * Sets the location of this <code>Point2D</code> to the 
         * specified <code>float</code> coordinates.
         * @param x, y the coordinates to which to set this
         * <code>Point2D</code>
	 * @since 1.2
	 */
	public void setLocation(float x, float y) {
	    this.x = x;
	    this.y = y;
	}

	/**
	 * Returns a <code>String</code> that represents the value 
         * of this <code>Point2D</code>.
         * @return a string representation of this <code>Point2D</code>.
	 * @since 1.2
	 */
	public String toString() {
	    return "Point2D.Float["+x+", "+y+"]";
	}
    }

    /**
     * The <code>Double</code> class defines a point specified in 
     * <code>double</code> precision.
     */
    public static class Double extends Point2D {
	/**
	 * The X coordinate of this <code>Point2D</code>.
	 * @since 1.2
	 */
	public double x;

	/**
	 * The Y coordinate of this <code>Point2D</code>.
	 * @since 1.2
	 */
	public double y;

	/**
	 * Constructs and initializes a <code>Point2D</code> with
         * coordinates (0, 0).
	 * @since 1.2
	 */
	public Double() {
	}

	/**
	 * Constructs and initializes a <code>Point2D</code> with the
         * specified coordinates.
         * @param x, y the coordinates to which to set the newly
         * constructed <code>Point2D</code>
	 * @since 1.2
	 */
	public Double(double x, double y) {
	    this.x = x;
	    this.y = y;
	}

	/**
	 * Returns the X coordinate of this <code>Point2D</code> 
         * in <code>double</code> precision.
         * @return the X coordinate of this <code>Point2D</code>.
	 * @since 1.2
	 */
	public double getX() {
	    return x;
	}

	/**
	 * Returns the Y coordinate of this <code>Point2D</code> in 
         * <code>double</code> precision.
         * @return the Y coordinate of this <code>Point2D</code>.
	 * @since 1.2
	 */
	public double getY() {
	    return y;
	}

	/**
	 * Sets the location of this <code>Point2D</code> to the 
         * specified <code>double</code> coordinates.
         * @param x, y the coordinates to which to set this
         * <code>Point2D</code>
	 * @since 1.2
	 */
	public void setLocation(double x, double y) {
	    this.x = x;
	    this.y = y;
	}

	/**
	 * Returns a <code>String</code> that represents the value 
         * of this <code>Point2D</code>.
         * @return a string representation of this <code>Point2D</code>.
	 * @since 1.2
	 */
	public String toString() {
	    return "Point2D.Double["+x+", "+y+"]";
	}
    }

    /**
     * This is an abstract class that cannot be instantiated directly.
     * Type-specific implementation subclasses are available for
     * instantiation and provide a number of formats for storing
     * the information necessary to satisfy the various accessor
     * methods below.
     *
     * @see java.awt.geom.Point2D.Float
     * @see java.awt.geom.Point2D.Double
     * @see java.awt.Point
     */
    protected Point2D() {
    }

    /**
     * Returns the X coordinate of this <code>Point2D</code> in 
     * <code>double</code> precision.
     * @return the X coordinate of this <code>Point2D</code>.
     * @since 1.2
     */
    public abstract double getX();

    /**
     * Returns the Y coordinate of this <code>Point2D</code> in 
     * <code>double</code> precision.
     * @return the Y coordinate of this <code>Point2D</code>. 
     * @since 1.2
     */
    public abstract double getY();

    /**
     * Sets the location of this <code>Point2D</code> to the 
     * specified <code>double</code> coordinates.
     * @param x, y the coordinates of this <code>Point2D</code>
     * @since 1.2
     */
    public abstract void setLocation(double x, double y);

    /**
     * Sets the location of this <code>Point2D</code> to the same
     * coordinates as the specified <code>Point2D</code> object.
     * @param p the specified <code>Point2D</code> the which to set
     * this <code>Point2D</code>
     * @since 1.2
     */
    public void setLocation(Point2D p) {
	setLocation(p.getX(), p.getY());
    }

    /**
     * Returns the square of the distance between two points.
     * @param X1, Y1 the coordinates of the first point
     * @param X2, Y2 the coordinates of the second point
     * @return the square of the distance between the two
     * sets of specified coordinates.
     */
    public static double distanceSq(double X1, double Y1,
				    double X2, double Y2) {
	X1 -= X2;
	Y1 -= Y2;
	return (X1 * X1 + Y1 * Y1);
    }

    /**
     * Returns the distance between two points.
     * @param X1, Y1 the coordinates of the first point
     * @param X2, Y2 the coordinates of the second point
     * @return the distance between the two sets of specified
     * coordinates.
     */
    public static double distance(double X1, double Y1,
				  double X2, double Y2) {
	X1 -= X2;
	Y1 -= Y2;
	return Math.sqrt(X1 * X1 + Y1 * Y1);
    }

    /**
     * Returns the square of the distance from this 
     * <code>Point2D</code> to a specified point.
     * @param PX, PY the coordinates of the other point
     * @return the square of the distance between this
     * <code>Point2D</code> and the specified point.
     */
    public double distanceSq(double PX, double PY) {
	PX -= getX();
	PY -= getY();
	return (PX * PX + PY * PY);
    }

    /**
     * Returns the square of the distance from this 
     * <code>Point2D</code> to a specified <code>Point2D</code>.
     * @param pt the specified <code>Point2D</code>
     * @return the square of the distance between this
     * <code>Point2D</code> to a specified <code>Point2D</code>.
     */
    public double distanceSq(Point2D pt) {
	double PX = pt.getX() - this.getX();
	double PY = pt.getY() - this.getY();
	return (PX * PX + PY * PY);
    }

    /**
     * Returns the distance from this <code>Point2D</code> to 
     * a specified point.
     * @param PX, PY the coordinates of the specified
     * <code>Point2D</code>
     * @return the distance between this <code>Point2D</code>
     * and a specified point.
     */
    public double distance(double PX, double PY) {
	PX -= getX();
	PY -= getY();
	return Math.sqrt(PX * PX + PY * PY);
    }

    /**
     * Returns the distance from this <code>Point2D</code> to a
     * specified <code>Point2D</code>.
     * @param pt the specified <code>Point2D</code>
     * @return the distance between this <code>Point2D</code> and
     * the specified <code>Point2D</code>.
     */
    public double distance(Point2D pt) {
	double PX = pt.getX() - this.getX();
	double PY = pt.getY() - this.getY();
	return Math.sqrt(PX * PX + PY * PY);
    }

    /**
     * Creates a new object of the same class and with the
     * same contents as this object.
     * @return     a clone of this instance.
     * @exception  OutOfMemoryError            if there is not enough memory.
     * @see        java.lang.Cloneable
     * @since      1.2
     */
    public Object clone() {
	try {
	    return super.clone();
	} catch (CloneNotSupportedException e) {
	    // this shouldn't happen, since we are Cloneable
	    throw new InternalError();
	}
    }

    /**
     * Returns the hashcode for this <code>Point2D</code>.
     * @return      a hash code for this <code>Point2D</code>.
     */
    public int hashCode() {
	long bits = java.lang.Double.doubleToLongBits(getX());
	bits ^= java.lang.Double.doubleToLongBits(getY()) * 31;
	return (((int) bits) ^ ((int) (bits >> 32)));
    }

    /**
     * Determines whether or not two points are equal. Two instances of
     * <code>Point2D</code> are equal if the values of their 
     * <code>x</code> and <code>y</code> member fields, representing
     * their position in the coordinate space, are the same.
     * @param obj an object to be compared with this <code>Point2D</code>
     * @return <code>true</code> if the object to be compared is
     *         an instance of <code>Point2D</code> and has
     *         the same values; <code>false</code> otherwise.
     * @since 1.2
     */
    public boolean equals(Object obj) {
	if (obj instanceof Point2D) {
	    Point2D p2d = (Point2D) obj;
	    return (getX() == p2d.getX()) && (getY() == p2d.getY());
	}
	return super.equals(obj);
    }
}