- /*
- * @(#)Point.java 1.28 01/02/09
- *
- * Copyright 1995-2001 Sun Microsystems, Inc. All Rights Reserved.
- *
- * This software is the proprietary information of Sun Microsystems, Inc.
- * Use is subject to license terms.
- *
- */
-
- package java.awt;
-
- import java.awt.geom.Point2D;
-
- /**
- * A point representing a location in (x, y) coordinate space, specified
- * in integer precision.
- *
- * @version 1.28, 02/09/01
- * @author Sami Shaio
- * @since JDK1.0
- */
- public class Point extends Point2D implements java.io.Serializable {
- /**
- * The <i>x</i> coordinate.
- * If no <i>x</i> coordinate is set it will default to '0'.
- *
- * @serial
- * @see #getLocation()
- * @see #move(int, int)
- */
- public int x;
-
- /**
- * The <i>y</i> coordinate.
- * If no <i>y</i> coordinate is set it will default to '0'.
- *
- * @serial
- * @see #getLocation()
- * @see #move(int, int)
- */
- public int y;
-
- /*
- * JDK 1.1 serialVersionUID
- */
- private static final long serialVersionUID = -5276940640259749850L;
-
- /**
- * Constructs and initializes a point at the origin
- * (0, 0) of the coordinate space.
- * @since JDK1.1
- */
- public Point() {
- this(0, 0);
- }
-
- /**
- * Constructs and initializes a point with the same location as
- * the specified <code>Point</code> object.
- * @param p a point.
- * @since JDK1.1
- */
- public Point(Point p) {
- this(p.x, p.y);
- }
-
- /**
- * Constructs and initializes a point at the specified
- * (<i>x</i>, <i>y</i>) location in the coordinate space.
- * @param x the <i>x</i> coordinate.
- * @param y the <i>y</i> coordinate.
- */
- public Point(int x, int y) {
- this.x = x;
- this.y = y;
- }
-
- /**
- * Returns the X coordinate of the point in double precision.
- */
- public double getX() {
- return x;
- }
-
- /**
- * Returns the Y coordinate of the point in double precision.
- */
- public double getY() {
- return y;
- }
-
- /**
- * Returns the location of this point.
- * This method is included for completeness, to parallel the
- * <code>getLocation</code> method of <code>Component</code>.
- * @return a copy of this point, at the same location.
- * @see java.awt.Component#getLocation
- * @see java.awt.Point#setLocation(java.awt.Point)
- * @see java.awt.Point#setLocation(int, int)
- * @since JDK1.1
- */
- public Point getLocation() {
- return new Point(x, y);
- }
-
- /**
- * Sets the location of the point to the specificed location.
- * This method is included for completeness, to parallel the
- * <code>setLocation</code> method of <code>Component</code>.
- * @param p a point, the new location for this point.
- * @see java.awt.Component#setLocation(java.awt.Point)
- * @see java.awt.Point#getLocation
- * @since JDK1.1
- */
- public void setLocation(Point p) {
- setLocation(p.x, p.y);
- }
-
- /**
- * Changes the point to have the specificed location.
- * <p>
- * This method is included for completeness, to parallel the
- * <code>setLocation</code> method of <code>Component</code>.
- * Its behavior is identical with <code>move(int, int)</code>.
- * @param x the <i>x</i> coordinate of the new location.
- * @param y the <i>y</i> coordinate of the new location.
- * @see java.awt.Component#setLocation(int, int)
- * @see java.awt.Point#getLocation
- * @see java.awt.Point#move(int, int)
- * @since JDK1.1
- */
- public void setLocation(int x, int y) {
- move(x, y);
- }
-
- /**
- * Sets the location of this point to the specified float coordinates.
- */
- public void setLocation(double x, double y) {
- this.x = (int) Math.round(x);
- this.y = (int) Math.round(y);
- }
-
- /**
- * Moves this point to the specificed location in the
- * (<i>x</i>, <i>y</i>) coordinate plane. This method
- * is identical with <code>setLocation(int, int)</code>.
- * @param x the <i>x</i> coordinate of the new location.
- * @param y the <i>y</i> coordinate of the new location.
- * @see java.awt.Component#setLocation(int, int)
- */
- public void move(int x, int y) {
- this.x = x;
- this.y = y;
- }
-
- /**
- * Translates this point, at location (<i>x</i>, <i>y</i>),
- * by <code>dx</code> along the <i>x</i> axis and <code>dy</code>
- * along the <i>y</i> axis so that it now represents the point
- * (<code>x</code> <code>+</code> <code>dx</code>,
- * <code>y</code> <code>+</code> <code>dy</code>).
- * @param x the distance to move this point
- * along the <i>x</i> axis.
- * @param y the distance to move this point
- * along the <i>y</i> axis.
- */
- public void translate(int x, int y) {
- this.x += x;
- this.y += y;
- }
-
- /**
- * Determines whether an instance of <code>Point2D</code> is equal
- * to this point. 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 point.
- * @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.
- */
- public boolean equals(Object obj) {
- if (obj instanceof Point) {
- Point pt = (Point)obj;
- return (x == pt.x) && (y == pt.y);
- }
- return super.equals(obj);
- }
-
- /**
- * Returns a string representation of this point and its location
- * in the (<i>x</i>, <i>y</i>) coordinate space. This method is
- * intended to be used only for debugging purposes, and the content
- * and format of the returned string may vary between implementations.
- * The returned string may be empty but may not be <code>null</code>.
- *
- * @return a string representation of this point.
- */
- public String toString() {
- return getClass().getName() + "[x=" + x + ",y=" + y + "]";
- }
- }