Borders
Any Swing component can have a decorative border. JComponent includes a method called setBorder() ; all you
have to do is call it, passing it an appropriate implementation of the
Border interface.
Swing provides many useful Border
implementations in the javax.swing.border
package. You could create an instance of one of these classes and pass it
to a component’s setBorder() method,
but there’s an even simpler technique.
The BorderFactory class creates
any kind of border for you using static “factory” methods. Creating and
setting a component’s border, then, is simple:
JLabellabelTwo=newJLabel("I have an etched border.");labelTwo.setBorder(BorderFactory.createEtchedBorder());
Every component has a setBorder()
method, from simple labels and buttons right up to the fancy text and
table components that we cover in Chapter 18.
BorderFactory is convenient, but
it does not offer every option of every border type. For example, if you
want to create a raised EtchedBorder instead of
the default lowered border, you’ll need to use EtchedBorder’s constructor, like this:
JLabellabelTwo=newJLabel("I have a raised etched border.");labelTwo.setBorder(newEtchedBorder(EtchedBorder.RAISED));
The Border implementation classes
are listed and briefly described here:
BevelBorderThis border draws raised or lowered beveled edges, giving an illusion of depth.
SoftBevelBorderThis border is similar to
BevelBorder, but thinner.EmptyBorderDoesn’t do any drawing, but does take up space. You can ...