Class SynthMenuItemUI
java.lang.Object
javax.swing.plaf.ComponentUI
javax.swing.plaf.ButtonUI
javax.swing.plaf.MenuItemUI
javax.swing.plaf.basic.BasicMenuItemUI
javax.swing.plaf.synth.SynthMenuItemUI
- All Implemented Interfaces:
PropertyChangeListener, EventListener, SynthConstants, SynthUI
- Direct Known Subclasses:
SynthCheckBoxMenuItemUI, SynthRadioButtonMenuItemUI
Provides the Synth L&F UI delegate for
JMenuItem.- Since:
- 1.7
-
Nested Class Summary
Nested classes/interfaces inherited from class BasicMenuItemUI
BasicMenuItemUI.MouseInputHandlerModifier and TypeClassDescriptionprotected classDeprecated, for removal: This API element is subject to removal in a future version. -
Field Summary
Fields inherited from class BasicMenuItemUI
acceleratorDelimiter, acceleratorFont, acceleratorForeground, acceleratorSelectionForeground, arrowIcon, checkIcon, defaultTextIconGap, disabledForeground, menuDragMouseListener, menuItem, menuKeyListener, mouseInputListener, oldBorderPainted, propertyChangeListener, selectionBackground, selectionForegroundModifier and TypeFieldDescriptionprotected StringAccelerator delimiter string, such as'+'in'Ctrl+C'.protected FontThe accelerator font.protected ColorThe color of the accelerator foreground.protected ColorThe color of the accelerator selection.protected IconThe arrow icon.protected IconThe check icon.protected intThe gap between the text and the icon.protected ColorThe color of the disabled foreground.protected MenuDragMouseListenerThe instance ofMenuDragMouseListener.protected JMenuItemThe instance ofJMenuItem.protected MenuKeyListenerThe instance ofMenuKeyListener.protected MouseInputListenerThe instance ofMouseInputListener.protected booleanThe value represents if the old border is painted.protected PropertyChangeListenerPropertyChangeListenerreturned fromcreatePropertyChangeListener.protected ColorThe color of the selection background.protected ColorThe color of the selection foreground.Fields inherited from interface SynthConstants
DEFAULT, DISABLED, ENABLED, FOCUSED, MOUSE_OVER, PRESSED, SELECTEDModifier and TypeFieldDescriptionstatic final intIndicates the region is the default.static final intPrimary state indicating the region is not enabled.static final intPrimary state indicating the component is enabled.static final intIndicates the region has focus.static final intPrimary state indicating the mouse is over the region.static final intPrimary state indicating the region is in a pressed state.static final intIndicates the region is selected. -
Constructor Summary
Constructors -
Method Summary
Modifier and TypeMethodDescriptionstatic ComponentUICreates a new UI object for the given component.Returns the Context for the specified component.protected DimensiongetPreferredMenuItemSize(JComponent c, Icon checkIcon, Icon arrowIcon, int defaultTextIconGap) Returns the preferred size of a menu item.protected voidInstalls default properties.protected voidRegisters listeners.voidpaint(Graphics g, JComponent c) Paints the specified component according to the Look and Feel.protected voidpaint(SynthContext context, Graphics g) Paints the specified component.voidpaintBorder(SynthContext context, Graphics g, int x, int y, int w, int h) Paints the border.voidThis method gets called when a bound property is changed.protected voidUninstalls default properties.protected voidUnregisters listeners.voidReverses configuration which was done on the specified component duringinstallUI.voidupdate(Graphics g, JComponent c) Notifies this UI delegate to repaint the specified component.Methods inherited from class BasicMenuItemUI
createMenuDragMouseListener, createMenuKeyListener, createMouseInputListener, createPropertyChangeListener, doClick, getMaximumSize, getMinimumSize, getPath, getPreferredSize, getPropertyPrefix, installComponents, installKeyboardActions, installUI, paintBackground, paintMenuItem, paintText, uninstallComponents, uninstallKeyboardActionsModifier and TypeMethodDescriptionprotected MenuDragMouseListenerReturns an instance ofMenuDragMouseListener.protected MenuKeyListenerReturns an instance ofMenuKeyListener.protected MouseInputListenerReturns an instance ofMouseInputListener.protected PropertyChangeListenerCreates aPropertyChangeListenerwhich will be added to the menu item.protected voidCall this method when a menu item is to be activated.Returns the specified component's maximum size appropriate for the look and feel.Returns the specified component's minimum size appropriate for the look and feel.getPath()Returns a menu element path.Returns the specified component's preferred size appropriate for the look and feel.protected StringReturns a property prefix.protected voidinstallComponents(JMenuItem menuItem) Registers the subcomponents of the menu.protected voidRegisters keyboard action.voidConfigures the specified component appropriately for the look and feel.protected voidpaintBackground(Graphics g, JMenuItem menuItem, Color bgColor) Draws the background of the menu item.protected voidpaintMenuItem(Graphics g, JComponent c, Icon checkIcon, Icon arrowIcon, Color background, Color foreground, int defaultTextIconGap) Paints a menu item.protected voidRenders the text of the current menu item.protected voiduninstallComponents(JMenuItem menuItem) Unregisters components.protected voidUnregisters keyboard actions.Methods inherited from class ComponentUI
contains, getAccessibleChild, getAccessibleChildrenCount, getBaseline, getBaselineResizeBehaviorModifier and TypeMethodDescriptionbooleancontains(JComponent c, int x, int y) Returnstrueif 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 theithAccessiblechild of the object.intReturns the number of accessible children in the object.intgetBaseline(JComponent c, int width, int height) Returns the baseline.Returns an enum indicating how the baseline of the component changes as the size changes.Methods inherited from class Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, waitModifier and TypeMethodDescriptionprotected Objectclone()Creates and returns a copy of this object.booleanIndicates whether some other object is "equal to" this one.protected voidfinalize()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.inthashCode()Returns a hash code value for this object.final voidnotify()Wakes up a single thread that is waiting on this object's monitor.final voidWakes up all threads that are waiting on this object's monitor.toString()Returns a string representation of the object.final voidwait()Causes the current thread to wait until it is awakened, typically by being notified or interrupted.final voidwait(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 voidwait(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
-
SynthMenuItemUI
public SynthMenuItemUI()Constructs aSynthMenuItemUI.
-
-
Method Details
-
createUI
Creates a new UI object for the given component.- Parameters:
c- component to create UI object for- Returns:
- the UI object
-
uninstallUI
Reverses configuration which was done on the specified component duringinstallUI. This method is invoked when thisUIComponentinstance is being removed as the UI delegate for the specified component. This method should undo the configuration performed ininstallUI, being careful to leave theJComponentinstance in a clean state (no extraneous listeners, look-and-feel-specific property objects, etc.). This should include the following:- Remove any UI-set borders from the component.
- Remove any UI-set layout managers on the component.
- Remove any UI-added sub-components from the component.
- Remove any UI-added event/property listeners from the component.
- Remove any UI-installed keyboard UI from the component.
- Nullify any allocated instance data objects to allow for GC.
- Overrides:
uninstallUIin classBasicMenuItemUI- 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.- Overrides:
installDefaultsin classBasicMenuItemUI
-
installListeners
protected void installListeners()Registers listeners.- Overrides:
installListenersin classBasicMenuItemUI
-
uninstallDefaults
protected void uninstallDefaults()Uninstalls default properties.- Overrides:
uninstallDefaultsin classBasicMenuItemUI
-
uninstallListeners
protected void uninstallListeners()Unregisters listeners.- Overrides:
uninstallListenersin classBasicMenuItemUI
-
getContext
Returns the Context for the specified component.- Specified by:
getContextin interfaceSynthUI- Parameters:
c- Component requesting SynthContext.- Returns:
- SynthContext describing component.
-
getPreferredMenuItemSize
protected Dimension getPreferredMenuItemSize(JComponent c, Icon checkIcon, Icon arrowIcon, int defaultTextIconGap) Returns the preferred size of a menu item.- Overrides:
getPreferredMenuItemSizein classBasicMenuItemUI- Parameters:
c- a componentcheckIcon- a check iconarrowIcon- an arrow icondefaultTextIconGap- a gap between a text and an icon- Returns:
- the preferred size of a menu item
-
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
paintmethod.- Overrides:
updatein classBasicMenuItemUI- Parameters:
g- theGraphicsobject used for paintingc- the component being painted- 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:
paintin classBasicMenuItemUI- Parameters:
g- theGraphicsobject used for paintingc- the component being painted- See Also:
-
paint
Paints the specified component.- Parameters:
context- context for the component being paintedg- theGraphicsobject used for painting- See Also:
-
paintBorder
Paints the border.- Specified by:
paintBorderin interfaceSynthUI- Parameters:
context- a component contextg-Graphicsto paint onx- the X coordinatey- the Y coordinatew- width of the borderh- height of the border
-
propertyChange
This method gets called when a bound property is changed.- Specified by:
propertyChangein interfacePropertyChangeListener- Parameters:
e- A PropertyChangeEvent object describing the event source and the property that has changed.
-