Class SynthComboBoxUI
java.lang.Object
javax.swing.plaf.ComponentUI
javax.swing.plaf.ComboBoxUI
javax.swing.plaf.basic.BasicComboBoxUI
javax.swing.plaf.synth.SynthComboBoxUI
- All Implemented Interfaces:
PropertyChangeListener, EventListener, SynthConstants, SynthUI
Provides the Synth L&F UI delegate for
JComboBox
.- Since:
- 1.7
-
Nested Class Summary
Nested classes/interfaces declared in class BasicComboBoxUI
BasicComboBoxUI.ComboBoxLayoutManager, BasicComboBoxUI.FocusHandler, BasicComboBoxUI.ItemHandler, BasicComboBoxUI.KeyHandler, BasicComboBoxUI.ListDataHandler, BasicComboBoxUI.PropertyChangeHandler
Modifier and TypeClassDescriptionclass
This layout manager handles the 'standard' layout of combo boxes.class
This listener hides the popup when the focus is lost.class
This listener watches for changes to the selection in the combo box.class
This listener checks to see if the key event isn't a navigation key.class
This listener watches for changes in theComboBoxModel
.class
This listener watches for bound properties that have changed in the combo box. -
Field Summary
Fields declared in class BasicComboBoxUI
arrowButton, cachedMinimumSize, comboBox, currentValuePane, editor, focusListener, hasFocus, isMinimumSizeDirty, itemListener, keyListener, listBox, listDataListener, padding, popup, popupKeyListener, popupMouseListener, popupMouseMotionListener, propertyChangeListener, squareButton
Modifier and TypeFieldDescriptionprotected JButton
The arrow button that invokes the popup.protected Dimension
The cached minimum preferred size.The instance ofJComboBox
.protected CellRendererPane
Used to render the currently selected item in the combo box.protected Component
The Component that theComboBoxEditor
uses for editing.protected FocusListener
This protected field is implementation specific.protected boolean
This protected field is implementation specific.protected boolean
The flag for recalculating the minimum preferred size.protected ItemListener
This protected field is implementation specific.protected KeyListener
This protected field is implementation specific.This list is for drawing the current item in the combo box.protected ListDataListener
This protected field is implementation specific.protected Insets
If specified, these insets act as padding around the cell renderer when laying out and painting the "selected" item in the combo box.protected ComboPopup
The implementation ofComboPopup
that is used to show the popup.protected KeyListener
TheKeyListener
listens to events.protected MouseListener
TheMouseListener
listens to events.protected MouseMotionListener
TheMouseMotionListener
listens to events.protected PropertyChangeListener
This protected field is implementation specific.protected boolean
Indicates whether or not the combo box button should be square.Fields declared in interface SynthConstants
DEFAULT, DISABLED, ENABLED, FOCUSED, MOUSE_OVER, PRESSED, SELECTED
Modifier and TypeFieldDescriptionstatic final int
Indicates the region is the default.static final int
Primary state indicating the region is not enabled.static final int
Primary state indicating the component is enabled.static final int
Indicates the region has focus.static final int
Primary state indicating the mouse is over the region.static final int
Primary state indicating the region is in a pressed state.static final int
Indicates the region is selected. -
Constructor Summary
Constructors -
Method Summary
Modifier and TypeMethodDescriptionstatic ComponentUI
Creates a new UI object for the given component.Returns the Context for the specified component.protected Dimension
Returns the default size of an empty display area of the combo box using the current renderer and font.The minimum size is the size of the display area plus insets plus the button.void
Configures the specified component appropriately for the look and feel.void
paint
(Graphics g, JComponent c) Paints the specified component according to the Look and Feel.protected void
paint
(SynthContext context, Graphics g) Paints the specified component.void
paintBorder
(SynthContext context, Graphics g, int x, int y, int w, int h) Paints the border.void
paintCurrentValue
(Graphics g, Rectangle bounds, boolean hasFocus) Paints the currently selected item.void
This method gets called when a bound property is changed.void
update
(Graphics g, JComponent c) Notifies this UI delegate to repaint the specified component.Methods declared in class BasicComboBoxUI
addEditor, configureArrowButton, configureEditor, createArrowButton, createEditor, createFocusListener, createItemListener, createKeyListener, createLayoutManager, createListDataListener, createPopup, createPropertyChangeListener, createRenderer, getBaseline, getBaselineResizeBehavior, getDisplaySize, getInsets, getSizeForComponent, installComponents, installDefaults, installKeyboardActions, installListeners, isFocusTraversable, isNavigationKey, isPopupVisible, paintCurrentValueBackground, rectangleForCurrentValue, removeEditor, selectNextPossibleValue, selectPreviousPossibleValue, setPopupVisible, toggleOpenClose, unconfigureArrowButton, unconfigureEditor, uninstallComponents, uninstallDefaults, uninstallKeyboardActions, uninstallListeners
Modifier and TypeMethodDescriptionvoid
This public method is implementation specific and should be private. do not call or override.void
This public method is implementation specific and should be private.protected void
This protected method is implementation specific and should be private. do not call or override.protected JButton
Creates a button which will be used as the control to show or hide the popup portion of the combo box.protected ComboBoxEditor
Creates the default editor that will be used in editable combo boxes.protected FocusListener
Creates aFocusListener
which will be added to the combo box.protected ItemListener
Creates anItemListener
which will be added to the combo box.protected KeyListener
Creates aKeyListener
which will be added to the combo box.protected LayoutManager
Creates a layout manager for managing the components which make up the combo box.protected ListDataListener
Creates a list data listener which will be added to theComboBoxModel
.protected ComboPopup
Creates the popup portion of the combo box.protected PropertyChangeListener
Creates aPropertyChangeListener
which will be added to the combo box.protected ListCellRenderer
<Object> Creates the default renderer that will be used in a non-editiable combo box.int
getBaseline
(JComponent c, int width, int height) Returns the baseline.Returns an enum indicating how the baseline of the component changes as the size changes.protected Dimension
Returns the calculated size of the display area.protected Insets
Gets the insets from the JComboBox.protected Dimension
getSizeForComponent
(Component comp) Returns the size a component would have if used as a cell renderer.protected void
Creates and initializes the components which make up the aggregate combo box.protected void
Installs the default colors, default font, default renderer, and default editor into the JComboBox.protected void
Adds keyboard actions to the JComboBox.protected void
Creates and installs listeners for the combo box and its model.boolean
isFocusTraversable
(JComboBox<?> c) Determines if the JComboBox is focus traversable.protected boolean
isNavigationKey
(int keyCode) Returns whether or not the supplied keyCode maps to a key that is used for navigation.boolean
isPopupVisible
(JComboBox<?> c) Tells if the popup is visible or not.void
paintCurrentValueBackground
(Graphics g, Rectangle bounds, boolean hasFocus) Paints the background of the currently selected item.protected Rectangle
Returns the area that is reserved for drawing the currently selected item.void
This public method is implementation specific and should be private. do not call or override.protected void
Selects the next item in the list.protected void
Selects the previous item in the list.void
setPopupVisible
(JComboBox<?> c, boolean v) Hides the popup.protected void
Hides the popup if it is showing and shows the popup if it is hidden.void
This public method is implementation specific and should be private.protected void
This protected method is implementation specific and should be private.protected void
The aggregate components which comprise the combo box are unregistered and uninitialized.protected void
Uninstalls the default colors, default font, default renderer, and default editor from the combo box.protected void
Removes the focus InputMap and ActionMap.protected void
Removes the installed listeners from the combo box and its model.Methods declared in class ComponentUI
contains, getAccessibleChild, getAccessibleChildrenCount, getMaximumSize, getPreferredSize, uninstallUI
Modifier and TypeMethodDescriptionboolean
contains
(JComponent c, int x, int y) Returnstrue
if the specified x,y location is contained within the look and feel's defined shape of the specified component.getAccessibleChild
(JComponent c, int i) Returns thei
thAccessible
child of the object.int
Returns the number of accessible children in the object.Returns the specified component's maximum size appropriate for the look and feel.Returns the specified component's preferred size appropriate for the look and feel.void
Reverses configuration which was done on the specified component duringinstallUI
.Methods declared in class Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
Modifier and TypeMethodDescriptionprotected Object
clone()
Creates and returns a copy of this object.boolean
Indicates whether some other object is "equal to" this one.protected void
finalize()
Deprecated, for removal: This API element is subject to removal in a future version.Finalization is deprecated and subject to removal in a future release.final Class
<?> getClass()
Returns the runtime class of thisObject
.int
hashCode()
Returns a hash code value for this object.final void
notify()
Wakes up a single thread that is waiting on this object's monitor.final void
Wakes up all threads that are waiting on this object's monitor.toString()
Returns a string representation of the object.final void
wait()
Causes the current thread to wait until it is awakened, typically by being notified or interrupted.final void
wait
(long timeoutMillis) Causes the current thread to wait until it is awakened, typically by being notified or interrupted, or until a certain amount of real time has elapsed.final void
wait
(long timeoutMillis, int nanos) Causes the current thread to wait until it is awakened, typically by being notified or interrupted, or until a certain amount of real time has elapsed.
-
Constructor Details
-
SynthComboBoxUI
public SynthComboBoxUI()Constructs aSynthComboBoxUI
.
-
-
Method Details
-
createUI
Creates a new UI object for the given component.- Parameters:
c
- component to create UI object for- Returns:
- the UI object
-
installUI
Configures the specified component appropriately for the look and feel. This method is invoked when theComponentUI
instance is being installed as the UI delegate on the specified component. This method should completely configure the component for the look and feel, including the following:- Install default property values for color, fonts, borders, icons, opacity, etc. on the component. Whenever possible, property values initialized by the client program should not be overridden.
- Install a
LayoutManager
on the component if necessary. - Create/add any required sub-components to the component.
- Create/install event listeners on the component.
- Create/install a
PropertyChangeListener
on the component in order to detect and respond to component property changes appropriately. - Install keyboard UI (mnemonics, traversal, etc.) on the component.
- Initialize any appropriate instance data.
- Overrides:
installUI
in classComponentUI
- Parameters:
c
- the component where this UI delegate is being installed- See Also:
-
getContext
Returns the Context for the specified component.- Specified by:
getContext
in interfaceSynthUI
- Parameters:
c
- Component requesting SynthContext.- Returns:
- SynthContext describing component.
-
propertyChange
This method gets called when a bound property is changed.- Specified by:
propertyChange
in interfacePropertyChangeListener
- Parameters:
e
- A PropertyChangeEvent object describing the event source and the property that has changed.
-
update
Notifies this UI delegate to repaint the specified component. This method paints the component background, then calls thepaint(SynthContext,Graphics)
method.In general, this method does not need to be overridden by subclasses. All Look and Feel rendering code should reside in the
paint
method.- Overrides:
update
in classComponentUI
- Parameters:
g
- theGraphics
object used for paintingc
- the component being painted- See Also:
-
getMinimumSize
The minimum size is the size of the display area plus insets plus the button.- Overrides:
getMinimumSize
in classBasicComboBoxUI
- Parameters:
c
- the component whose minimum 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 ornull
- See Also:
-
paint
Paints the specified component according to the Look and Feel.This method is not used by Synth Look and Feel. Painting is handled by the
paint(SynthContext,Graphics)
method.- Overrides:
paint
in classComponentUI
- Parameters:
g
- theGraphics
object used for paintingc
- the component being painted- See Also:
-
paint
Paints the specified component.- Parameters:
context
- context for the component being paintedg
- theGraphics
object used for painting- See Also:
-
paintBorder
Paints the border.- Specified by:
paintBorder
in interfaceSynthUI
- Parameters:
context
- a component contextg
-Graphics
to paint onx
- the X coordinatey
- the Y coordinatew
- width of the borderh
- height of the border
-
paintCurrentValue
Paints the currently selected item.- Overrides:
paintCurrentValue
in classBasicComboBoxUI
- Parameters:
g
- an instance ofGraphics
bounds
- a bounding rectangle to render tohasFocus
- is focused
-
getDefaultSize
Returns the default size of an empty display area of the combo box using the current renderer and font. This method was overridden to use SynthComboBoxRenderer instead of DefaultListCellRenderer as the default renderer when calculating the size of the combo box. This is used in the case of the combo not having any data.- Overrides:
getDefaultSize
in classBasicComboBoxUI
- Returns:
- the size of an empty display area
- See Also:
-