Added in API level 3

BaseInputConnection


open class BaseInputConnection : InputConnection

Base class for implementors of the InputConnection interface, taking care of most of the common behavior for providing a connection to an Editable. Implementors of this class will want to be sure to implement getEditable to provide access to their own editable object, and to refer to the documentation in InputConnection.

Summary

Inherited constants
Int CURSOR_UPDATE_FILTER_CHARACTER_BOUNDS

The editor is requested to call InputMethodManager.updateCursorAnchorInfo(android.view.View, CursorAnchorInfo) with new character bounds CursorAnchorInfo.getCharacterBounds(int) whenever cursor/anchor position is changed. To disable monitoring, call InputConnection.requestCursorUpdates(int) again with this flag off.

This flag can be combined with other filters: CURSOR_UPDATE_FILTER_EDITOR_BOUNDS, CURSOR_UPDATE_FILTER_VISIBLE_LINE_BOUNDS, CURSOR_UPDATE_FILTER_TEXT_APPEARANCE, CURSOR_UPDATE_FILTER_INSERTION_MARKER and update flags CURSOR_UPDATE_IMMEDIATE and CURSOR_UPDATE_MONITOR.

Int CURSOR_UPDATE_FILTER_EDITOR_BOUNDS

The editor is requested to call InputMethodManager.updateCursorAnchorInfo(android.view.View, CursorAnchorInfo) with new EditorBoundsInfo whenever cursor/anchor position is changed. To disable monitoring, call InputConnection.requestCursorUpdates(int) again with this flag off.

This flag can be used together with filters: CURSOR_UPDATE_FILTER_CHARACTER_BOUNDS, CURSOR_UPDATE_FILTER_VISIBLE_LINE_BOUNDS, CURSOR_UPDATE_FILTER_TEXT_APPEARANCE, CURSOR_UPDATE_FILTER_INSERTION_MARKER and update flags CURSOR_UPDATE_IMMEDIATE and CURSOR_UPDATE_MONITOR.

Int CURSOR_UPDATE_FILTER_INSERTION_MARKER

The editor is requested to call InputMethodManager.updateCursorAnchorInfo(android.view.View, CursorAnchorInfo) with new Insertion marker info CursorAnchorInfo.getInsertionMarkerFlags(), CursorAnchorInfo.getInsertionMarkerBaseline(), etc whenever cursor/anchor position is changed. To disable monitoring, call InputConnection.requestCursorUpdates(int) again with this flag off.

This flag can be combined with other filters: CURSOR_UPDATE_FILTER_CHARACTER_BOUNDS, CURSOR_UPDATE_FILTER_VISIBLE_LINE_BOUNDS, CURSOR_UPDATE_FILTER_TEXT_APPEARANCE, CURSOR_UPDATE_FILTER_EDITOR_BOUNDS and update flags CURSOR_UPDATE_IMMEDIATE and CURSOR_UPDATE_MONITOR.

Int CURSOR_UPDATE_FILTER_TEXT_APPEARANCE

The editor is requested to call InputMethodManager.updateCursorAnchorInfo(android.view.View, CursorAnchorInfo) with new text appearance info CursorAnchorInfo.getTextAppearanceInfo()} whenever cursor/anchor position is changed. To disable monitoring, call InputConnection.requestCursorUpdates(int) again with this flag off.

This flag can be combined with other filters: CURSOR_UPDATE_FILTER_CHARACTER_BOUNDS, CURSOR_UPDATE_FILTER_EDITOR_BOUNDS, CURSOR_UPDATE_FILTER_INSERTION_MARKER, CURSOR_UPDATE_FILTER_VISIBLE_LINE_BOUNDS and update flags CURSOR_UPDATE_IMMEDIATE and CURSOR_UPDATE_MONITOR.

Int CURSOR_UPDATE_FILTER_VISIBLE_LINE_BOUNDS

