/*
* Sun Public License Notice
*
* The contents of this file are subject to the Sun Public License
* Version 1.0 (the "License"). You may not use this file except in
* compliance with the License. A copy of the License is available at
* http://www.sun.com/
*
* The Original Code is NetBeans. The Initial Developer of the Original
* Code is Sun Microsystems, Inc. Portions Copyright 1997-2000 Sun
* Microsystems, Inc. All Rights Reserved.
*/
package org.netbeans.lib.awtextra;
import java.awt.Dimension ;
import java.awt.Point ;
/** An object that encapsulates position and (optionally) size for
* Absolute positioning of components.
*
* @see AbsoluteLayout
* @version 1.01, Aug 19, 1998
*/
public class AbsoluteConstraints implements java.io.Serializable {
/** generated Serialized Version UID */
static final long serialVersionUID = 5261460716622152494L;
/** The X position of the component */
public int x;
/** The Y position of the component */
public int y;
/** The width of the component or -1 if the component's preferred width should be used */
public int width = -1;
/** The height of the component or -1 if the component's preferred height should be used */
public int height = -1;
/** Creates a new AbsoluteConstraints for specified position.
* @param pos The position to be represented by this AbsoluteConstraints
*/
public AbsoluteConstraints(Point pos) {
this (pos.x, pos.y);
}
/** Creates a new AbsoluteConstraints for specified position.
* @param x The X position to be represented by this AbsoluteConstraints
* @param y The Y position to be represented by this AbsoluteConstraints
*/
public AbsoluteConstraints(int x, int y) {
this.x = x;
this.y = y;
}
/** Creates a new AbsoluteConstraints for specified position and size.
* @param pos The position to be represented by this AbsoluteConstraints
* @param size The size to be represented by this AbsoluteConstraints or null
* if the component's preferred size should be used
*/
public AbsoluteConstraints(Point pos, Dimension size) {
this.x = pos.x;
this.y = pos.y;
if (size != null) {
this.width = size.width;
this.height = size.height;
}
}
/** Creates a new AbsoluteConstraints for specified position and size.
* @param x The X position to be represented by this AbsoluteConstraints
* @param y The Y position to be represented by this AbsoluteConstraints
* @param width The width to be represented by this AbsoluteConstraints or -1 if the
* component's preferred width should be used
* @param height The height to be represented by this AbsoluteConstraints or -1 if the
* component's preferred height should be used
*/
public AbsoluteConstraints(int x, int y, int width, int height) {
this.x = x;
this.y = y;
this.width = width;
this.height = height;
}
/** @return The X position represented by this AbsoluteConstraints */
public int getX () {
return x;
}
/** @return The Y position represented by this AbsoluteConstraints */
public int getY () {
return y;
}
/** @return The width represented by this AbsoluteConstraints or -1 if the
* component's preferred width should be used
*/
public int getWidth () {
return width;
}
/** @return The height represented by this AbsoluteConstraints or -1 if the
* component's preferred height should be used
*/
public int getHeight () {
return height;
}
public String toString () {
return super.toString () +" [x="+x+", y="+y+", width="+width+", height="+height+"]";
}
}