InputMethodSession
public
interface
InputMethodSession
android.view.inputmethod.InputMethodSession |
The InputMethodSession interface provides the per-client functionality
of InputMethod
that is safe to expose to applications.
Applications will not normally use this interface themselves, instead
relying on the standard interaction provided by
TextView
and EditText
.
Summary
Nested classes | |
---|---|
interface |
InputMethodSession.EventCallback
|
Public methods | |
---|---|
abstract
void
|
appPrivateCommand(String action, Bundle data)
Process a private command sent from the application to the input method. |
abstract
void
|
dispatchGenericMotionEvent(int seq, MotionEvent event, InputMethodSession.EventCallback callback)
This method is called when there is a generic motion event. |
abstract
void
|
dispatchKeyEvent(int seq, KeyEvent event, InputMethodSession.EventCallback callback)
This method is called when a key is pressed. |
abstract
void
|
dispatchTrackballEvent(int seq, MotionEvent event, InputMethodSession.EventCallback callback)
This method is called when there is a track ball event. |
abstract
void
|
displayCompletions(CompletionInfo[] completions)
Called by a text editor that performs auto completion, to tell the input method about the completions it has available. |
abstract
void
|
finishInput()
This method is called when the application would like to stop receiving text input. |
abstract
void
|
toggleSoftInput(int showFlags, int hideFlags)
This method was deprecated
in API level 31.
Starting in |
abstract
void
|
updateCursor(Rect newCursor)
This method is called when cursor location of the target input field has changed within its window. |
abstract
void
|
updateCursorAnchorInfo(CursorAnchorInfo cursorAnchorInfo)
This method is called when the cursor and/or the character position relevant to text input is changed on the screen. |
abstract
void
|
updateExtractedText(int token, ExtractedText text)
Called by a text editor to report its new extracted text when its contents change. |
abstract
void
|
updateSelection(int oldSelStart, int oldSelEnd, int newSelStart, int newSelEnd, int candidatesStart, int candidatesEnd)
This method is called when the selection or cursor in the current target input field has changed. |
abstract
void
|
viewClicked(boolean focusChanged)
This method is called when the user tapped a text view. |
Public methods
appPrivateCommand
public abstract void appPrivateCommand (String action, Bundle data)
Process a private command sent from the application to the input method. This can be used to provide domain-specific features that are only known between certain input methods and their clients.
Parameters | |
---|---|
action |
String : Name of the command to be performed. This must
be a scoped name, i.e. prefixed with a package name you own, so that
different developers will not create conflicting commands. |
data |
Bundle : Any data to include with the command. |
dispatchGenericMotionEvent
public abstract void dispatchGenericMotionEvent (int seq, MotionEvent event, InputMethodSession.EventCallback callback)
This method is called when there is a generic motion event.
If the input method wants to handle this event, return true, otherwise return false and the caller (i.e. the application) will handle the event.
Parameters | |
---|---|
seq |
int |
event |
MotionEvent : The motion event. |
callback |
InputMethodSession.EventCallback |
Returns | |
---|---|
void |
Whether the input method wants to handle this event. |
See also:
dispatchKeyEvent
public abstract void dispatchKeyEvent (int seq, KeyEvent event, InputMethodSession.EventCallback callback)
This method is called when a key is pressed. When done with the event, the implementation must call back on callback with its result.
If the input method wants to handle this event, return true, otherwise return false and the caller (i.e. the application) will handle the event.
Parameters | |
---|---|
seq |
int |
event |
KeyEvent : The key event. |
callback |
InputMethodSession.EventCallback |
Returns | |
---|---|
void |
Whether the input method wants to handle this event. |
See also:
dispatchTrackballEvent
public abstract void dispatchTrackballEvent (int seq, MotionEvent event, InputMethodSession.EventCallback callback)
This method is called when there is a track ball event.
If the input method wants to handle this event, return true, otherwise return false and the caller (i.e. the application) will handle the event.
Parameters | |
---|---|
seq |
int |
event |
MotionEvent : The motion event. |
callback |
InputMethodSession.EventCallback |
Returns | |
---|---|
void |
Whether the input method wants to handle this event. |
See also:
displayCompletions
public abstract void displayCompletions (CompletionInfo[] completions)
Called by a text editor that performs auto completion, to tell the input method about the completions it has available. This can be used by the input method to display them to the user to select the text to be inserted.
Parameters | |
---|---|
completions |
CompletionInfo : Array of text completions that are available, starting with
the best. If this array is null, any existing completions will be
removed. |
finishInput
public abstract void finishInput ()
This method is called when the application would like to stop receiving text input.
toggleSoftInput
public abstract void toggleSoftInput (int showFlags, int hideFlags)
This method was deprecated
in API level 31.
Starting in Build.VERSION_CODES.S
the system no longer invokes
this method, instead it explicitly shows or hides the IME. An InputMethodService
wishing to toggle its own visibility should instead invoke InputMethodService.requestShowSelf(int)
or InputMethodService.requestHideSelf
Toggle the soft input window. Applications can toggle the state of the soft input window.
Parameters | |
---|---|
showFlags |
int : Value is either 0 or a combination of InputMethodManager.SHOW_IMPLICIT , and InputMethodManager.SHOW_FORCED |
hideFlags |
int : Value is either 0 or a combination of InputMethodManager.HIDE_IMPLICIT_ONLY , and InputMethodManager.HIDE_NOT_ALWAYS |
updateCursor
public abstract void updateCursor (Rect newCursor)
This method is called when cursor location of the target input field has changed within its window. This is not normally called, but will only be reported if requested by the input method.
Parameters | |
---|---|
newCursor |
Rect : The rectangle of the cursor currently being shown in
the input field's window coordinates. |
updateCursorAnchorInfo
public abstract void updateCursorAnchorInfo (CursorAnchorInfo cursorAnchorInfo)
This method is called when the cursor and/or the character position relevant to text input is changed on the screen. This is not called by default. It will only be reported if requested by the input method.
Parameters | |
---|---|
cursorAnchorInfo |
CursorAnchorInfo : Positional information relevant to text input, such as text
insertion point and composition string. |
updateExtractedText
public abstract void updateExtractedText (int token, ExtractedText text)
Called by a text editor to report its new extracted text when its
contents change. This will only be called if the input method
calls InputConnection.getExtractedText()
with the option to report updates.
Parameters | |
---|---|
token |
int : The input method supplied token for identifying its request. |
text |
ExtractedText : The new extracted text. |
updateSelection
public abstract void updateSelection (int oldSelStart, int oldSelEnd, int newSelStart, int newSelEnd, int candidatesStart, int candidatesEnd)
This method is called when the selection or cursor in the current target input field has changed.
Parameters | |
---|---|
oldSelStart |
int : The previous text offset of the cursor selection
start position. |
oldSelEnd |
int : The previous text offset of the cursor selection
end position. |
newSelStart |
int : The new text offset of the cursor selection
start position. |
newSelEnd |
int : The new text offset of the cursor selection
end position. |
candidatesStart |
int : The text offset of the current candidate
text start position. |
candidatesEnd |
int : The text offset of the current candidate
text end position. |
viewClicked
public abstract void viewClicked (boolean focusChanged)
This method is called when the user tapped a text view. IMEs can't rely on this method being called because this was not part of the original IME protocol, so applications with custom text editing written before this method appeared will not call to inform the IME of this interaction.
Parameters | |
---|---|
focusChanged |
boolean : true if the user changed the focused view by this click. |
Content and code samples on this page are subject to the licenses described in the Content License. Java and OpenJDK are trademarks or registered trademarks of Oracle and/or its affiliates.
Last updated 2025-01-23 UTC.