The editor is requested to call InputMethodManager.updateCursorAnchorInfo(android.view.View, CursorAnchorInfo) with new visible line bounds CursorAnchorInfo.getVisibleLineBounds() whenever cursor/anchor position is changed, the editor or its parent is scrolled or the line bounds changed due to text updates. To disable monitoring, call InputConnection.requestCursorUpdates(int) again with this flag off.

This flag can be combined with other filters: CURSOR_UPDATE_FILTER_CHARACTER_BOUNDS, CURSOR_UPDATE_FILTER_EDITOR_BOUNDS, CURSOR_UPDATE_FILTER_INSERTION_MARKER, CURSOR_UPDATE_FILTER_TEXT_APPEARANCE and update flags CURSOR_UPDATE_IMMEDIATE and CURSOR_UPDATE_MONITOR.

Int CURSOR_UPDATE_IMMEDIATE

The editor is requested to call InputMethodManager.updateCursorAnchorInfo(android.view.View, CursorAnchorInfo) at once, as soon as possible, regardless of cursor/anchor position changes. This flag can be used together with CURSOR_UPDATE_MONITOR.

Note by default all of CURSOR_UPDATE_FILTER_EDITOR_BOUNDS, CURSOR_UPDATE_FILTER_CHARACTER_BOUNDS, CURSOR_UPDATE_FILTER_VISIBLE_LINE_BOUNDS, CURSOR_UPDATE_FILTER_TEXT_APPEARANCE, and CURSOR_UPDATE_FILTER_INSERTION_MARKER, are included but specifying them can filter-out others. It can be CPU intensive to include all, filtering specific info is recommended.

Int CURSOR_UPDATE_MONITOR

The editor is requested to call InputMethodManager.updateCursorAnchorInfo(android.view.View, CursorAnchorInfo) whenever cursor/anchor position is changed. To disable monitoring, call InputConnection.requestCursorUpdates(int) again with this flag off.

This flag can be used together with CURSOR_UPDATE_IMMEDIATE.

Note by default all of CURSOR_UPDATE_FILTER_EDITOR_BOUNDS, CURSOR_UPDATE_FILTER_CHARACTER_BOUNDS, CURSOR_UPDATE_FILTER_VISIBLE_LINE_BOUNDS, CURSOR_UPDATE_FILTER_TEXT_APPEARANCE, and CURSOR_UPDATE_FILTER_INSERTION_MARKER, are included but specifying them can filter-out others. It can be CPU intensive to include all, filtering specific info is recommended.

Int GET_EXTRACTED_TEXT_MONITOR

Flag for use with getExtractedText to indicate you would like to receive updates when the extracted text changes.

Int GET_TEXT_WITH_STYLES

Flag for use with getTextAfterCursor, getTextBeforeCursor and getSurroundingText to have style information returned along with the text. If not set, getTextAfterCursor sends only the raw text, without style or other spans. If set, it may return a complex CharSequence of both text and style spans. Editor authors: you should strive to send text with styles if possible, but it is not required.

Int HANDWRITING_GESTURE_RESULT_CANCELLED

Result for performHandwritingGesture(android.view.inputmethod.HandwritingGesture,java.util.concurrent.Executor,java.util.function.IntConsumer) when HandwritingGesture was cancelled. This happens when the InputConnection is or becomes invalidated while performing the gesture, for example because a new InputConnection was started, or due to InputMethodManager.invalidateInput.

Int HANDWRITING_GESTURE_RESULT_FAILED

Result for performHandwritingGesture(android.view.inputmethod.HandwritingGesture,java.util.concurrent.Executor,java.util.function.IntConsumer) when HandwritingGesture failed and there was no applicable HandwritingGesture.getFallbackText() or it couldn't be applied for any other reason.

Int HANDWRITING_GESTURE_RESULT_FALLBACK

Result for performHandwritingGesture(android.view.inputmethod.HandwritingGesture,java.util.concurrent.Executor,java.util.function.IntConsumer) when HandwritingGesture failed but HandwritingGesture.getFallbackText() was committed.

