android监听键盘弹出和隐藏

2018-10-11 16:10:25

这个确实是个坑啊,android没有原生的方法支持

从网上看了又修改edittext成功监听的,Android软键盘弹出和收回监听

反正在小米上不管事啊,不过点击后退倒是能监听吧,写上也没删除,就当做下兼容吧。



最终还是用检测键盘弹出后的屏幕高度来解决的,虽然网友不推荐,但是还是很好用

即使有的屏幕和键盘的比例,导致失败,咱还有上面的兼容,以及检测EditText聚焦等操作,影响还不是很大。


获取软键盘状态思路:

  1. 获取当前页面根布局及其高度 RootH;


  2. 获取状态栏高度 StatusH和导航栏高度 NavigationH;


  3. 获取当前根视图在屏幕上显示的高度RectH;


  4. 高度差值比较,(根布局高度 - 根视图显示高度)与(状态栏高度 + 导航栏高度)的大小对比;


  5. 大于:展开软键盘


  6. 小于:隐藏软键盘

相关代码块:

viewTree的监听

// viewTree的监听private ViewTreeObserver.OnGlobalLayoutListener keyboardLayoutListener = new ViewTreeObserver.OnGlobalLayoutListener() {@Overridepublic void onGlobalLayout() {// 显示的根视图 Rect r = new Rect();rootLayout.getWindowVisibleDisplayFrame(r);// 导航栏对象Point navigationBarHeight = SystemUtils.getNavigationBarSize(InformationBaseActivity.this);// 状态栏高度int statusBarHeight = SystemUtils.getStatusBarHeight(InformationBaseActivity.this);Log.e(TAG, "navigationBarHeight " + navigationBarHeight.x + " " + navigationBarHeight.y + statusBarHeight);// (r.bottom - r.top) 当前页面根视图显示的高度// heightDiff 当前页面原本根布局高度与显示视图的高度差int heightDiff = rootLayout.getRootView().getHeight() - (r.bottom - r.top);// 高度差判断是否弹出软键盘if (heightDiff > (100 + navigationBarHeight.y + statusBarHeight)) { // if more than 100 pixels, its probably a keyboard...mIsShowSoft = true;onShowKeyboard(heightDiff);} else {if (mIsShowSoft) {onHideKeyboard();mIsShowSoft = false;}}}};

根布局对viewTree的实时监听

protected void attachKeyboardListeners(int rootViewId) {if (keyboardListenersAttached) {return;}rootLayout = findViewById(rootViewId);rootLayout.getViewTreeObserver().addOnGlobalLayoutListener(keyboardLayoutListener);keyboardListenersAttached = true;}

页面销毁时移除监听

@Overridepublic void onDestroy() {super.onDestroy();if (keyboardListenersAttached) {rootLayout.getViewTreeObserver().removeGlobalOnLayoutListener(keyboardLayoutListener);}}

如何使用:

这些软键盘的监听操作可部署到基类中,需要用时可调用基类中的attachKeyboardListeners(),onShowKeyboard()和onHideKeyboard()方法进行相对应的操作。

项目下载地址


参考链接如下

https://blog.csdn.net/L0123456L/article/details/82887407



  • 2019-11-19 01:20:18

    java8 forEach、filter、map

    filter()、findAny()、orElse()配合使用,可以根据条件获取某个元素,如果没有返回指定的值。

  • 2019-11-19 01:24:01

    使用JAVA8 filter对List多条件筛选

    记录项目开发的过程中遇到的一些问题及解决方法,由于公司操作数据库都是统一使用工具生成的存在一些多表查询模糊查询,这些操作只能在集合方面下手了,比如发送邮件记录方面查询,对用户的名字及邮件模糊检索 年龄匹配查询。

  • 2019-11-21 18:13:08

    如何在vue单页应用中使用百度地图

    百度开发者平台已经封装了基于vue的地图组件,详细使用,请参考官网: https://dafrok.github.io/vue-baidu-map/#/zh/start/installation 网上有一些是直接在index.html页面全部引用的,本人强烈反对此种使用方式,因为我们项目是组件化的单页应用,强行引入多页应用的开发方式,会破坏整个项目的框架,严重影响性能。有些甚至还在vue单页应用中引入jquery,感觉这都是一些反人类的骚操作,不到万不得已,不建议使用。

  • 2019-11-25 17:04:10

    Throttle 和 Debounce 的本质及一个简单的实现

    Throttle,Debounce 就不把这两个词翻译成中文了,直接解释他们的概念。实际上这两个东西本质上是一样的,作用都是「为了避免某个『事件』在『一个较短的时间段内』内连续被触发从而引起的其对应的『事件处理函数』不必要的连续执行」。那么区别在哪呢?

  • 2019-11-25 17:05:44

    js实现 throttle 和 debounce,节流,防抖详解

    throttle 节流:drag改变浏览器大小,触发onresize函数,实现拖动每过1秒输出一次,不足1秒,1秒后输出一次。多用于高频操作,如抢票、抢购等,无论点击多少次,只固定间隔执行一次,以减轻压力。debounce防抖:drag改变浏览器大小,触发onresize函数,实现拖动停顿1秒输出。多用于输入框,当某一次输入后停顿满n秒才会去触发远程搜索。