借助 Jetpack androidx.compose.material3 库,用户可以使用触控笔在任何应用的任何 TextField 组件中进行书写。
如需默认启用触控笔输入,请将库依赖项添加到应用的 build.gradle 文件中:
Kotlin
dependencies { implementation("androidx.compose.foundation:foundation:LATEST_COMPOSE_VERSION") } android { buildFeatures { compose = true } composeOptions { kotlinCompilerExtensionVersion = "LATEST_EXTENSION_VERSION" } kotlinOptions { jvmTarget = "LATEST_JVM_VERSION" } }
Groovy
dependencies { implementation 'androidx.compose.foundation:foundation:LATEST_COMPOSE_VERSION' } android { buildFeatures { compose true } composeOptions { kotlinCompilerExtensionVersion = 'LATEST_EXTENSION_VERSION' } kotlinOptions { jvmTarget = 'LATEST_JVM_VERSION' } }
TextField
在 Android 14 及更高版本和 androidx.compose.foundation:foundation:1.7.0 依赖项中,默认会为所有 TextField 组件启用触控笔手写功能。当在组件的手写边界内检测到触控笔移动事件时,系统会为 TextField 启动手写模式。
手写边界包括输入字段周围 40 dp 的垂直内边距和 10 dp 的水平内边距。
TextField 组件的手写边界。
当使用 KeyboardType.Password 请求输入法编辑器时,TextField 字段不支持触控笔手写。
输入委托
应用可以显示看似是文本输入字段的占位界面元素,但实际上这些元素只是静态界面元素,不具备文本输入功能。搜索框就是一个常见的示例。点按静态界面元素会触发向新界面的过渡,新界面包含一个可用的文本输入字段,该字段已聚焦以供输入。
触控笔输入委托
使用手写委托 API 支持占位符输入字段的触控笔手写输入(请参阅 handwritingDetector 和 handwritingHandler)。占位符界面元素配置为将手写委托给功能性输入字段。如需查看示例实现,请参阅 HandwritingDetectorSample.kt。
当功能性输入字段获得焦点并创建 InputConnection 时,触控笔手写模式开始。
测试
在搭载 Android 14 及更高版本的设备上,如果设备具有兼容的触控笔输入设备和支持 Android 14 触控笔手写 API 的输入法编辑器 (IME),则支持触控笔手写。
如果您没有触控笔输入设备,可以使用以下 Android 调试桥 (adb) 命令在任何具有 root 访问权限的设备(包括模拟器)上模拟触控笔输入:
// Android 14
adb shell setprop persist.debug.input.simulate_stylus_with_touch true && adb shell stop && adb shell start
// Android 15 and higher
// Property takes effect after screen reconfiguration such as orientation change.
adb shell setprop debug.input.simulate_stylus_with_touch true
如果您使用的设备不支持触控笔,请使用 Gboard Beta 版进行测试。