您的位置:首页 > 移动开发 > Android开发

Android爬坑之旅:软键盘挡住输入框问题的终极解决方案

2017-04-17 12:03 639 查看
前言

开发做得久了,总免不了会遇到各种坑。

而在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
就好了嘛


怎么样,是不是很简单?
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息