commonMain.androidx.compose.ui.input.key.KeyEvent.kt Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of ui-desktop Show documentation
Show all versions of ui-desktop Show documentation
Compose UI primitives. This library contains the primitives that form the Compose UI Toolkit, such as drawing, measurement and layout.
/*
* Copyright 2020 The Android Open Source Project
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package androidx.compose.ui.input.key
/**
* The native platform-specific keyboard key event.
*/
expect class NativeKeyEvent
/**
* When a user presses a key on a hardware keyboard, a [KeyEvent] is sent to the item that is
* currently focused. Any parent composable can intercept this [key event][KeyEvent] on its way to
* the focused item by using [Modifier.onPreviewKeyEvent()]][onPreviewKeyEvent]. If the item is
* not consumed, it returns back to each parent and can be intercepted by using
* [Modifier.onKeyEvent()]][onKeyEvent].
*
* @sample androidx.compose.ui.samples.KeyEventSample
*/
@kotlin.jvm.JvmInline
value class KeyEvent(val nativeKeyEvent: NativeKeyEvent)
/**
* The key that was pressed.
*
* @sample androidx.compose.ui.samples.KeyEventIsAltPressedSample
*/
expect val KeyEvent.key: Key
/**
* The UTF16 value corresponding to the key event that was pressed. The unicode character
* takes into account any meta keys that are pressed (eg. Pressing shift results in capital
* alphabets). The UTF16 value uses the
* [U+n notation][http://www.unicode.org/reports/tr27/#notation] of the Unicode Standard.
*
* An [Int] is used instead of a [Char] so that we can support supplementary characters. The
* Unicode Standard allows for characters whose representation requires more than 16 bits.
* The range of legal code points is U+0000 to U+10FFFF, known as Unicode scalar value.
*
* The set of characters from U+0000 to U+FFFF is sometimes referred to as the Basic
* Multilingual Plane (BMP). Characters whose code points are greater than U+FFFF are called
* supplementary characters. In this representation, supplementary characters are represented
* as a pair of char values, the first from the high-surrogates range, (\uD800-\uDBFF), the
* second from the low-surrogates range (\uDC00-\uDFFF).
*/
expect val KeyEvent.utf16CodePoint: Int
/**
* The [type][KeyEventType] of key event.
*
* @sample androidx.compose.ui.samples.KeyEventTypeSample
*/
expect val KeyEvent.type: KeyEventType
/**
* Indicates whether the Alt key is pressed.
*
* @sample androidx.compose.ui.samples.KeyEventIsAltPressedSample
*/
expect val KeyEvent.isAltPressed: Boolean
/**
* Indicates whether the Ctrl key is pressed.
*
* @sample androidx.compose.ui.samples.KeyEventIsCtrlPressedSample
*/
expect val KeyEvent.isCtrlPressed: Boolean
/**
* Indicates whether the Meta key is pressed.
*
* @sample androidx.compose.ui.samples.KeyEventIsMetaPressedSample
*/
expect val KeyEvent.isMetaPressed: Boolean
/**
* Indicates whether the Shift key is pressed.
*
* @sample androidx.compose.ui.samples.KeyEventIsShiftPressedSample
*/
expect val KeyEvent.isShiftPressed: Boolean
/**
* The type of Key Event.
*
* @sample androidx.compose.ui.samples.KeyEventTypeSample
*/
@kotlin.jvm.JvmInline
value class KeyEventType internal constructor(@Suppress("unused") private val value: Int) {
override fun toString(): String {
return when (this) {
KeyUp -> "KeyUp"
KeyDown -> "KeyDown"
Unknown -> "Unknown"
else -> "Invalid"
}
}
companion object {
/**
* Unknown key event.
*
* @sample androidx.compose.ui.samples.KeyEventTypeSample
*/
val Unknown: KeyEventType = KeyEventType(0)
/**
* Type of KeyEvent sent when the user lifts their finger off a key on the keyboard.
*
* @sample androidx.compose.ui.samples.KeyEventTypeSample
*/
val KeyUp: KeyEventType = KeyEventType(1)
/**
* Type of KeyEvent sent when the user presses down their finger on a key on the keyboard.
*
* @sample androidx.compose.ui.samples.KeyEventTypeSample
*/
val KeyDown: KeyEventType = KeyEventType(2)
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy