Java 教程是为 JDK 8 编写的。本页中描述的示例和实践未利用在后续版本中引入的改进。
A change listener is similar to a property change listener. A change listener is registered on an object — typically a component, but it could be another object, like a model — and the listener is notified when the object has changed. The big difference from a property change listener is that a change listener is not notified of what has changed, but simply that the source object has changed. Therefore, a change listener is most useful when it is only necessary to know when an object has changed in any way.
Several Swing components (including JTabbedPane, JViewPort) rely on change events for basic functionality — sliders, color choosers and spinners. To learn when the value in a slider changes, you need to register a change listener. Similarly, you need to register a change listener on a color chooser to be informed when the user chooses a new color. You register a change listener on a spinner, to be notified when the spinner's value changes.
Here is an example of change event handling code for a slider:
//...where initialization occurs: framesPerSecond.addChangeListener(new SliderListener()); ... class SliderListener implements ChangeListener { public void stateChanged(ChangeEvent e) { JSlider source = (JSlider)e.getSource(); if (!source.getValueIsAdjusting()) { int fps = (int)source.getValue(); ... } } }
You can find the source file for SliderDemo
in the
example index for Using Swing Components.
Because ChangeListener
has only one method, it has no corresponding adapter class.
方法 | 目的 |
---|---|
stateChanged(ChangeEvent) | Called when the listened-to component changes state. |
方法 | 目的 |
---|---|
Object getSource() (in java.util.EventObject ) |
Returns the object that fired the event. |
The following table lists the examples that use change listeners.
例子 | Where Described | Notes |
---|---|---|
SliderDemo andSliderDemo2 |
如何使用滑块 | Registers a change listener on a slider that controls animation speed. The change listener ignores the change events until the user releases the slider. |
ColorChooserDemo andColorChooserDemo2 |
如何使用颜色选择器 | Uses a change listener on the selection model of a color chooser to learn when the user changes the current color. |
SpinnerDemo3 |
Detecting Spinner Value Changesin How to Use Spinners. | Uses a change listener on a date-field spinner to change the color of the text as the spinner's date changes. |
SpinnerDemo4 |
Detecting Spinner Value Changesin How to Use Spinners. | Uses a change listener on a spinner to cycle through the gray scale as the spinner's value changes. |
ConverterRangeModel and its subclass, FollowerRangeModel |
如何使用模型 | Implement custom models for the sliders used in the Converter demo. Both models explicitly fire change events when necessary. |