Int HANDWRITING_GESTURE_RESULT_SUCCESS

Result for performHandwritingGesture(android.view.inputmethod.HandwritingGesture,java.util.concurrent.Executor,java.util.function.IntConsumer) when HandwritingGesture is successfully executed on text.

Int HANDWRITING_GESTURE_RESULT_UNKNOWN

Result for performHandwritingGesture(android.view.inputmethod.HandwritingGesture,java.util.concurrent.Executor,java.util.function.IntConsumer) when editor didn't provide any result.

Int HANDWRITING_GESTURE_RESULT_UNSUPPORTED

Result for performHandwritingGesture(android.view.inputmethod.HandwritingGesture,java.util.concurrent.Executor,java.util.function.IntConsumer) when HandwritingGesture is unsupported by the current editor.

Int INPUT_CONTENT_GRANT_READ_URI_PERMISSION

When this flag is used, the editor will be able to request read access to the content URI contained in the InputContentInfo object.

Make sure that the content provider owning the Uri sets the grantUriPermissions attribute in its manifest or included the <grant-uri-permissions> tag. Otherwise InputContentInfo.requestPermission() can fail.

Although calling this API is allowed only for the IME that is currently selected, the client is able to request a temporary read-only access even after the current IME is switched to any other IME as long as the client keeps InputContentInfo object.

Public constructors
BaseInputConnection(targetView: View, fullEditor: Boolean)

Public methods
open Boolean

Default implementation does nothing.

open Boolean

Default implementation uses MetaKeyKeyListener.clearMetaKeyState(long, int) to clear the state.

open Unit

Default implementation calls finishComposingText() and setImeConsumesInput(false).

open Boolean

Default implementation does nothing and returns false.

open Boolean
commitContent(inputContentInfo: InputContentInfo, flags: Int, opts: Bundle?)

Default implementation which invokes View.performReceiveContent on the target view if the view allows content insertion; otherwise returns false without any side effects.

open Boolean
commitCorrection(correctionInfo: CorrectionInfo!)

Default implementation does nothing and returns false.

open Boolean
commitText(text: CharSequence!, newCursorPosition: Int)

Default implementation replaces any existing composing text with the given text.

open Boolean
deleteSurroundingText(beforeLength: Int, afterLength: Int)

The default implementation performs the deletion around the current selection position of the editable text.

open Boolean
deleteSurroundingTextInCodePoints(beforeLength: Int, afterLength: Int)

The default implementation performs the deletion around the current selection position of the editable text.

open Boolean

Default implementation does nothing.

open Boolean

The default implementation removes the composing state from the current editable text.

open static Int

Return the end of the range of composing text, or -1 if there's no composing text.

open static Int

Return the beginning of the range of composing text, or -1 if there's no composing text.

open Int

The default implementation uses TextUtils.

open Editable?

Return the target of edit operations.

open ExtractedText?

The default implementation always returns null.

open Handler?

Called by the system to enable application developers to specify a dedicated thread on which InputConnection methods are called back.

open CharSequence?

The default implementation returns the text currently selected, or null if none is selected.

open SurroundingText?
getSurroundingText(beforeLength: Int, afterLength: Int, flags: Int)

The default implementation returns the given amount of text around the current cursor position in the buffer.

open CharSequence?
getTextAfterCursor(length: Int, flags: Int)

The default implementation returns the given amount of text from the current cursor position in the buffer.

open CharSequence?
getTextBeforeCursor(length: Int, flags: Int)

The default implementation returns the given amount of text from the current cursor position in the buffer.

open Boolean

The default implementation does nothing.

open Boolean
performEditorAction(actionCode: Int)

The default implementation turns this into the enter key.

open Boolean
performPrivateCommand(action: String!, data: Bundle!)

The default implementation does nothing.

static Unit

Removes the composing spans from the given text if any.

open Boolean
replaceText(start: Int, end: Int, text: CharSequence, newCursorPosition: Int, textAttribute: TextAttribute?)

