nextapp.echo2.app.FillImageBorder Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of ibis-echo2 Show documentation
Show all versions of ibis-echo2 Show documentation
Echo2 bundled with Echo2_Extras, Echo2_FileTransfer and echopointing and various improvements/bugfixes
/*
* This file is part of the Echo Web Application Framework (hereinafter "Echo").
* Copyright (C) 2002-2009 NextApp, Inc.
*
* Version: MPL 1.1/GPL 2.0/LGPL 2.1
*
* The contents of this file are subject to the Mozilla Public License Version
* 1.1 (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.mozilla.org/MPL/
*
* Software distributed under the License is distributed on an "AS IS" basis,
* WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License for
* the specific language governing rights and limitations under the License.
*
* Alternatively, the contents of this file may be used under the terms of
* either the GNU General Public License Version 2 or later (the "GPL"), or the
* GNU Lesser General Public License Version 2.1 or later (the "LGPL"), in which
* case the provisions of the GPL or the LGPL are applicable instead of those
* above. If you wish to allow use of your version of this file only under the
* terms of either the GPL or the LGPL, and not to allow others to use your
* version of this file under the terms of the MPL, indicate your decision by
* deleting the provisions above and replace them with the notice and other
* provisions required by the GPL or the LGPL. If you do not delete the
* provisions above, a recipient may use your version of this file under the
* terms of any one of the MPL, the GPL or the LGPL.
*/
package nextapp.echo2.app;
import java.io.Serializable;
/**
* A representation of a graphical border drawn using a series of
* eight FillImage
s. The eight images are used to describe
* the four corners and four sides of the border.
* The BorderInsets
property is used to describe the width and
* height of the border images, i.e. the inset to which the border images
* extend inward from the outer edges of the box.
* The ContentInsets
property is used to describe the inset of
* the content displayed within the border. If the content inset is less
* than the border inset, the content will be drawn above the border.
* The Color
property may be used in addition to or in lieu of
* setting FillImage
s. The color will be drawn behind
* the FillImage
s in the case where both are used.
*/
public class FillImageBorder
implements Serializable {
public static final int TOP_LEFT = 0;
public static final int TOP = 1;
public static final int TOP_RIGHT= 2;
public static final int LEFT = 3;
public static final int RIGHT = 4;
public static final int BOTTOM_LEFT= 5;
public static final int BOTTOM = 6;
public static final int BOTTOM_RIGHT = 7;
private Insets contentInsets, borderInsets;
private Color color;
private FillImage[] fillImages;
/**
* Creates a new FillImageBorder
.
*/
public FillImageBorder() {
super();
}
/**
* Creates a new FillImageBorder
with the specified color,
* border inset, and content inset.
*
* @param color the solid color background of the border
* @param borderInsets the border inset
* @param contentInsets the content inset
* @see #setBorderInsets(nextapp.echo2.app.Insets)
* @see #setContentInsets(nextapp.echo2.app.Insets)
* @see #setColor(nextapp.echo2.app.Color)
*/
public FillImageBorder(Color color, Insets borderInsets, Insets contentInsets) {
super();
this.color = color;
this.borderInsets = borderInsets;
this.contentInsets = contentInsets;
}
/**
* @see java.lang.Object#equals(java.lang.Object)
*/
public boolean equals(Object o) {
if (!(o instanceof FillImageBorder)) {
return false;
}
FillImageBorder that = (FillImageBorder) o;
if (!(this.color == that.color ||
(this.color != null && this.color.equals(that.color)))) {
return false;
}
if (!(this.borderInsets == that.borderInsets ||
(this.borderInsets != null && this.borderInsets.equals(that.borderInsets)))) {
return false;
}
if (!(this.contentInsets == that.contentInsets ||
(this.contentInsets != null && this.contentInsets.equals(that.contentInsets)))) {
return false;
}
if (this.fillImages != null || that.fillImages != null) {
if (this.fillImages == null || that.fillImages == null) {
return false;
}
for (int i = 0; i < fillImages.length; ++i) {
if (!(this.fillImages[i] == that.fillImages[i] ||
(this.fillImages[i] != null && this.fillImages[i].equals(that.fillImages[i])))) {
return false;
}
}
}
return true;
}
/**
* Returns the content inset.
*
* @see #setBorderInsets(nextapp.echo2.app.Insets)
* @return the border inset
*/
public Insets getBorderInsets() {
return borderInsets;
}
/**
* Returns the solid color background of the border.
*
* @see #setColor(nextapp.echo2.app.Color)
* @return the color
*/
public Color getColor() {
return color;
}
/**
* Sets the content inset.
*
* @see #setContentInsets(nextapp.echo2.app.Insets)
* @return the content inset
*/
public Insets getContentInsets() {
return contentInsets;
}
/**
* Retrieves the FillImage
at the specified position.
*
* @param position the position, one of the following values:
*
* TOP_LEFT
the top left corner image
* TOP
the top side image
* TOP_RIGHT
the top right corner image
* LEFT
the left side image
* RIGHT
the right side image
* BOTTOM_LFET
the bottom left corner image
* BOTTOM
the bottom side image
* BOTTOM_RIGHT
the bottom right corner image
*
* @return the FillImage
*/
public FillImage getFillImage(int position) {
if (fillImages == null) {
return null;
} else {
return fillImages[position];
}
}
/**
* Sets the inset of the border images, thus defining the width and
* height of the border images.
* The provided Insets
value must only contain margins defined
* in pixel units.
*
* @param borderInsets the new border inset
*/
public void setBorderInsets(Insets borderInsets) {
this.borderInsets = borderInsets;
}
/**
* Sets the solid color background of the border.
* Note that setting a solid background color for the border will cause
* the alpha channel of any FillImage
s to be rendered against
* this color.
*
* @param color the color
*/
public void setColor(Color color) {
this.color = color;
}
/**
* Sets the inset of the content that is contained within the border
* relative to the outside of the border. If this inset value is smaller
* than the the border inset, the content will be rendered partially on top
* of the border. A null value for this property specifies that the
* content should be drawn at the border inset.
* The provided Insets
value must only contain margins defined
* in pixel units.
*
* @param contentInsets the new content inset
*/
public void setContentInsets(Insets contentInsets) {
this.contentInsets = contentInsets;
}
/**
* Sets the FillImage
at the specified position.
*
* @param position the position, one of the following values:
*
* TOP_LEFT
the top left corner image
* TOP
the top side image
* TOP_RIGHT
the top right corner image
* LEFT
the left side image
* RIGHT
the right side image
* BOTTOM_LFET
the bottom left corner image
* BOTTOM
the bottom side image
* BOTTOM_RIGHT
the bottom right corner image
*
* @param fillImage the new FillIamge
*/
public void setFillImage(int position, FillImage fillImage) {
if (fillImages == null) {
if (fillImage == null) {
return;
}
fillImages = new FillImage[8];
}
fillImages[position] = fillImage;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy