/* * Licensed to the Apache Software Foundation (ASF) under one or more * contributor license agreements. See the NOTICE file distributed with * this work for additional information regarding copyright ownership. * The ASF licenses this file to You under the Apache License, Version 2.0 * (the "License"); you may not use this file except in compliance with * the License. You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ /** * @author Denis M. Kishenko * @version $Revision$ */ package java.awt; import java.awt.geom.Point2D; import java.io.Serializable; /** * The Point class represents a point location with coordinates X, Y in current * coordinate system. * * @since Android 1.0 */ public class Point extends Point2D implements Serializable { /** * The Constant serialVersionUID. */ private static final long serialVersionUID = -5276940640259749850L; /** * The X coordinate of Point. */ public int x; /** * The Y coordinate of Point. */ public int y; /** * Instantiates a new point with (0, O) coordinates, the origin of * coordinate system. */ public Point() { setLocation(0, 0); } /** * Instantiates a new point with (x, y) coordinates. * * @param x * the X coordinate of Point. * @param y * the Y coordinate of Point. */ public Point(int x, int y) { setLocation(x, y); } /** * Instantiates a new point, giving it the same location as the parameter p. * * @param p * the Point object giving the coordinates of the new point. */ public Point(Point p) { setLocation(p.x, p.y); } /** * Compares current Point with the specified object. * * @param obj * the Object to be compared. * @return true, if the Object being compared is a Point whose coordinates * are equal to the coordinates of this Point, false otherwise. * @see java.awt.geom.Point2D#equals(Object) */ @Override public boolean equals(Object obj) { if (obj == this) { return true; } if (obj instanceof Point) { Point p = (Point)obj; return x == p.x && y == p.y; } return false; } /** * Returns string representation of the current Point object. * * @return a string representation of the current Point object. */ @Override public String toString() { return getClass().getName() + "[x=" + x + ",y=" + y + "]"; //$NON-NLS-1$ //$NON-NLS-2$ //$NON-NLS-3$ } /** * Gets X coordinate of Point as a double. * * @return X coordinate of the point as a double. * @see java.awt.geom.Point2D#getX() */ @Override public double getX() { return x; } /** * Gets Y coordinate of Point as a double. * * @return Y coordinate of the point as a double. * @see java.awt.geom.Point2D#getY() */ @Override public double getY() { return y; } /** * Gets the location of the Point as a new Point object. * * @return a copy of the Point. */ public Point getLocation() { return new Point(x, y); } /** * Sets the location of the Point to the same coordinates as p. * * @param p * the Point that gives the new location. */ public void setLocation(Point p) { setLocation(p.x, p.y); } /** * Sets the location of the Point to the coordinates X, Y. * * @param x * the X coordinate of the Point's new location. * @param y * the Y coordinate of the Point's new location. */ public void setLocation(int x, int y) { this.x = x; this.y = y; } /** * Sets the location of Point to the specified double coordinates. * * @param x * the X the Point's new location. * @param y * the Y the Point's new location. * @see java.awt.geom.Point2D#setLocation(double, double) */ @Override public void setLocation(double x, double y) { x = x < Integer.MIN_VALUE ? Integer.MIN_VALUE : x > Integer.MAX_VALUE ? Integer.MAX_VALUE : x; y = y < Integer.MIN_VALUE ? Integer.MIN_VALUE : y > Integer.MAX_VALUE ? Integer.MAX_VALUE : y; setLocation((int)Math.round(x), (int)Math.round(y)); } /** * Moves the Point to the specified (x, y) location. * * @param x * the X coordinate of the new location. * @param y * the Y coordinate of the new location. */ public void move(int x, int y) { setLocation(x, y); } /** * Translates current Point moving it from the position (x, y) to the new * position given by (x+dx, x+dy) coordinates. * * @param dx * the horizontal delta - the Point is moved to this distance * along X axis. * @param dy * the vertical delta - the Point is moved to this distance along * Y axis. */ public void translate(int dx, int dy) { x += dx; y += dy; } }