Interface KeyEventDispatcher
- All Known Implementing Classes:
-
DefaultFocusManager
,DefaultKeyboardFocusManager
,FocusManager
,KeyboardFocusManager
- Functional Interface:
- This is a functional interface and can therefore be used as the assignment target for a lambda expression or method reference.
@FunctionalInterface public interface KeyEventDispatcher
Note that KeyboardFocusManager itself implements KeyEventDispatcher. By default, the current KeyboardFocusManager will be the sink for all KeyEvents not dispatched by the registered KeyEventDispatchers. The current KeyboardFocusManager cannot be completely deregistered as a KeyEventDispatcher. However, if a KeyEventDispatcher reports that it dispatched the KeyEvent, regardless of whether it actually did so, the KeyboardFocusManager will take no further action with regard to the KeyEvent. (While it is possible for client code to register the current KeyboardFocusManager as a KeyEventDispatcher one or more times, this is usually unnecessary and not recommended.)
Method Summary
Modifier and Type | Method | Description |
---|---|---|
boolean |
dispatchKeyEvent |
This method is called by the current KeyboardFocusManager requesting that this KeyEventDispatcher dispatch the specified event on its behalf. |
Method Details
dispatchKeyEvent
boolean dispatchKeyEvent(KeyEvent e)
redispatchEvent
to prevent the current KeyboardFocusManager from recursively requesting that this KeyEventDispatcher dispatch the event again. If an implementation of this method returns false
, then the KeyEvent is passed to the next KeyEventDispatcher in the chain, ending with the current KeyboardFocusManager. If an implementation returns true
, the KeyEvent is assumed to have been dispatched (although this need not be the case), and the current KeyboardFocusManager will take no further action with regard to the KeyEvent. In such a case, KeyboardFocusManager.dispatchEvent
should return true
as well. If an implementation consumes the KeyEvent, but returns false
, the consumed event will still be passed to the next KeyEventDispatcher in the chain. It is important for developers to check whether the KeyEvent has been consumed before dispatching it to a target. By default, the current KeyboardFocusManager will not dispatch a consumed KeyEvent.
- Parameters:
-
e
- the KeyEvent to dispatch - Returns:
-
true
if the KeyboardFocusManager should take no further action with regard to the KeyEvent;false
otherwise - 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/java/awt/KeyEventDispatcher.html