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-04-27 11:02:21

    CSS 气泡对话框

    点击上面地址,我们可以看到一个灵活的css气泡,拖动按钮,改变气泡效果。

  • 2020-04-27 16:59:23

    Docker部署nuxtjs

    将一下文件拷贝至服务器目录/app |名称|描述| |-|-| |.nuxt|编译后生成的目录,开发模式和发布模式通用,注意发布前使用npm run build 防止将dev目录发布| |static| 静态资源文件,通过/可直接访问| |package.json|npm 包管理配置文件| |nuxt.config.js|Nuxt.js 默认的配置涵盖了大部分使用情形,可通过 nuxt.config.js 来覆盖默认的配置。| |node_modules|依赖模块|

  • 2020-04-28 10:47:16

    currentColor css 的使用

    以前我们在如何动态设置伪元素的颜色上非过不少心思,看完下面的文章,你就会超级见到那的设置伪元素的颜色了。

  • 2020-04-28 10:48:39

    使用currentColor设置SVG样式

    css自己也又很多变量哦,大家还要多多学习哦。CSS中的变量很有用,因为它们允许我们写更多DRY(不再自我重复,也就是不需要一直写重复内容的代码)代码。它们对于管理和维护大型项目也有非常好用,因为它们包含了大量重复的值。

  • 2020-04-29 20:57:07

    mac卸载avast

    第一种就是卸载。打开主界面,在左上角Avast一栏中选择卸载。卸载完之后要么再装回去,要么去找找别的杀软吧