Replace the specific range in the editor with suggested text.

open Boolean

Updates InputMethodManager with the current fullscreen mode.

open Boolean
requestCursorUpdates(cursorUpdateMode: Int)

The default implementation does nothing.

open Boolean

Provides standard implementation for sending a key event to the window attached to the input connection's view.

open Boolean
setComposingRegion(start: Int, end: Int)

open static Unit

Removes the composing spans from the given text if any.

open Boolean
setComposingText(text: CharSequence!, newCursorPosition: Int)

The default implementation places the given text into the editable, replacing any existing composing text.

open Boolean
setSelection(start: Int, end: Int)

The default implementation changes the selection position in the current editable text.

open TextSnapshot?

Default implementation that constructs TextSnapshot with information extracted from BaseInputConnection.

Inherited functions
Boolean commitText(text: CharSequence, newCursorPosition: Int, textAttribute: TextAttribute?)

The variant of InputConnection.commitText(CharSequence, int). This method is used to allow the IME to provide extra information while setting up text.

Unit performHandwritingGesture(gesture: HandwritingGesture, executor: Executor?, consumer: IntConsumer?)

Perform a handwriting gesture on text.

Note: A supported gesture EditorInfo.getSupportedHandwritingGestures() may not have preview supported EditorInfo.getSupportedHandwritingGesturePreviews().

Boolean performSpellCheck()

Have the editor perform spell checking for the full content.

The editor can ignore this method call if it does not support spell checking.

Boolean previewHandwritingGesture(gesture: PreviewableHandwritingGesture, cancellationSignal: CancellationSignal?)

Preview a handwriting gesture on text. Provides a real-time preview for a gesture to user for an ongoing gesture. e.g. as user begins to draw a circle around text, resulting selection SelectGesture is previewed while stylus is moving over applicable text.

Note: A supported gesture EditorInfo.getSupportedHandwritingGestures() might not have preview supported EditorInfo.getSupportedHandwritingGesturePreviews().

Boolean requestCursorUpdates(cursorUpdateMode: Int, cursorUpdateFilter: Int)

Called by the input method to ask the editor for calling back InputMethodManager.updateCursorAnchorInfo(android.view.View, CursorAnchorInfo) to notify cursor/anchor locations.

Unit requestTextBoundsInfo(bounds: RectF, executor: Executor, consumer: Consumer<TextBoundsInfoResult!>)

Called by input method to request the TextBoundsInfo for a range of text which is covered by or in vicinity of the given bounds. It can be used as a supplementary method to implement the handwriting gesture API - performHandwritingGesture(android.view.inputmethod.HandwritingGesture,java.util.concurrent.Executor,java.util.function.IntConsumer).

Editor authors: It's preferred that the editor returns a TextBoundsInfo of all the text lines whose bounds intersect with the given bounds.

IME authors: This method is expensive when the text is long. Please consider that both the text bounds computation and IPC round-trip to send the data are time consuming. It's preferable to only request text bounds in smaller areas.

Boolean setComposingRegion(start: Int, end: Int, textAttribute: TextAttribute?)

The variant of InputConnection.setComposingRegion(int, int). This method is used to allow the IME to provide extra information while setting up text.

Boolean setComposingText(text: CharSequence, newCursorPosition: Int, textAttribute: TextAttribute?)

The variant of setComposingText(java.lang.CharSequence,int). This method is used to allow the IME to provide extra information while setting up composing text.

Boolean setImeConsumesInput(imeConsumesInput: Boolean)

Called by the input method to indicate that it consumes all input for itself, or no longer does so.

Editors should reflect that they are not receiving input by hiding the cursor if imeConsumesInput is true, and resume showing the cursor if it is false.

Public constructors

BaseInputConnection

Added in API level 3
BaseInputConnection(
    targetView: View,
    fullEditor: Boolean)
Parameters
targetView View: This value cannot be null.

Public methods

beginBatchEdit

Added in API level 3
open fun beginBatchEdit(): Boolean

Default implementation does nothing.

Return
Boolean true if a batch edit is now in progress, false otherwise. Since this method starts a batch edit, that means it will always return true unless the input connection is no longer valid.

clearMetaKeyStates

Added in API level 3
open fun clearMetaKeyStates(states: Int): Boolean

Default implementation uses MetaKeyKeyListener.clearMetaKeyState(long, int) to clear the state.

Parameters
states Int: The states to be cleared, may be one or more bits as per KeyEvent.getMetaState().
Return
Boolean true on success, false if the input connection is no longer valid.

closeConnection

Added in API level 24
open fun closeConnection(): Unit

Default implementation calls finishComposingText() and setImeConsumesInput(false).
If you override this method you must call through to the superclass implementation.

commitCompletion

Added in API level 3
open fun commitCompletion(text: CompletionInfo!): Boolean

Default implementation does nothing and returns false.

Parameters
text CompletionInfo!: The committed completion.
Return
Boolean true on success, false if the input connection is no longer valid.

commitContent

Added in API level 25
open fun commitContent(
    inputContentInfo: InputContentInfo,
    flags: Int,
    opts: Bundle?
): Boolean

Default implementation which invokes View.performReceiveContent on the target view if the view allows content insertion; otherwise returns false without any side effects.

Parameters
inputContentInfo InputContentInfo: Content to be inserted. This value cannot be null.
flags Int: INPUT_CONTENT_GRANT_READ_URI_PERMISSION if the content provider allows grantUriPermissions or 0 if the application does not need to call InputContentInfo.requestPermission().
opts Bundle?: optional bundle data. This can be null.
Return
Boolean true if this request is accepted by the application, whether the request is already handled or still being handled in background, false otherwise.

commitCorrection

Added in API level 11
open fun commitCorrection(correctionInfo: CorrectionInfo!): Boolean

Default implementation does nothing and returns false.

Parameters
correctionInfo CorrectionInfo!: Detailed information about the correction.
Return
Boolean true on success, false if the input connection is no longer valid. Since Android android.os.Build.VERSION_CODES#N until android.os.Build.VERSION_CODES#TIRAMISU, this API returned false when the target application does not implement this method.

commitText

Added in API level 3
open fun commitText(
    text: CharSequence!,
    newCursorPosition: Int
): Boolean

Default implementation replaces any existing composing text with the given text. In addition, only if fallback mode, a key event is sent for the new text and the current editable buffer cleared.

Parameters
text CharSequence!: The text to commit. This may include styles.
newCursorPosition Int: The new cursor position around the text, in Java characters. If > 0, this is relative to the end of the text - 1; if <= 0, this is relative to the start of the text. So a value of 1 will always advance the cursor to the position after the full text being inserted. Note that this means you can't position the cursor within the text, because the editor can make modifications to the text you are providing so it is not possible to correctly specify locations there.
Return
Boolean true on success, false if the input connection is no longer valid.

deleteSurroundingText

Added in API level 3
open fun deleteSurroundingText(
    beforeLength: Int,
    afterLength: Int
): Boolean

The default implementation performs the deletion around the current selection position of the editable text.

Parameters
beforeLength Int: The number of characters before the cursor to be deleted, in code unit. If this is greater than the number of existing characters between the beginning of the text and the cursor, then this method does not fail but deletes all the characters in that range.
afterLength Int: The number of characters after the cursor to be deleted, in code unit. If this is greater than the number of existing characters between the cursor and the end of the text, then this method does not fail but deletes all the characters in that range.
Return
Boolean true when selected text is deleted, false when either the selection is invalid or not yet attached (i.e. selection start or end is -1), or the editable text is null.

deleteSurroundingTextInCodePoints

Added in API level 24
open fun deleteSurroundingTextInCodePoints(
    beforeLength: Int,
    afterLength: Int
): Boolean

The default implementation performs the deletion around the current selection position of the editable text.

