Class SynthSpinnerUI
- All Implemented Interfaces:
-
PropertyChangeListener
,EventListener
,SynthConstants
,SynthUI
public class SynthSpinnerUI extends BasicSpinnerUI implements PropertyChangeListener, SynthUI
JSpinner
.- Since:
- 1.7
Field Summary
Fields declared in class javax.swing.plaf.basic.BasicSpinnerUI
spinner
Fields declared in interface javax.swing.plaf.synth.SynthConstants
DEFAULT, DISABLED, ENABLED, FOCUSED, MOUSE_OVER, PRESSED, SELECTED
Constructor Summary
Constructor | Description |
---|---|
SynthSpinnerUI() |
Constructs a SynthSpinnerUI . |
Method Summary
Modifier and Type | Method | Description |
---|---|---|
protected JComponent |
createEditor() |
This method is called by installUI to get the editor component of the JSpinner . |
static ComponentUI |
createUI |
Returns a new instance of SynthSpinnerUI. |
SynthContext |
getContext |
Returns the Context for the specified component. |
protected void |
installDefaults() |
Initializes the JSpinner border , foreground , and background , properties based on the corresponding "Spinner.*" properties from defaults table. |
void |
paint |
Paints the specified component according to the Look and Feel. |
protected void |
paint |
Paints the specified component. |
void |
paintBorder |
Paints the border. |
void |
propertyChange |
This method gets called when a bound property is changed. |
protected void |
replaceEditor |
Called by the PropertyChangeListener when the JSpinner editor property changes. |
protected void |
uninstallDefaults() |
Sets the JSpinner's layout manager to null. |
void |
update |
Notifies this UI delegate to repaint the specified component. |
Methods declared in class javax.swing.plaf.basic.BasicSpinnerUI
createLayout, createNextButton, createPreviousButton, createPropertyChangeListener, getBaseline, getBaselineResizeBehavior, installKeyboardActions, installListeners, installNextButtonListeners, installPreviousButtonListeners, installUI, uninstallListeners, uninstallUI
Methods declared in class javax.swing.plaf.ComponentUI
contains, getAccessibleChild, getAccessibleChildrenCount, getMaximumSize, getMinimumSize, getPreferredSize
Constructor Details
SynthSpinnerUI
public SynthSpinnerUI()
SynthSpinnerUI
.Method Details
createUI
public static ComponentUI createUI(JComponent c)
- Parameters:
-
c
- the JSpinner (not used) - Returns:
- a new SynthSpinnerUI object
- See Also:
installDefaults
protected void installDefaults()
JSpinner
border
, foreground
, and background
, properties based on the corresponding "Spinner.*" properties from defaults table. The JSpinners
layout is set to the value returned by createLayout
. This method is called by installUI
.- Overrides:
-
installDefaults
in classBasicSpinnerUI
- See Also:
uninstallDefaults
protected void uninstallDefaults()
JSpinner's
layout manager to null. This method is called by uninstallUI
.- Overrides:
-
uninstallDefaults
in classBasicSpinnerUI
- See Also:
createEditor
protected JComponent createEditor()
JSpinner
. By default it just returns JSpinner.getEditor()
. Subclasses can override createEditor
to return a component that contains the spinner's editor or null, if they're going to handle adding the editor to the JSpinner
in an installUI
override. 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 replaceEditor
method is called when the spinners editor is changed with JSpinner.setEditor
. If you've overriden this method, then you'll probably want to override replaceEditor
as well.
- Overrides:
-
createEditor
in classBasicSpinnerUI
- Returns:
- the JSpinners editor JComponent, spinner.getEditor() by default
- See Also:
replaceEditor
protected void replaceEditor(JComponent oldEditor, JComponent newEditor)
PropertyChangeListener
when the JSpinner
editor 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 of
replaceEditor
should be coordinated with the createEditor
method.- Overrides:
-
replaceEditor
in classBasicSpinnerUI
- Parameters:
-
oldEditor
- an old instance of editor -
newEditor
- a new instance of editor - See Also:
getContext
public SynthContext getContext(JComponent c)
- Specified by:
-
getContext
in interfaceSynthUI
- Parameters:
-
c
- Component requesting SynthContext. - Returns:
- SynthContext describing component.
update
public void update(Graphics g, JComponent c)
paint(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 painting -
c
- the component being painted - See Also:
paint
public void paint(Graphics g, JComponent c)
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 painting -
c
- the component being painted - See Also:
paint
protected void paint(SynthContext context, Graphics g)
- Parameters:
-
context
- context for the component being painted -
g
- theGraphics
object used for painting - See Also:
paintBorder
public void paintBorder(SynthContext context, Graphics g, int x, int y, int w, int h)
- Specified by:
-
paintBorder
in interfaceSynthUI
- Parameters:
-
context
- a component context -
g
-Graphics
to paint on -
x
- the X coordinate -
y
- the Y coordinate -
w
- width of the border -
h
- height of the border
propertyChange
public void propertyChange(PropertyChangeEvent e)
- Specified by:
-
propertyChange
in interfacePropertyChangeListener
- Parameters:
-
e
- A PropertyChangeEvent object describing the event source and the property that has changed.
© 1993, 2021, Oracle and/or its affiliates. All rights reserved.
Documentation extracted from Debian's OpenJDK Development Kit package.
Licensed under the GNU General Public License, version 2, with the Classpath Exception.
Various third party code in OpenJDK is licensed under different licenses (see Debian package).
Java and OpenJDK are trademarks or registered trademarks of Oracle and/or its affiliates.
https://docs.oracle.com/en/java/javase/17/docs/api/java.desktop/javax/swing/plaf/synth/SynthSpinnerUI.html