Class BasicOptionPaneUI
java.lang.Object
javax.swing.plaf.ComponentUI
javax.swing.plaf.OptionPaneUI
javax.swing.plaf.basic.BasicOptionPaneUI
- Direct Known Subclasses:
SynthOptionPaneUI
Provides the basic look and feel for a
JOptionPane
.
BasicMessagePaneUI
provides a means to place an icon,
message and buttons into a Container
.
Generally, the layout will look like:
------------------ | i | message | | c | message | | o | message | | n | message | ------------------ | buttons | |________________|icon is an instance of
Icon
that is wrapped inside a
JLabel
. The message is an opaque object and is tested
for the following: if the message is a Component
it is
added to the Container
, if it is an Icon
it is wrapped inside a JLabel
and added to the
Container
otherwise it is wrapped inside a JLabel
.
The above layout is used when the option pane's
ComponentOrientation
property is horizontal, left-to-right.
The layout will be adjusted appropriately for other orientations.
The Container
, message, icon, and buttons are all
determined from abstract methods.
-
Nested Class Summary
Modifier and TypeClassDescriptionclass
This class should be treated as a "protected" inner class.static class
ButtonAreaLayout
behaves in a similar manner toFlowLayout
.class
This class should be treated as a "protected" inner class. -
Field Summary
Modifier and TypeFieldDescriptionprotected boolean
This is set to true in validateComponent if a Component is contained in either the message or the buttons.protected Component
Component to receive focus when messaged with selectInitialValue.protected JComponent
JComponent provide for input if optionPane.getWantsInput() returns true.static final int
The minimum height ofJOptionPane
.protected Dimension
The size ofJOptionPane
.static final int
The minimum width ofJOptionPane
.protected JOptionPane
JOptionPane
that the receiver is providing the look and feel for.protected PropertyChangeListener
The instance ofPropertyChangeListener
. -
Constructor Summary
-
Method Summary
Modifier and TypeMethodDescriptionprotected void
addButtonComponents
(Container container, Object[] buttons, int initialIndex) Creates the appropriate object to represent each of the objects inbuttons
and adds it tocontainer
.protected void
Creates and adds a JLabel representing the icon returned fromgetIcon
totop
.protected void
addMessageComponents
(Container container, GridBagConstraints cons, Object msg, int maxll, boolean internallyCreated) Creates the appropriate object to representmsg
and places it intocontainer
.protected void
burstStringInto
(Container c, String d, int maxll) Recursively creates newJLabel
instances to representd
.boolean
Returns true if in the last call to validateComponent the message or buttons contained a subclass of Component.protected ActionListener
createButtonActionListener
(int buttonIndex) Constructs a new instance of aButtonActionListener
.protected Container
Creates and returns aContainer
containing the buttons.protected LayoutManager
Returns a layout manager.protected Container
Messaged frominstallComponents
to create aContainer
containing the body of the message.protected PropertyChangeListener
Returns an instance ofPropertyChangeListener
.protected Container
Returns a separator.static ComponentUI
Creates a newBasicOptionPaneUI
instance.protected Object[]
Returns the buttons to display from theJOptionPane
the receiver is providing the look and feel for.protected Icon
getIcon()
Returns the icon from theJOptionPane
the receiver is providing the look and feel for, or the default icon as returned fromgetDefaultIcon
.protected Icon
getIconForType
(int messageType) Returns the icon to use for the passed in type.protected int
Returns the initial index into the buttons to select.protected int
Returns the maximum number of characters to place on a line.protected Object
Returns the message to display from theJOptionPane
the receiver is providing the look and feel for.Returns the minimum size the option pane should be.Ifc
is theJOptionPane
the receiver is contained in, the preferred size that is returned is the maximum of the preferred size of theLayoutManager
for theJOptionPane
, andgetMinimumOptionPaneSize
.protected boolean
Returnstrue
, basic L&F wants all the buttons to have the same width.protected void
Registers components.protected void
Installs default properties.protected void
Registers keyboard actions.protected void
Registers listeners.void
Installs the receiver as the L&F for the passed inJOptionPane
.protected void
Sets the input value in the option pane the receiver is providing the look and feel for based on the value in the inputComponent.void
If inputComponent is non-null, the focus is requested on that, otherwise request focus on the default valueprotected void
Unregisters components.protected void
Uninstalls default properties.protected void
Unregisters keyboard actions.protected void
Unregisters listeners.void
Removes the receiver from the L&F controller of the passed in split pane.Methods declared in class ComponentUI
contains, getAccessibleChild, getAccessibleChildrenCount, getBaseline, getBaselineResizeBehavior, getMaximumSize, getMinimumSize, paint, update
-
Field Details
-
MinimumWidth
public static final int MinimumWidthThe minimum width ofJOptionPane
.- See Also:
-
MinimumHeight
public static final int MinimumHeightThe minimum height ofJOptionPane
.- See Also:
-
optionPane
JOptionPane
that the receiver is providing the look and feel for. -
minimumSize
The size ofJOptionPane
. -
inputComponent
JComponent provide for input if optionPane.getWantsInput() returns true. -
initialFocusComponent
Component to receive focus when messaged with selectInitialValue. -
hasCustomComponents
protected boolean hasCustomComponentsThis is set to true in validateComponent if a Component is contained in either the message or the buttons. -
propertyChangeListener
The instance ofPropertyChangeListener
.
-
-
Constructor Details
-
BasicOptionPaneUI
public BasicOptionPaneUI()Constructs aBasicOptionPaneUI
.
-
-
Method Details
-
createUI
Creates a newBasicOptionPaneUI
instance.- Parameters:
x
- the component- Returns:
- a new
BasicOptionPaneUI
instance
-
installUI
Installs the receiver as the L&F for the passed inJOptionPane
.- Overrides:
installUI
in classComponentUI
- Parameters:
c
- the component where this UI delegate is being installed- See Also:
-
uninstallUI
Removes the receiver from the L&F controller of the passed in split pane.- Overrides:
uninstallUI
in classComponentUI
- Parameters:
c
- the component from which this UI delegate is being removed; this argument is often ignored, but might be used if the UI object is stateless and shared by multiple components- See Also:
-
installDefaults
protected void installDefaults()Installs default properties. -
uninstallDefaults
protected void uninstallDefaults()Uninstalls default properties. -
installComponents
protected void installComponents()Registers components. -
uninstallComponents
protected void uninstallComponents()Unregisters components. -
createLayoutManager
-
installListeners
protected void installListeners()Registers listeners. -
uninstallListeners
protected void uninstallListeners()Unregisters listeners. -
createPropertyChangeListener
Returns an instance ofPropertyChangeListener
.- Returns:
- an instance of
PropertyChangeListener
-
installKeyboardActions
protected void installKeyboardActions()Registers keyboard actions. -
uninstallKeyboardActions
protected void uninstallKeyboardActions()Unregisters keyboard actions. -
getMinimumOptionPaneSize
Returns the minimum size the option pane should be. Primarily provided for subclassers wishing to offer a different minimum size.- Returns:
- the minimum size of the option pane
-
getPreferredSize
Ifc
is theJOptionPane
the receiver is contained in, the preferred size that is returned is the maximum of the preferred size of theLayoutManager
for theJOptionPane
, andgetMinimumOptionPaneSize
.- Overrides:
getPreferredSize
in classComponentUI
- Parameters:
c
- the component whose preferred size is being queried; this argument is often ignored, but might be used if the UI object is stateless and shared by multiple components- Returns:
- a
Dimension
object containing given component's preferred size appropriate for the look and feel - See Also:
-
createMessageArea
Messaged frominstallComponents
to create aContainer
containing the body of the message. The icon is the created by callingaddIcon
.- Returns:
- a instance of
Container
-
addMessageComponents
protected void addMessageComponents(Container container, GridBagConstraints cons, Object msg, int maxll, boolean internallyCreated) Creates the appropriate object to representmsg
and places it intocontainer
. Ifmsg
is an instance ofComponent
, it is added directly; if it is anIcon
, aJLabel
is created to represent it; otherwise, aJLabel
is created for the string. Ifmsg
is an Object[], this method will be recursively invoked for the children.internallyCreated
istrue
ifmsg
is an instance ofComponent
and was created internally by this method (this is used to correctly sethasCustomComponents
only ifinternallyCreated
isfalse
).- Parameters:
container
- a containercons
- an instance ofGridBagConstraints
msg
- a messagemaxll
- a maximum lengthinternallyCreated
-true
if the component was internally created
-
getMessage
Returns the message to display from theJOptionPane
the receiver is providing the look and feel for.- Returns:
- the message to display
-
addIcon
Creates and adds a JLabel representing the icon returned fromgetIcon
totop
. This is messaged fromcreateMessageArea
.- Parameters:
top
- a container
-
getIcon
Returns the icon from theJOptionPane
the receiver is providing the look and feel for, or the default icon as returned fromgetDefaultIcon
.- Returns:
- the icon
-
getIconForType
Returns the icon to use for the passed in type.- Parameters:
messageType
- a type of message- Returns:
- the icon to use for the passed in type
-
getMaxCharactersPerLineCount
protected int getMaxCharactersPerLineCount()Returns the maximum number of characters to place on a line.- Returns:
- the maximum number of characters to place on a line
-
burstStringInto
-
createSeparator
-
createButtonArea
Creates and returns aContainer
containing the buttons. The buttons are created by callinggetButtons
.- Returns:
- a
Container
containing the buttons
-
addButtonComponents
Creates the appropriate object to represent each of the objects inbuttons
and adds it tocontainer
. This differs from addMessageComponents in that it will recurse onbuttons
and that if button is not a Component it will create an instance of JButton.- Parameters:
container
- a containerbuttons
- an array of buttonsinitialIndex
- an initial index
-
createButtonActionListener
Constructs a new instance of aButtonActionListener
.- Parameters:
buttonIndex
- an index of the button- Returns:
- a new instance of a
ButtonActionListener
-
getButtons
Returns the buttons to display from theJOptionPane
the receiver is providing the look and feel for. If theJOptionPane
has options set, they will be provided, otherwise if the optionType isYES_NO_OPTION
,yesNoOptions
is returned, if the type isYES_NO_CANCEL_OPTION
yesNoCancelOptions
is returned, otherwisedefaultButtons
are returned.- Returns:
- the buttons to display from the JOptionPane
-
getSizeButtonsToSameWidth
protected boolean getSizeButtonsToSameWidth()Returnstrue
, basic L&F wants all the buttons to have the same width.- Returns:
true
if all the buttons should have the same width
-
getInitialValueIndex
protected int getInitialValueIndex()Returns the initial index into the buttons to select. The index is calculated from the initial value from the JOptionPane and options of the JOptionPane or 0.- Returns:
- the initial index into the buttons to select
-
resetInputValue
protected void resetInputValue()Sets the input value in the option pane the receiver is providing the look and feel for based on the value in the inputComponent. -
selectInitialValue
If inputComponent is non-null, the focus is requested on that, otherwise request focus on the default value- Specified by:
selectInitialValue
in classOptionPaneUI
- Parameters:
op
- aJOptionPane
-
containsCustomComponents
Returns true if in the last call to validateComponent the message or buttons contained a subclass of Component.- Specified by:
containsCustomComponents
in classOptionPaneUI
- Parameters:
op
- aJOptionPane
- Returns:
true
if the givenJOptionPane
contains user createdComponent
s
-