Parameters
beforeLength Int: The number of characters before the cursor to be deleted, in code points. If this is greater than the number of existing characters between the beginning of the text and the cursor, then this method does not fail but deletes all the characters in that range.
afterLength Int: The number of characters after the cursor to be deleted, in code points. If this is greater than the number of existing characters between the cursor and the end of the text, then this method does not fail but deletes all the characters in that range.
Return
Boolean true on success, false if the input connection is no longer valid. Before Android android.os.Build.VERSION_CODES#TIRAMISU, this API returned false when the target application does not implement this method.

endBatchEdit

Added in API level 3
open fun endBatchEdit(): Boolean

Default implementation does nothing.

Return
Boolean For editor authors, you must return true if a batch edit is still in progress after closing the latest one (in other words, if the nesting count is still a positive number). Return false otherwise. For IME authors, you will always receive true as long as the request was sent to the editor, and receive false only if the input connection is no longer valid.

finishComposingText

Added in API level 3
open fun finishComposingText(): Boolean

The default implementation removes the composing state from the current editable text. In addition, only if fallback mode, a key event is sent for the new text and the current editable buffer cleared.

Return
Boolean true on success, false if the input connection is no longer valid.

getComposingSpanEnd

Added in API level 3
open static fun getComposingSpanEnd(text: Spannable): Int

Return the end of the range of composing text, or -1 if there's no composing text.

Parameters
text Spannable: This value cannot be null.

getComposingSpanStart

Added in API level 3
open static fun getComposingSpanStart(text: Spannable): Int

Return the beginning of the range of composing text, or -1 if there's no composing text.

Parameters
text Spannable: This value cannot be null.

getCursorCapsMode

Added in API level 3
open fun getCursorCapsMode(reqModes: Int): Int

The default implementation uses TextUtils.getCapsMode to get the cursor caps mode for the current selection position in the editable text, unless in fallback mode in which case 0 is always returned.

Parameters
reqModes Int: The desired modes to retrieve, as defined by TextUtils.getCapsMode. These constants are defined so that you can simply pass the current TextBoxAttribute.contentType value directly in to here.
Return
Int the caps mode flags that are in effect at the current cursor position. See TYPE_TEXT_FLAG_CAPS_* in android.text.InputType.

getEditable

Added in API level 3
open fun getEditable(): Editable?

Return the target of edit operations. The default implementation returns its own fake editable that is just used for composing text; subclasses that are real text editors should override this and supply their own.

Subclasses could override this method to turn null.

getExtractedText

Added in API level 3
open fun getExtractedText(
    request: ExtractedTextRequest!,
    flags: Int
): ExtractedText?

The default implementation always returns null.

Parameters
request ExtractedTextRequest!: Description of how the text should be returned. android.view.inputmethod.ExtractedTextRequest
flags Int: Additional options to control the client, either 0 or GET_EXTRACTED_TEXT_MONITOR.
Return
ExtractedText? an android.view.inputmethod.ExtractedText object describing the state of the text view and containing the extracted text itself, or null if the input connection is no longer valid of the editor can't comply with the request for some reason.

getHandler

Added in API level 24
open fun getHandler(): Handler?

Called by the system to enable application developers to specify a dedicated thread on which InputConnection methods are called back.

Editor authors: although you can return your custom subclasses of Handler, the system only uses android.os.Looper returned from Handler.getLooper(). You cannot intercept or cancel InputConnection callbacks by implementing this method.

IME authors: This method is not intended to be called from the IME. You will always receive null.

Return
Handler? This value may be null.

getSelectedText

Added in API level 9
open fun getSelectedText(flags: Int): CharSequence?

The default implementation returns the text currently selected, or null if none is selected.

Parameters
flags Int: Supplies additional options controlling how the text is returned. May be either 0 or GET_TEXT_WITH_STYLES.
Return
CharSequence? the text that is currently selected, if any, or null if no text is selected.

getSurroundingText

