/*
 * Copyright (c) 1997, 2015, Oracle and/or its affiliates. All rights reserved.
 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
 *
 * This code is free software; you can redistribute it and/or modify it
 * under the terms of the GNU General Public License version 2 only, as
 * published by the Free Software Foundation.  Oracle designates this
 * particular file as subject to the "Classpath" exception as provided
 * by Oracle in the LICENSE file that accompanied this code.
 *
 * This code is distributed in the hope that it will be useful, but WITHOUT
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
 * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
 * version 2 for more details (a copy is included in the LICENSE file that
 * accompanied this code).
 *
 * You should have received a copy of the GNU General Public License version
 * 2 along with this work; if not, write to the Free Software Foundation,
 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
 *
 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
 * or visit www.oracle.com if you need additional information or have any
 * questions.
 */

package javax.swing.plaf;

import java.awt.Component;
import java.awt.Insets;
import java.awt.Color;
import java.awt.Font;
import java.awt.Graphics;
import java.io.Serializable;

import java.beans.ConstructorProperties;
import javax.swing.border.*;
import javax.swing.Icon;
import javax.swing.plaf.UIResource;


A Border wrapper class which implements UIResource. UI classes which set border properties should use this class to wrap any borders specified as defaults. This class delegates all method invocations to the Border "delegate" object specified at construction.

Warning: Serialized objects of this class will not be compatible with future Swing releases. The current serialization support is appropriate for short term storage or RMI between applications running the same version of Swing. As of 1.4, support for long term storage of all JavaBeans™ has been added to the java.beans package. Please see XMLEncoder.

Author:Amy Fowler
See Also:
/** * A Border wrapper class which implements UIResource. UI * classes which set border properties should use this class * to wrap any borders specified as defaults. * * This class delegates all method invocations to the * Border "delegate" object specified at construction. * <p> * <strong>Warning:</strong> * Serialized objects of this class will not be compatible with * future Swing releases. The current serialization support is * appropriate for short term storage or RMI between applications running * the same version of Swing. As of 1.4, support for long term storage * of all JavaBeans&trade; * has been added to the <code>java.beans</code> package. * Please see {@link java.beans.XMLEncoder}. * * @see javax.swing.plaf.UIResource * @author Amy Fowler * */
@SuppressWarnings("serial") // Same-version serialization only public class BorderUIResource implements Border, UIResource, Serializable { static Border etched; static Border loweredBevel; static Border raisedBevel; static Border blackLine;
Returns a etched border UI resource.
Returns:a etched border UI resource
/** * Returns a etched border UI resource. * @return a etched border UI resource */
public static Border getEtchedBorderUIResource() { if (etched == null) { etched = new EtchedBorderUIResource(); } return etched; }
Returns a lowered bevel border UI resource.
Returns:a lowered bevel border UI resource
/** * Returns a lowered bevel border UI resource. * @return a lowered bevel border UI resource */
public static Border getLoweredBevelBorderUIResource() { if (loweredBevel == null) { loweredBevel = new BevelBorderUIResource(BevelBorder.LOWERED); } return loweredBevel; }
Returns a raised bevel border UI resource.
Returns:a raised bevel border UI resource
/** * Returns a raised bevel border UI resource. * @return a raised bevel border UI resource */
public static Border getRaisedBevelBorderUIResource() { if (raisedBevel == null) { raisedBevel = new BevelBorderUIResource(BevelBorder.RAISED); } return raisedBevel; }
Returns a black line border UI resource.
Returns:a black line border UI resource
/** * Returns a black line border UI resource. * @return a black line border UI resource */
public static Border getBlackLineBorderUIResource() { if (blackLine == null) { blackLine = new LineBorderUIResource(Color.black); } return blackLine; } private Border delegate;
Creates a UIResource border object which wraps an existing Border instance.
Params:
  • delegate – the border being wrapped
