Class SynthSpinnerUI
java.lang.Object
javax.swing.plaf.ComponentUI
javax.swing.plaf.SpinnerUI
javax.swing.plaf.basic.BasicSpinnerUI
javax.swing.plaf.synth.SynthSpinnerUI
- All Implemented Interfaces:
PropertyChangeListener, EventListener, SynthConstants, SynthUI
Provides the Synth L&F UI delegate for
JSpinner.- Since:
- 1.7
-
Field Summary
Fields declared in class BasicSpinnerUI
spinnerFields declared in 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 TypeMethodDescriptionprotected JComponentThis method is called by installUI to get the editor component of theJSpinner.static ComponentUIReturns a new instance of SynthSpinnerUI.Returns the Context for the specified component.protected voidInitializes theJSpinnerborder,foreground, andbackground, properties based on the corresponding "Spinner.*" properties from defaults table.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 voidreplaceEditor(JComponent oldEditor, JComponent newEditor) Called by thePropertyChangeListenerwhen theJSpinnereditor property changes.protected voidSets theJSpinner'slayout manager to null.voidupdate(Graphics g, JComponent c) Notifies this UI delegate to repaint the specified component.Methods declared in class BasicSpinnerUI
createLayout, createNextButton, createPreviousButton, createPropertyChangeListener, getBaseline, getBaselineResizeBehavior, installKeyboardActions, installListeners, installNextButtonListeners, installPreviousButtonListeners, installUI, uninstallListeners, uninstallUIModifier and TypeMethodDescriptionprotected LayoutManagerCreates aLayoutManagerthat manages theeditor,nextButton, andpreviousButtonchildren of the JSpinner.protected ComponentCreates an increment button, i.e. component that replaces the spinner value with the object returned byspinner.getNextValue.protected ComponentCreates a decrement button, i.e. component that replaces the spinner value with the object returned byspinner.getPreviousValue.protected PropertyChangeListenerCreates aPropertyChangeListenerthat can be added to the JSpinner itself.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.protected voidInstalls the keyboard Actions onto the JSpinner.protected voidInitializesPropertyChangeListenerwith a shared object that delegates interesting PropertyChangeEvents to protected methods.protected voidInstalls the necessary listeners on the next button,c, to update theJSpinnerin response to a user gesture.protected voidInstalls the necessary listeners on the previous button,c, to update theJSpinnerin response to a user gesture.voidCallsinstallDefaults,installListeners, and then adds the components returned bycreateNextButton,createPreviousButton, andcreateEditor.protected voidRemoves thePropertyChangeListeneradded by installListeners.voidCallsuninstallDefaults,uninstallListeners, and then removes all of the spinners children.Methods declared in class ComponentUI
contains, getAccessibleChild, getAccessibleChildrenCount, getMaximumSize, getMinimumSize, getPreferredSizeModifier 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.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.Returns the specified component's preferred size appropriate for the look and feel.Methods declared in 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
-
SynthSpinnerUI
public SynthSpinnerUI()Constructs aSynthSpinnerUI.
-
-
Method Details
-
createUI
Returns a new instance of SynthSpinnerUI.- Parameters:
c- the JSpinner (not used)- Returns:
- a new SynthSpinnerUI object
- See Also:
-
installDefaults
protected void installDefaults()Initializes theJSpinnerborder,foreground, andbackground, properties based on the corresponding "Spinner.*" properties from defaults table. TheJSpinnerslayout is set to the value returned bycreateLayout. This method is called byinstallUI.- Overrides:
installDefaultsin classBasicSpinnerUI- See Also:
-
uninstallDefaults
protected void uninstallDefaults()Sets theJSpinner'slayout manager to null. This method is called byuninstallUI.- Overrides:
uninstallDefaultsin classBasicSpinnerUI- See Also:
-
createEditor
This method is called by installUI to get the editor component of theJSpinner. By default it just returnsJSpinner.getEditor(). Subclasses can overridecreateEditorto return a component that contains the spinner's editor or null, if they're going to handle adding the editor to theJSpinnerin aninstallUIoverride.Typically this method would be overridden to wrap the editor with a container with a custom border, since one can't assume that the editors border can be set directly.
The
replaceEditormethod is called when the spinners editor is changed withJSpinner.setEditor. If you've overridden this method, then you'll probably want to overridereplaceEditoras well.- Overrides:
createEditorin classBasicSpinnerUI- Returns:
- the JSpinners editor JComponent, spinner.getEditor() by default
- See Also:
-
replaceEditor
Called by thePropertyChangeListenerwhen theJSpinnereditor property changes. It's the responsibility of this method to remove the old editor and add the new one. By default this operation is just:spinner.remove(oldEditor); spinner.add(newEditor, "Editor");
The implementation ofreplaceEditorshould be coordinated with thecreateEditormethod.- Overrides:
replaceEditorin classBasicSpinnerUI- Parameters:
oldEditor- an old instance of editornewEditor- a new instance of editor- See Also:
-
getContext
Returns the Context for the specified component.- Specified by:
getContextin interfaceSynthUI- Parameters:
c- Component requesting SynthContext.- Returns:
- SynthContext describing component.
-
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 classComponentUI- 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 classComponentUI- Parameters:
g- theGraphicsobject used for paintingc- the component being painted- See Also:
-
paint
Paints the specified component. This implementation does nothing.- 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.
-