Added in API level 31
open fun getSurroundingText(
    beforeLength: Int,
    afterLength: Int,
    flags: Int
): SurroundingText?

The default implementation returns the given amount of text around the current cursor position in the buffer.

Parameters
beforeLength Int: Value is 0 or greater
afterLength Int: Value is 0 or greater
flags Int: Supplies additional options controlling how the text is returned. May be either 0 or GET_TEXT_WITH_STYLES. Value is either 0 or android.view.inputmethod.InputConnection#GET_TEXT_WITH_STYLES
Return
SurroundingText? This value may be null.
Exceptions
java.lang.IllegalArgumentException if beforeLength or afterLength is negative.

getTextAfterCursor

Added in API level 3
open fun getTextAfterCursor(
    length: Int,
    flags: Int
): CharSequence?

The default implementation returns the given amount of text from the current cursor position in the buffer.

Parameters
n The expected length of the text. This must be non-negative. Value is 0 or greater
flags Int: Supplies additional options controlling how the text is returned. May be either 0 or GET_TEXT_WITH_STYLES.
length Int: Value is 0 or greater
Return
CharSequence? This value may be null.
Exceptions
java.lang.IllegalArgumentException if n is negative.

getTextBeforeCursor

Added in API level 3
open fun getTextBeforeCursor(
    length: Int,
    flags: Int
): CharSequence?

The default implementation returns the given amount of text from the current cursor position in the buffer.

Parameters
n The expected length of the text. This must be non-negative. Value is 0 or greater
flags Int: Supplies additional options controlling how the text is returned. May be either 0 or GET_TEXT_WITH_STYLES.
length Int: Value is 0 or greater
Return
CharSequence? This value may be null.
Exceptions
java.lang.IllegalArgumentException if n is negative.

performContextMenuAction

Added in API level 3
open fun performContextMenuAction(id: Int): Boolean

The default implementation does nothing.

performEditorAction

Added in API level 3
open fun performEditorAction(actionCode: Int): Boolean

The default implementation turns this into the enter key.

Parameters
editorAction This must be one of the action constants for EditorInfo.imeOptions, such as EditorInfo.EDITOR_ACTION_GO, or the value of EditorInfo.actionId if a custom action is available.
Return
Boolean true on success, false if the input connection is no longer valid.

performPrivateCommand

Added in API level 3
open fun performPrivateCommand(
    action: String!,
    data: Bundle!
): Boolean

The default implementation does nothing.

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.
Return
Boolean true if the command was sent (whether or not the associated editor understood it), false if the input connection is no longer valid.

removeComposingSpans

Added in API level 3
static fun removeComposingSpans(text: Spannable): Unit

Removes the composing spans from the given text if any.

Parameters
text Spannable: the spannable text to remove composing spans This value cannot be null.

replaceText

Added in API level 34
open fun replaceText(
    start: Int,
    end: Int,
    text: CharSequence,
    newCursorPosition: Int,
    textAttribute: TextAttribute?
): Boolean

Replace the specific range in the editor with suggested text.