/** * Creates a UIResource border object which wraps * an existing Border instance. * @param delegate the border being wrapped */
public BorderUIResource(Border delegate) { if (delegate == null) { throw new IllegalArgumentException("null border delegate argument"); } this.delegate = delegate; } public void paintBorder(Component c, Graphics g, int x, int y, int width, int height) { delegate.paintBorder(c, g, x, y, width, height); } public Insets getBorderInsets(Component c) { return delegate.getBorderInsets(c); } public boolean isBorderOpaque() { return delegate.isBorderOpaque(); }
A compound border UI resource.
/** * A compound border UI resource. */
public static class CompoundBorderUIResource extends CompoundBorder implements UIResource {
Constructs a CompoundBorderUIResource.
Params:
  • outsideBorder – the outside border
  • insideBorder – the inside border
/** * Constructs a {@code CompoundBorderUIResource}. * @param outsideBorder the outside border * @param insideBorder the inside border */
@ConstructorProperties({"outsideBorder", "insideBorder"}) public CompoundBorderUIResource(Border outsideBorder, Border insideBorder) { super(outsideBorder, insideBorder); } }
An empty border UI resource.
/** * An empty border UI resource. */
public static class EmptyBorderUIResource extends EmptyBorder implements UIResource {
Constructs an EmptyBorderUIResource.
Params:
  • top – the top inset of the border
  • left – the left inset of the border
  • bottom – the bottom inset of the border
  • right – the right inset of the border
/** * Constructs an {@code EmptyBorderUIResource}. * @param top the top inset of the border * @param left the left inset of the border * @param bottom the bottom inset of the border * @param right the right inset of the border */
public EmptyBorderUIResource(int top, int left, int bottom, int right) { super(top, left, bottom, right); }
Constructs an EmptyBorderUIResource.
Params:
  • insets – the insets of the border
/** * Constructs an {@code EmptyBorderUIResource}. * @param insets the insets of the border */
@ConstructorProperties({"borderInsets"}) public EmptyBorderUIResource(Insets insets) { super(insets); } }
A line border UI resource.
/** * A line border UI resource. */
public static class LineBorderUIResource extends LineBorder implements UIResource {
Constructs a LineBorderUIResource.
Params:
  • color – the color for the border
/** * Constructs a {@code LineBorderUIResource}. * @param color the color for the border */
public LineBorderUIResource(Color color) { super(color); }
Constructs a LineBorderUIResource.
Params:
  • color – the color for the border
  • thickness – the thickness of the border
/** * Constructs a {@code LineBorderUIResource}. * @param color the color for the border * @param thickness the thickness of the border */
@ConstructorProperties({"lineColor", "thickness"}) public LineBorderUIResource(Color color, int thickness) { super(color, thickness); } }
A bevel border UI resource.
/** * A bevel border UI resource. */
public static class BevelBorderUIResource extends BevelBorder implements UIResource {
Constructs a BevelBorderUIResource.
Params:
  • bevelType – the type of bevel for the border
/** * Constructs a {@code BevelBorderUIResource}. * @param bevelType the type of bevel for the border */
public BevelBorderUIResource(int bevelType) { super(bevelType); }
Constructs a BevelBorderUIResource.
Params:
  • bevelType – the type of bevel for the border
  • highlight – the color to use for the bevel highlight
  • shadow – the color to use for the bevel shadow
/** * Constructs a {@code BevelBorderUIResource}. * @param bevelType the type of bevel for the border * @param highlight the color to use for the bevel highlight * @param shadow the color to use for the bevel shadow */
public BevelBorderUIResource(int bevelType, Color highlight, Color shadow) { super(bevelType, highlight, shadow); }
Constructs a BevelBorderUIResource.
Params:
  • bevelType – the type of bevel for the border
  • highlightOuter – the color to use for the bevel outer highlight
  • highlightInner – the color to use for the bevel inner highlight
  • shadowOuter – the color to use for the bevel outer shadow
  • shadowInner – the color to use for the bevel inner shadow
/** * Constructs a {@code BevelBorderUIResource}. * @param bevelType the type of bevel for the border * @param highlightOuter the color to use for the bevel outer highlight * @param highlightInner the color to use for the bevel inner highlight * @param shadowOuter the color to use for the bevel outer shadow * @param shadowInner the color to use for the bevel inner shadow */
@ConstructorProperties({"bevelType", "highlightOuterColor", "highlightInnerColor", "shadowOuterColor", "shadowInnerColor"}) public BevelBorderUIResource(int bevelType, Color highlightOuter, Color highlightInner, Color shadowOuter, Color shadowInner) { super(bevelType, highlightOuter, highlightInner, shadowOuter, shadowInner); } }
An etched border UI resource.
/** * An etched border UI resource. */
public static class EtchedBorderUIResource extends EtchedBorder implements UIResource {
Constructs an EtchedBorderUIResource.
/** * Constructs an {@code EtchedBorderUIResource}. */
public EtchedBorderUIResource() { super(); }
Constructs an EtchedBorderUIResource.
Params:
  • etchType – the type of etch to be drawn by the border
/** * Constructs an {@code EtchedBorderUIResource}. * @param etchType the type of etch to be drawn by the border */
public EtchedBorderUIResource(int etchType) { super(etchType); }
Constructs an EtchedBorderUIResource.
Params:
  • highlight – the color to use for the etched highlight
  • shadow – the color to use for the etched shadow
/** * Constructs an {@code EtchedBorderUIResource}. * @param highlight the color to use for the etched highlight * @param shadow the color to use for the etched shadow */
public EtchedBorderUIResource(Color highlight, Color shadow) { super(highlight, shadow); }
Constructs an EtchedBorderUIResource.
Params:
  • etchType – the type of etch to be drawn by the border
  • highlight – the color to use for the etched highlight
  • shadow – the color to use for the etched shadow
/** * Constructs an {@code EtchedBorderUIResource}. * @param etchType the type of etch to be drawn by the border * @param highlight the color to use for the etched highlight * @param shadow the color to use for the etched shadow */
@ConstructorProperties({"etchType", "highlightColor", "shadowColor"}) public EtchedBorderUIResource(int etchType, Color highlight, Color shadow) { super(etchType, highlight, shadow); } }
A matte border UI resource.
/** * A matte border UI resource. */
public static class MatteBorderUIResource extends MatteBorder implements UIResource {
Constructs a MatteBorderUIResource.
Params:
  • top – the top inset of the border
  • left – the left inset of the border
  • bottom – the bottom inset of the border
  • right – the right inset of the border
  • color – the color rendered for the border
/** * Constructs a {@code MatteBorderUIResource}. * @param top the top inset of the border * @param left the left inset of the border * @param bottom the bottom inset of the border * @param right the right inset of the border * @param color the color rendered for the border */
public MatteBorderUIResource(int top, int left, int bottom, int right, Color color) { super(top, left, bottom, right, color); }
Constructs a MatteBorderUIResource.
Params:
  • top – the top inset of the border
  • left – the left inset of the border
  • bottom – the bottom inset of the border
  • right – the right inset of the border
  • tileIcon – the icon to be used for tiling the border
/** * Constructs a {@code MatteBorderUIResource}. * @param top the top inset of the border * @param left the left inset of the border * @param bottom the bottom inset of the border * @param right the right inset of the border * @param tileIcon the icon to be used for tiling the border */
public MatteBorderUIResource(int top, int left, int bottom, int right, Icon tileIcon) { super(top, left, bottom, right, tileIcon); }
Constructs a MatteBorderUIResource.
Params:
  • tileIcon – the icon to be used for tiling the border
/** * Constructs a {@code MatteBorderUIResource}. * @param tileIcon the icon to be used for tiling the border */
public MatteBorderUIResource(Icon tileIcon) { super(tileIcon); } }
A titled border UI resource.
/** * A titled border UI resource. */
public static class TitledBorderUIResource extends TitledBorder implements UIResource {
Constructs a TitledBorderUIResource.
Params:
  • title – the title the border should display
/** * Constructs a {@code TitledBorderUIResource}. * @param title the title the border should display */
public TitledBorderUIResource(String title) { super(title); }
Constructs a TitledBorderUIResource.
Params:
  • border – the border
/** * Constructs a {@code TitledBorderUIResource}. * @param border the border */
public TitledBorderUIResource(Border border) { super(border); }
Constructs a TitledBorderUIResource.
Params:
  • border – the border
  • title – the title the border should display
/** * Constructs a {@code TitledBorderUIResource}. * @param border the border * @param title the title the border should display */
public TitledBorderUIResource(Border border, String title) { super(border, title); }
Constructs a TitledBorderUIResource.
Params:
  • border – the border
  • title – the title the border should display
  • titleJustification – the justification fro the title
  • titlePosition – the position for the title
/** * Constructs a {@code TitledBorderUIResource}. * @param border the border * @param title the title the border should display * @param titleJustification the justification fro the title * @param titlePosition the position for the title */
public TitledBorderUIResource(Border border, String title, int titleJustification, int titlePosition) { super(border, title, titleJustification, titlePosition); }
Constructs a TitledBorderUIResource.
Params:
  • border – the border
  • title – the title the border should display
  • titleJustification – the justification fro the title
  • titlePosition – the position for the title
  • titleFont – the font for rendering the title
/** * Constructs a {@code TitledBorderUIResource}. * @param border the border * @param title the title the border should display * @param titleJustification the justification fro the title * @param titlePosition the position for the title * @param titleFont the font for rendering the title */
public TitledBorderUIResource(Border border, String title, int titleJustification, int titlePosition, Font titleFont) { super(border, title, titleJustification, titlePosition, titleFont); }
Constructs a TitledBorderUIResource.
Params:
  • border – the border
  • title – the title the border should display
  • titleJustification – the justification fro the title
  • titlePosition – the position for the title
  • titleFont – the font for rendering the title
  • titleColor – the color of the title
/** * Constructs a {@code TitledBorderUIResource}. * @param border the border * @param title the title the border should display * @param titleJustification the justification fro the title * @param titlePosition the position for the title * @param titleFont the font for rendering the title * @param titleColor the color of the title */
@ConstructorProperties({"border", "title", "titleJustification", "titlePosition", "titleFont", "titleColor"}) public TitledBorderUIResource(Border border, String title, int titleJustification, int titlePosition, Font titleFont, Color titleColor) { super(border, title, titleJustification, titlePosition, titleFont, titleColor); } } }