Interface BoundedRangeModel
- All Known Implementing Classes:
DefaultBoundedRangeModel
public interface BoundedRangeModel
Slider
s and ProgressBar
s. Defines four interrelated integer properties: minimum, maximum, extent and value. These four integers define two nested ranges like this: minimum <= value <= value+extent <= maximumThe outer range is
minimum,maximum
and the inner range is value,value+extent
. The inner range must lie within the outer one, i.e. value
must be less than or equal to maximum
and value+extent
must greater than or equal to minimum
, and maximum
must be greater than or equal to minimum
. There are a few features of this model that one might find a little surprising. These quirks exist for the convenience of the Swing BoundedRangeModel clients, such as Slider
and ScrollBar
. - The minimum and maximum set methods "correct" the other three properties to accommodate their new value argument. For example setting the model's minimum may change its maximum, value, and extent properties (in that order), to maintain the constraints specified above.
- The value and extent set methods "correct" their argument to fit within the limits defined by the other three properties. For example if
value == maximum
,setExtent(10)
would change the extent (back) to zero. - The four BoundedRangeModel values are defined as Java Beans properties however Swing ChangeEvents are used to notify clients of changes rather than PropertyChangeEvents. This was done to keep the overhead of monitoring a BoundedRangeModel low. Changes are often reported at MouseDragged rates.
For an example of specifying custom bounded range models used by sliders, see Separable model architecture in A Swing Architecture Overview.
- Since:
- 1.2
- See Also:
Method Summary
Modifier and Type | Method | Description |
---|---|---|
void |
addChangeListener |
Adds a ChangeListener to the model's listener list. |
int |
getExtent() |
Returns the model's extent, the length of the inner range that begins at the model's value. |
int |
getMaximum() |
Returns the model's maximum. |
int |
getMinimum() |
Returns the minimum acceptable value. |
int |
getValue() |
Returns the model's current value. |
boolean |
getValueIsAdjusting() |
Returns true if the current changes to the value property are part of a series of changes. |
void |
removeChangeListener |
Removes a ChangeListener from the model's listener list. |
void |
setExtent |
Sets the model's extent. |
void |
setMaximum |
Sets the model's maximum to newMaximum. |
void |
setMinimum |
Sets the model's minimum to newMinimum. |
void |
setRangeProperties |
This method sets all of the model's data with a single method call. |
void |
setValue |
Sets the model's current value to newValue if newValue satisfies the model's constraints. |
void |
setValueIsAdjusting |
This attribute indicates that any upcoming changes to the value of the model should be considered a single event. |
Method Details
getMinimum
int getMinimum()
- Returns:
- the value of the minimum property
- See Also:
setMinimum
void setMinimum(int newMinimum)
minimum <= value <= value+extent <= maximum
Notifies any listeners if the model changes.
- Parameters:
-
newMinimum
- the model's new minimum - See Also:
getMaximum
int getMaximum()
- Returns:
- the value of the maximum property.
- See Also:
setMaximum
void setMaximum(int newMaximum)
minimum <= value <= value+extent <= maximum
Notifies any listeners if the model changes.
- Parameters:
-
newMaximum
- the model's new maximum - See Also:
getValue
int getValue()
maximum - extent
and the lower limit is minimum
.- Returns:
- the model's value
- See Also:
setValue
void setValue(int newValue)
newValue
if newValue
satisfies the model's constraints. Those constraints are: minimum <= value <= value+extent <= maximumOtherwise, if
newValue
is less than minimum
it's set to minimum
, if its greater than maximum
then it's set to maximum
, and if it's greater than value+extent
then it's set to value+extent
. When a BoundedRange model is used with a scrollbar the value specifies the origin of the scrollbar knob (aka the "thumb" or "elevator"). The value usually represents the origin of the visible part of the object being scrolled.
Notifies any listeners if the model changes.
- Parameters:
-
newValue
- the model's new value - See Also:
setValueIsAdjusting
void setValueIsAdjusting(boolean b)
Sliders and scrollbars use this property when a drag is underway.
- Parameters:
-
b
- true if the upcoming changes to the value property are part of a series
getValueIsAdjusting
boolean getValueIsAdjusting()
- Returns:
- the valueIsAdjustingProperty.
- See Also:
getExtent
int getExtent()
- Returns:
- the value of the model's extent property
- See Also:
setExtent
void setExtent(int newExtent)
When a BoundedRange model is used with a scrollbar the extent defines the length of the scrollbar knob (aka the "thumb" or "elevator"). The extent usually represents how much of the object being scrolled is visible. When used with a slider, the extent determines how much the value can "jump", for example when the user presses PgUp or PgDn.
Notifies any listeners if the model changes.
- Parameters:
-
newExtent
- the model's new extent - See Also:
setRangeProperties
void setRangeProperties(int value, int extent, int min, int max, boolean adjusting)
- Parameters:
-
value
- an int giving the current value -
extent
- an int giving the amount by which the value can "jump" -
min
- an int giving the minimum value -
max
- an int giving the maximum value -
adjusting
- a boolean, true if a series of changes are in progress - See Also:
addChangeListener
void addChangeListener(ChangeListener x)
- Parameters:
-
x
- the ChangeListener to add - See Also:
removeChangeListener
void removeChangeListener(ChangeListener x)
- Parameters:
-
x
- the ChangeListener to remove - See Also:
© 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/BoundedRangeModel.html