android 自定义软键盘的显示和隐藏

复制代码
记一下,以后不用找

在InputMethodService中有这两个方法可以看到软键盘显示状态
复制代码
//软键盘隐藏
override fun onWindowHidden() {
    super.onWindowHidden()
}
复制代码
//软键盘显示
override fun onWindowShown() {
    super.onWindowShown()
}

在activity中可以通过这种方法看到软键盘显示状态

复制代码
view.viewTreeObserver.addOnGlobalLayoutListener {
    // 获取屏幕的高度
    val screenHeight: Int = view.getRootView().getHeight()

    // 获取当前布局的可见高度
    val rect = Rect()
    view.getWindowVisibleDisplayFrame(rect)
    // 计算键盘的高度
    var keyboardHeight = screenHeight - rect.bottom;
    if (keyboardHeight > screenHeight * 0.15) {
        // 键盘显示
        showKeyBoardHeight = keyboardHeight
        if (showKeyBoardHeight - hideKeyBoardHeight > 0) {
        
        }
    } else {
        hideKeyBoardHeight = keyboardHeight
        // 键盘隐藏
    }
}
相关推荐
低调小一12 分钟前
LRU缓存科普与实现(Kotlin 与 Swift)
开发语言·缓存·kotlin
雨白14 分钟前
深入理解协程的运作机制 —— 调度、挂起与性能
android·kotlin
沐怡旸26 分钟前
【Android】Android系统体系结构
android
namehu1 小时前
React Native 应用性能分析与优化不完全指南
android·react native·ios
xqlily2 小时前
Kotlin:现代编程语言的革新者
android·开发语言·kotlin
HelloBan2 小时前
如何正确去掉SeekBar的Thumb和按压效果
android
木易 士心2 小时前
Android EventBus 源码解析:设计模式、原理与实现
android
ClassOps2 小时前
源码阅读 LeakCanary
android
用户2018792831672 小时前
为啥现在 Android App 不用手动搞 MultiDex 了?
android
fouryears_234172 小时前
如何将Vue 项目转换为 Android App(使用Capacitor)
android·前端·vue.js