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



  • 2020-11-07 16:31:02

    nginx配置X-Frame-Options允许多个域名iframe嵌套

    有时候我们需要允许多个url的来源,但是又不能全部开放,所以应该匹配第三种方法ALLOW-FROM url,那么多个url该如何配置呢,百度了所有网站都没有找到,那么这里写给大家,其实很简单: add_header X-Frame-Options 'ALLOW-FROM https://xxx.xxxxxx.com https://xxx2.xxxxxxx.com'; 就是使用空格隔开就好了!

  • 2020-11-08 08:31:51

    meteor在不同端口启动服务

    当没有任何参数时,run是默认行为,在幕后,它3000端口开启node.js服务器实例,同时开启监听3001端口的MongoDB服务

  • 2020-11-11 15:05:39

    nuxt如何在其它js文件中使用store

    在新建的js文件中想用store里面的数据,比如token想在封装的axios里面,请求头里面去使用,亦或者通过app的JS接口获取token并存储在store里面。我们都知道如何在vue中如何使用。

  • 2020-11-12 14:01:46

    使用postMessage来实现父子通信跨域

    1.子向父,子postMessage,父监听message; 2.父向子,父postMessage,子监听message; 3.测试发现,子向父postMessage的时候,源可以写为‘*’,父向子postMessage的时候,源需要写成子的源,(也就是子页面的协议+主机号+端口) 测试代码部分:

  • 2020-11-12 14:24:39

    Object.entries()

    Object.entries()方法返回一个给定对象自身可枚举属性的键值对数组,其排列与使用 for...in 循环遍历该对象时返回的顺序一致(区别在于 for-in 循环还会枚举原型链中的属性)