This method finishes whatever composing text is currently active and leaves the text as-it, replaces the specific range of text with the passed CharSequence, and then moves the cursor according to newCursorPosition. This behaves like calling finishComposingText(), setSelection(start, end), and then commitText(text, newCursorPosition,.

Similar to setSelection(int,int), the order of start and end is not important. In effect, the region from start to end and the region from end to start is the same. Editor authors, be ready to accept a start that is greater than end.

Parameters
start Int: Value is 0 or greater
end Int: Value is 0 or greater
newCursorPosition Int: the new cursor position around the text. If > 0, this is relative to the end of the text - 1; if <= 0, this is relative to the start of the text. So a value of 1 will always advance you to the position after the full text being inserted. Note that this means you can't position the cursor within the text.
text CharSequence: This value cannot be null.
textAttribute TextAttribute?: This value may be null.
Return
Boolean true if the replace command was sent to the associated editor (regardless of whether the replacement is success or not), false otherwise.

reportFullscreenMode

Added in API level 3
open fun reportFullscreenMode(enabled: Boolean): Boolean

Updates InputMethodManager with the current fullscreen mode.

Return
Boolean For editor authors, the return value will always be ignored. For IME authors, this always returns true on android.os.Build.VERSION_CODES#N_MR1 and prior devices and false on android.os.Build.VERSION_CODES#O and later devices.

requestCursorUpdates

Added in API level 21
open fun requestCursorUpdates(cursorUpdateMode: Int): Boolean

The default implementation does nothing.

Parameters
cursorUpdateMode Int: any combination of update modes and filters: CURSOR_UPDATE_IMMEDIATE, CURSOR_UPDATE_MONITOR, and data filters: CURSOR_UPDATE_FILTER_CHARACTER_BOUNDS, CURSOR_UPDATE_FILTER_EDITOR_BOUNDS, CURSOR_UPDATE_FILTER_INSERTION_MARKER, CURSOR_UPDATE_FILTER_VISIBLE_LINE_BOUNDS, CURSOR_UPDATE_FILTER_TEXT_APPEARANCE. Pass 0 to disable them. However, if an unknown flag is provided, request will be rejected and method will return false.
Return
Boolean true if the request is scheduled. false to indicate that when the application will not call InputMethodManager.updateCursorAnchorInfo(. Since Android android.os.Build.VERSION_CODES#N until android.os.Build.VERSION_CODES#TIRAMISU, this API returned false when the target application does not implement this method.

sendKeyEvent

Added in API level 3
open fun sendKeyEvent(event: KeyEvent!): Boolean

Provides standard implementation for sending a key event to the window attached to the input connection's view.

Parameters
event KeyEvent!: The key event.
Return
Boolean true on success, false if the input connection is no longer valid.

setComposingRegion

Added in API level 9
open fun setComposingRegion(
    start: Int,
    end: Int
): Boolean
Parameters
start Int: the position in the text at which the composing region begins
end Int: the position in the text at which the composing region ends
Return
Boolean true on success, false if the input connection is no longer valid. Since Android android.os.Build.VERSION_CODES#N until android.os.Build.VERSION_CODES#TIRAMISU, this API returned false when the target application does not implement this method.

setComposingSpans

Added in API level 3
open static fun setComposingSpans(text: Spannable): Unit

Removes the composing spans from the given text if any.

Parameters
text Spannable: the spannable text to remove composing spans This value cannot be null.

setComposingText

Added in API level 3
open fun setComposingText(
    text: CharSequence!,
    newCursorPosition: Int
): Boolean

The default implementation places the given text into the editable, replacing any existing composing text. The new text is marked as in a composing state with the composing style.

Parameters
text CharSequence!: The composing text with styles if necessary. If no style object attached to the text, the default style for composing text is used. See android.text.Spanned for how to attach style object to the text. android.text.SpannableString and android.text.SpannableStringBuilder are two implementations of the interface android.text.Spanned.
newCursorPosition Int: The new cursor position around the text. If > 0, this is relative to the end of the text - 1; if <= 0, this is relative to the start of the text. So a value of 1 will always advance you to the position after the full text being inserted. Note that this means you can't position the cursor within the text, because the editor can make modifications to the text you are providing so it is not possible to correctly specify locations there.
Return
Boolean true on success, false if the input connection is no longer valid.

setSelection

Added in API level 3
open fun setSelection(
    start: Int,
    end: Int
): Boolean

The default implementation changes the selection position in the current editable text.

Parameters
start Int: the character index where the selection should start.
end Int: the character index where the selection should end.
Return
Boolean true on success, false if the input connection is no longer valid.

takeSnapshot

Added in API level 33
open fun takeSnapshot(): TextSnapshot?

Default implementation that constructs TextSnapshot with information extracted from BaseInputConnection.

Return
TextSnapshot? null when TextSnapshot cannot be fully taken.