软键盘挡住输入框问题的终极解决方案
前言
开发做得久了,总免不了会遇到各种坑。 而在Android开发的路上,『软键盘挡住了输入框』这个坑,可谓是一个旷日持久的巨坑——来来来,我们慢慢看。
入门篇
最基本的情况,如图所示:在页面底部有一个EditText,如果不做任何处理,那么在软键盘弹出的时候,就有可能会挡住EditText。
对于这种情况的处理其实很简单,只需要在AndroidManifest文件中对activity设置:android:windowSoftInputMode
的值adjustPan
或者adjustResize
即可,像这样:
<activity
android:name=".MainActivity"
android:windowSoftInputMode="adjustPan" >
...
</activity>
一般来说,他们都可以解决问题,当然,adjustPan
跟adjustResize
的效果略有区别。
-
adjustPan
是把整个界面向上平移,使输入框露出,不会改变界面的布局; -
adjustResize
则是重新计算弹出软键盘之后的界面大小,相当于是用更少的界面区域去显示内容,输入框一般自然也就在内了。
↑↑↑ OK,这只是入门,基本上地球上所有的Android工程师都能搞定。
别急,看下面~
加上WebView试试看?坑来了……
上面的入门篇中,软键盘是由原生的EditText触发弹出的。而在H5、Hybrid几乎已经成为App标配的时候,我们经常还会碰到的情况是:软键盘是由WebView中的网页元素所触发弹出的。
情况描述
这时候,情况就会变得复杂了:
- 首先,页面是
非全屏模式
的情况下,给activity设置adjustPan
会失效。 - 其次,页面是
全屏模式
的情况,adjustPan
跟adjustResize
都会失效。
——解释一下,这里的全屏模式
即是页面是全屏的,包括Application或activity使用了Fullscreen主题、使用了『状态色着色』、『沉浸式状态栏』、『Immersive Mode』等等——总之,基本上只要是App自己接管了状态栏的控制,就会产生这种问题。
下面这个表格可以简单列举了具体的情况。
为什么说它是个坑?"issue 5497"
上面表格的这种情况并非是Google所期望的,理想的情况当然是它们都能正常生效才对——所以这其实是Android系统本身的一个BUG。
为什么文章开头说这是个坑呢?
——因为这个BUG从Android1.x时代(2009年)就被报告了,而一直到了如今的Android7.0(2016年)还是没有修复……/(ㄒoㄒ)/
可以说这不仅是个坑,而且还是个官方挖的坑~
"issue 5497",详情传送门 ☞ Issue 5497 - android -WebView adjustResize windowSoftInputMode breaks when activity is fullscreen - Android Open Source Project - Issue Tracker - Google Project Hosting
当然了,不管坑是谁挖的,最终还是要开发者来解决。
遇到坑之后,有两种方法可以过去:躲,或者填。
躲坑姿势
如前文所示,出现坑的条件是:带有WebView的activity使用了全屏模式
或者adjustPan
模式。
那么躲坑的姿势就很简单了——
如果activity中有WebView,就不要使用全屏模式
,并且把它的windowSoftInputMode值设为adjustResize
就好了嘛
怎么样,是不是很简单?
推荐阅读
-
js解决软键盘遮挡输入框的问题分享
-
解决react-native软键盘弹出挡住输入框的问题
-
ios软键盘在input聚集时遮挡住输入框的问题
-
DISCUZ在win2003环境下 Unable to access ./include/common.inc.php in... 的问题终极解决方案
-
sublime text linux上中文输入问题的终极解决方案
-
h5软键盘挡住输入框问题解决(android)
-
DISCUZ在win2003环境下 Unable to access ./include/common.inc.php in... 的问题终极解决方案_php技巧
-
android 关于软键盘遮挡webView底部输入框问题(解决方案)
-
DISCUZ在win2003环境下 Unable to access /include/commonincphp in 的问题终极解决方案
-
js解决软键盘遮挡输入框的问题分享