Class BasicScrollBarUI
- All Implemented Interfaces:
-
LayoutManager
,SwingConstants
- Direct Known Subclasses:
-
MetalScrollBarUI
,SynthScrollBarUI
public class BasicScrollBarUI extends ScrollBarUI implements LayoutManager, SwingConstants
Nested Class Summary
Modifier and Type | Class | Description |
---|---|---|
protected class |
BasicScrollBarUI.ArrowButtonListener |
Listener for cursor keys. |
protected class |
BasicScrollBarUI.ModelListener |
A listener to listen for model changes. |
class |
BasicScrollBarUI.PropertyChangeHandler |
Property change handler |
protected class |
BasicScrollBarUI.ScrollListener |
Listener for scrolling events initiated in the ScrollPane . |
protected class |
BasicScrollBarUI.TrackListener |
Track mouse drags. |
Field Summary
Modifier and Type | Field | Description |
---|---|---|
protected BasicScrollBarUI.ArrowButtonListener |
buttonListener |
Button listener |
protected JButton |
decrButton |
Decrement button |
protected static final int |
DECREASE_HIGHLIGHT |
Decrease highlight |
protected int |
decrGap |
Distance between the decrement button and the track. |
protected JButton |
incrButton |
Increment button |
protected static final int |
INCREASE_HIGHLIGHT |
Increase highlight |
protected int |
incrGap |
Distance between the increment button and the track. |
protected boolean |
isDragging |
Dragging |
protected Dimension |
maximumThumbSize |
Maximum thumb size |
protected Dimension |
minimumThumbSize |
Minimum thumb size |
protected BasicScrollBarUI.ModelListener |
modelListener |
Model listener |
protected static final int |
NO_HIGHLIGHT |
No highlight |
protected PropertyChangeListener |
propertyChangeListener |
Property change listener |
protected JScrollBar |
scrollbar |
Scrollbar |
protected int |
scrollBarWidth |
Hint as to what width (when vertical) or height (when horizontal) should be. |
protected BasicScrollBarUI.ScrollListener |
scrollListener |
Scroll listener |
protected Timer |
scrollTimer |
Scroll timer |
protected Color |
thumbColor |
Thumb color |
protected Color |
thumbDarkShadowColor |
Thumb dark shadow color |
protected Color |
thumbHighlightColor |
Thumb highlight color |
protected Color |
thumbLightShadowColor |
Thumb light shadow color |
protected Rectangle |
thumbRect |
Thumb rectangle |
protected Color |
trackColor |
Track color |
protected int |
trackHighlight |
Track highlight |
protected Color |
trackHighlightColor |
Track highlight color |
protected BasicScrollBarUI.TrackListener |
trackListener |
Track listener |
protected Rectangle |
trackRect |
Track rectangle |
Fields declared in interface javax.swing.SwingConstants
BOTTOM, CENTER, EAST, HORIZONTAL, LEADING, LEFT, NEXT, NORTH, NORTH_EAST, NORTH_WEST, PREVIOUS, RIGHT, SOUTH, SOUTH_EAST, SOUTH_WEST, TOP, TRAILING, VERTICAL, WEST
Constructor Summary
Constructor | Description |
---|---|
BasicScrollBarUI() |
Constructs a BasicScrollBarUI . |
Method Summary
Modifier and Type | Method | Description |
---|---|---|
void |
addLayoutComponent |
If the layout manager uses a per-component string, adds the component comp to the layout, associating it with the string specified by name . |
protected void |
configureScrollBarColors() |
Configures the scroll bar colors. |
protected BasicScrollBarUI.ArrowButtonListener |
createArrowButtonListener() |
Creates an arrow button listener. |
protected JButton |
createDecreaseButton |
Creates a decrease button. |
protected JButton |
createIncreaseButton |
Creates an increase button. |
protected BasicScrollBarUI.ModelListener |
createModelListener() |
Creates a model listener. |
protected PropertyChangeListener |
createPropertyChangeListener() |
Creates a property change listener. |
protected BasicScrollBarUI.ScrollListener |
createScrollListener() |
Creates a scroll listener. |
protected BasicScrollBarUI.TrackListener |
createTrackListener() |
Creates a track listener. |
static ComponentUI |
createUI |
Creates the UI. |
Dimension |
getMaximumSize |
Returns the specified component's maximum size appropriate for the look and feel. |
protected Dimension |
getMaximumThumbSize() |
Returns the largest acceptable size for the thumb. |
protected Dimension |
getMinimumThumbSize() |
Returns the smallest acceptable size for the thumb. |
Dimension |
getPreferredSize |
A vertical scrollbar's preferred width is the maximum of preferred widths of the (non null ) increment/decrement buttons, and the minimum width of the thumb. |
boolean |
getSupportsAbsolutePositioning() |
Indicates whether the user can absolutely position the thumb with a mouse gesture (usually the middle mouse button). |
protected Rectangle |
getThumbBounds() |
Return the current size/location of the thumb. |
protected Rectangle |
getTrackBounds() |
Returns the current bounds of the track, i.e. the space in between the increment and decrement buttons, less the insets. |
protected void |
installComponents() |
Installs the components. |
protected void |
installDefaults() |
Installs the defaults. |
protected void |
installKeyboardActions() |
Installs the keyboard actions. |
protected void |
installListeners() |
Installs the listeners. |
void |
installUI |
Installs the UI. |
boolean |
isThumbRollover() |
Returns true if the mouse is currently over the thumb. |
void |
layoutContainer |
Lays out the specified container. |
protected void |
layoutHScrollbar |
Laysouts a vertical scroll bar. |
protected void |
layoutVScrollbar |
Laysouts a vertical scroll bar. |
Dimension |
minimumLayoutSize |
Calculates the minimum size dimensions for the specified container, given the components it contains. |
protected void |
paintDecreaseHighlight |
Paints the decrease highlight. |
protected void |
paintIncreaseHighlight |
Paints the increase highlight. |
protected void |
paintThumb |
Paints the thumb. |
protected void |
paintTrack |
Paints the track. |
Dimension |
preferredLayoutSize |
Calculates the preferred size dimensions for the specified container, given the components it contains. |
void |
removeLayoutComponent |
Removes the specified component from the layout. |
protected void |
scrollByBlock |
Scrolls by block. |
protected void |
scrollByUnit |
Scrolls by unit. |
protected void |
setThumbBounds |
Set the bounds of the thumb and force a repaint that includes the old thumbBounds and the new one. |
protected void |
setThumbRollover |
Sets whether or not the mouse is currently over the thumb. |
protected void |
uninstallComponents() |
Uninstalls the components. |
protected void |
uninstallDefaults() |
Uninstalls the defaults. |
protected void |
uninstallKeyboardActions() |
Uninstalls the keyboard actions. |
protected void |
uninstallListeners() |
Uninstall the listeners. |
void |
uninstallUI |
Uninstalls the UI. |
Methods declared in class javax.swing.plaf.ComponentUI
contains, getAccessibleChild, getAccessibleChildrenCount, getBaseline, getBaselineResizeBehavior, getMinimumSize, paint, update
Field Details
minimumThumbSize
protected Dimension minimumThumbSize
maximumThumbSize
protected Dimension maximumThumbSize
thumbHighlightColor
protected Color thumbHighlightColor
thumbLightShadowColor
protected Color thumbLightShadowColor
thumbDarkShadowColor
protected Color thumbDarkShadowColor
thumbColor
protected Color thumbColor
trackColor
protected Color trackColor
trackHighlightColor
protected Color trackHighlightColor
scrollbar
protected JScrollBar scrollbar
incrButton
protected JButton incrButton
decrButton
protected JButton decrButton
isDragging
protected boolean isDragging
trackListener
protected BasicScrollBarUI.TrackListener trackListener
buttonListener
protected BasicScrollBarUI.ArrowButtonListener buttonListener
modelListener
protected BasicScrollBarUI.ModelListener modelListener
thumbRect
protected Rectangle thumbRect
trackRect
protected Rectangle trackRect
trackHighlight
protected int trackHighlight
NO_HIGHLIGHT
protected static final int NO_HIGHLIGHT
- See Also:
DECREASE_HIGHLIGHT
protected static final int DECREASE_HIGHLIGHT
- See Also:
INCREASE_HIGHLIGHT
protected static final int INCREASE_HIGHLIGHT
- See Also:
scrollListener
protected BasicScrollBarUI.ScrollListener scrollListener
propertyChangeListener
protected PropertyChangeListener propertyChangeListener
scrollTimer
protected Timer scrollTimer
scrollBarWidth
protected int scrollBarWidth
- Since:
- 1.7
incrGap
protected int incrGap
- Since:
- 1.7
decrGap
protected int decrGap
- Since:
- 1.7
Constructor Details
BasicScrollBarUI
public BasicScrollBarUI()
BasicScrollBarUI
.Method Details
createUI
public static ComponentUI createUI(JComponent c)
- Parameters:
-
c
- the component - Returns:
- the UI
configureScrollBarColors
protected void configureScrollBarColors()
installUI
public void installUI(JComponent c)
- Overrides:
-
installUI
in classComponentUI
- Parameters:
-
c
- the component - See Also:
uninstallUI
public void uninstallUI(JComponent c)
- Overrides:
-
uninstallUI
in classComponentUI
- Parameters:
-
c
- the component - See Also:
installDefaults
protected void installDefaults()
installComponents
protected void installComponents()
uninstallComponents
protected void uninstallComponents()
installListeners
protected void installListeners()
installKeyboardActions
protected void installKeyboardActions()
uninstallKeyboardActions
protected void uninstallKeyboardActions()
uninstallListeners
protected void uninstallListeners()
uninstallDefaults
protected void uninstallDefaults()
createTrackListener
protected BasicScrollBarUI.TrackListener createTrackListener()
- Returns:
- a track listener
createArrowButtonListener
protected BasicScrollBarUI.ArrowButtonListener createArrowButtonListener()
- Returns:
- an arrow button listener
createModelListener
protected BasicScrollBarUI.ModelListener createModelListener()
- Returns:
- a model listener
createScrollListener
protected BasicScrollBarUI.ScrollListener createScrollListener()
- Returns:
- a scroll listener
createPropertyChangeListener
protected PropertyChangeListener createPropertyChangeListener()
- Returns:
- a property change listener
setThumbRollover
protected void setThumbRollover(boolean active)
- Parameters:
-
active
- True indicates the thumb is currently active. - Since:
- 1.5
isThumbRollover
public boolean isThumbRollover()
- Returns:
- true if the thumb is currently active
- Since:
- 1.5
getPreferredSize
public Dimension getPreferredSize(JComponent c)
null
) increment/decrement buttons, and the minimum width of the thumb. The preferred height is the sum of the preferred heights of the same parts. The basis for the preferred size of a horizontal scrollbar is similar. The preferredSize
is only computed once, subsequent calls to this method just return a cached size.
- Overrides:
-
getPreferredSize
in classComponentUI
- Parameters:
-
c
- theJScrollBar
that's delegating this method to us - Returns:
- the preferred size of a Basic JScrollBar
- See Also:
getMaximumSize
public Dimension getMaximumSize(JComponent c)
ComponentUI
null
is returned, the maximum size will be calculated by the component's layout manager instead (this is the preferred approach for any component with a specific layout manager installed). The default implementation of this method invokes getPreferredSize
and returns that value.- Overrides:
-
getMaximumSize
in classComponentUI
- Parameters:
-
c
- The JScrollBar that's delegating this method to us. - Returns:
- new Dimension(Integer.MAX_VALUE, Integer.MAX_VALUE);
- See Also:
createDecreaseButton
protected JButton createDecreaseButton(int orientation)
- Parameters:
-
orientation
- the orientation - Returns:
- a decrease button
createIncreaseButton
protected JButton createIncreaseButton(int orientation)
- Parameters:
-
orientation
- the orientation - Returns:
- an increase button
paintDecreaseHighlight
protected void paintDecreaseHighlight(Graphics g)
- Parameters:
-
g
- the graphics
paintIncreaseHighlight
protected void paintIncreaseHighlight(Graphics g)
- Parameters:
-
g
- the graphics
paintTrack
protected void paintTrack(Graphics g, JComponent c, Rectangle trackBounds)
- Parameters:
-
g
- the graphics -
c
- the component -
trackBounds
- the track bounds
paintThumb
protected void paintThumb(Graphics g, JComponent c, Rectangle thumbBounds)
- Parameters:
-
g
- the graphics -
c
- the component -
thumbBounds
- the thumb bounds
getMinimumThumbSize
protected Dimension getMinimumThumbSize()
Warning : the value returned by this method should not be be modified, it's a shared static constant.
- Returns:
- The smallest acceptable size for the thumb.
- See Also:
getMaximumThumbSize
protected Dimension getMaximumThumbSize()
getMinimumThumbSize
return the same value. Warning : the value returned by this method should not be be modified, it's a shared static constant.
- Returns:
- The largest acceptable size for the thumb.
- See Also:
addLayoutComponent
public void addLayoutComponent(String name, Component child)
LayoutManager
comp
to the layout, associating it with the string specified by name
.- Specified by:
-
addLayoutComponent
in interfaceLayoutManager
- Parameters:
-
name
- the string to be associated with the component -
child
- the component to be added
removeLayoutComponent
public void removeLayoutComponent(Component child)
LayoutManager
- Specified by:
-
removeLayoutComponent
in interfaceLayoutManager
- Parameters:
-
child
- the component to be removed
preferredLayoutSize
public Dimension preferredLayoutSize(Container scrollbarContainer)
LayoutManager
- Specified by:
-
preferredLayoutSize
in interfaceLayoutManager
- Parameters:
-
scrollbarContainer
- the container to be laid out - Returns:
- the preferred dimension for the container
- See Also:
minimumLayoutSize
public Dimension minimumLayoutSize(Container scrollbarContainer)
LayoutManager
- Specified by:
-
minimumLayoutSize
in interfaceLayoutManager
- Parameters:
-
scrollbarContainer
- the component to be laid out - Returns:
- the minimum dimension for the container
- See Also:
layoutVScrollbar
protected void layoutVScrollbar(JScrollBar sb)
- Parameters:
-
sb
- the scroll bar
layoutHScrollbar
protected void layoutHScrollbar(JScrollBar sb)
- Parameters:
-
sb
- the scroll bar
layoutContainer
public void layoutContainer(Container scrollbarContainer)
LayoutManager
- Specified by:
-
layoutContainer
in interfaceLayoutManager
- Parameters:
-
scrollbarContainer
- the container to be laid out
setThumbBounds
protected void setThumbBounds(int x, int y, int width, int height)
- Parameters:
-
x
- set the x location of the thumb -
y
- set the y location of the thumb -
width
- set the width of the thumb -
height
- set the height of the thumb - See Also:
getThumbBounds
protected Rectangle getThumbBounds()
Warning : the value returned by this method should not be be modified, it's a reference to the actual rectangle, not a copy.
- Returns:
- The current size/location of the thumb.
- See Also:
getTrackBounds
protected Rectangle getTrackBounds()
Warning : the value returned by this method should not be be modified, it's a reference to the actual rectangle, not a copy.
- Returns:
- the current bounds of the scrollbar track
- See Also:
scrollByBlock
protected void scrollByBlock(int direction)
- Parameters:
-
direction
- the direction to scroll
scrollByUnit
protected void scrollByUnit(int direction)
- Parameters:
-
direction
- the direction to scroll
getSupportsAbsolutePositioning
public boolean getSupportsAbsolutePositioning()
- Returns:
- true if a mouse gesture can absolutely position the thumb
- Since:
- 1.5
© 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/basic/BasicScrollBarUI.html