好贷网好贷款

android 软键盘 输入法 弹出引起的各种不适终极解决方案

发布时间:2016-12-3 23:39:53 编辑:www.fx114.net 分享查询网我要评论
本篇文章主要介绍了"android 软键盘 输入法 弹出引起的各种不适终极解决方案",主要涉及到android 软键盘 输入法 弹出引起的各种不适终极解决方案方面的内容,对于android 软键盘 输入法 弹出引起的各种不适终极解决方案感兴趣的同学可以参考一下。

引用自:http://blog.csdn.net/itachi85/article/details/6596284 android:windowSoftInputMode activity主窗口与软键盘的交互模式,可以用来避免输入法面板遮挡问题,Android1.5后的一个新特性。 这个属性能影响两件事情: 【一】当有焦点产生时,软键盘是隐藏还是显示 【二】是否减少活动主窗口大小以便腾出空间放软键盘 它的设置必须是下面列表中的一个值,或一个”state…”值加一个”adjust…”值的组合。在任一组设置多个值——多个”state…”values,例如&mdash有未定义的结果。各个值之间用|分开。例如:<activity android:windowSoftInputMode="stateVisible|adjustResize". . . > 在这设置的值(除"stateUnspecified"和"adjustUnspecified"以外)将覆盖在主题中设置的值 各值的含义: 【A】stateUnspecified:软键盘的状态并没有指定,系统将选择一个合适的状态或依赖于主题的设置 【B】stateUnchanged:当这个activity出现时,软键盘将一直保持在上一个activity里的状态,无论是隐藏还是显示 【C】stateHidden:用户选择activity时,软键盘总是被隐藏 【D】stateAlwaysHidden:当该Activity主窗口获取焦点时,软键盘也总是被隐藏的 【E】stateVisible:软键盘通常是可见的 【F】stateAlwaysVisible:用户选择activity时,软键盘总是显示的状态 【G】adjustUnspecified:默认设置,通常由系统自行决定是隐藏还是显示 【H】adjustResize:该Activity总是调整屏幕的大小以便留出软键盘的空间 【I】adjustPan:当前窗口的内容将自动移动以便当前焦点从不被键盘覆盖和用户能总是看到输入内容的部分         很多写登录界面的开发者都会遇到一个问题:那就是在登录界面时,当你点击输入框时,下边的按钮有时会被输入框挡住,这个不利于用户的体验,所以很多人希望软键盘弹出时,也能把按钮挤上去。很多开发者想要监听键盘的状态,这无疑是一个很麻烦的做法。        我们可以在AndroidManifest.xml的Activity设置属性:android:windowSoftInputMode = "adjustResize" ,软键盘弹出时,要对主窗口布局重新进行布局,并调用onSizeChanged方法,切记一点当我们设置为“adjustResize”时,我们的界面不要设置为全屏模式,否则设置了这个属性也不会有什么效果。而当我们设置android: windowSoftInputMode = "adjustPan"时,主窗口就不会调用onSizeChanged方法,界面的一部分就会被软键盘覆盖住,就不会被挤到软键盘之上了。 我们通过一段代码来测试一下,当我们设置了该属性后,弹出输入法时,系统做了什么: 重写Layout布局: [java] view plaincopyprint?public class ResizeLayout extends LinearLayout{       private static int count = 0;              public ResizeLayout(Context context, AttributeSet attrs) {           super(context, attrs);       }              @Override       protected void onSizeChanged(int w, int h, int oldw, int oldh) {               super.onSizeChanged(w, h, oldw, oldh);                      Log.e("onSizeChanged " + count++, "=>onResize called! w="+w + ",h="+h+",oldw="+oldw+",oldh="+oldh);       }              @Override       protected void onLayout(boolean changed, int l, int t, int r, int b) {           super.onLayout(changed, l, t, r, b);           Log.e("onLayout " + count++, "=>OnLayout called! l=" + l + ", t=" + t + ",r=" + r + ",b="+b);       }              @Override       protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) {           super.onMeasure(widthMeasureSpec, heightMeasureSpec);                      Log.e("onMeasure " + count++, "=>onMeasure called! widthMeasureSpec=" + widthMeasureSpec + ", heightMeasureSpec=" + heightMeasureSpec);       }    我们的布局设置为: [html] view plaincopyprint?<com.winuxxan.inputMethodTest.ResizeLayout        xmlns:android="http://schemas.android.com/apk/res/android"       android:id="@+id/root_layout"       android:layout_width="fill_parent"       android:layout_height="fill_parent"       android:orientation="vertical"       >              <EditText           android:layout_width="fill_parent"            android:layout_height="wrap_content"        />            <LinearLayout               android:id="@+id/bottom_layout"               android:layout_width="fill_parent"                android:layout_height="fill_parent"                android:orientation="vertical"               android:gravity="bottom">s             <TextView             android:layout_width="fill_parent"            android:layout_height="wrap_content"            android:text="@string/hello"           android:background="#77777777"         />      </LinearLayout>   </com.winuxxan.inputMethodTest.ResizeLayout>    AndroidManifest.xml的Activity设置属性:android:windowSoftInputMode = "adjustResize"     运行程序,点击文本框,查看调试信息:     E/onMeasure 6(7960): =>onMeasure called! widthMeasureSpec=1073742144, heightMeasureSpec = 1073742024     E/onMeasure 7(7960): =>onMeasure called! widthMeasureSpec=1073742144, heightMeasureSpec = 1073742025     E/onSizeChanged 8(7960): =>onSizeChanged called! w=320,h=201,oldw=320,oldh=377     E/onLayout 9(7960): =>OnLayout called! l=0, t=0,r=320,b=201     从调试结果我们可以看出,当我们点击文本框后,根布局调用了onMeasure,onSizeChanged和onLayout。   windowSoftInputMode的值如果设置为adjustPan,那么该Activity主窗口并不调整屏幕的大小以便留出软键盘的空间。相反,当前窗口的内容将自动移动以便当前焦点从不被键盘覆盖和用户能总是看到输入内容的部分。这个通常是不期望比调整大小,因为用户可能关闭软键盘以便获得与被覆盖内容的交互操作。     上面的例子中,我们将AndroidManifest.xml的属性进行更改:android: windowSoftInputMode = "adjustPan"     重新运行,并点击文本框,查看调试信息:     E/onMeasure 6(8378): =>onMeasure called! widthMeasureSpec=1073742144, heightMeasureSpec=1073742200     E/onMeasure 7(8378): =>onMeasure called! widthMeasureSpec=1073742144, heightMeasureSpec=1073742201     E/onLayout 8(8378): =>OnLayout called! l=0, t=0,r=320,b=377     我们看到:系统也重新进行了measrue和layout,但是我们发现,layout过程中onSizeChanged并没有调用,这说明输入法弹出前后并没有改变原有布局的大小。 当然还有其他属性可以设置: "stateUnspecified" 软键盘的状态(是否它是隐藏或可见)没有被指定。系统将选择一个合适的状态或依赖于主题的设置。 这个是为了软件盘行为默认的设置。 "stateUnchanged" 软键盘被保持无论它上次是什么状态,是否可见或隐藏,当主窗口出现在前面时。 "stateHidden" 当用户选择该Activity时,软键盘被隐藏——也就是,当用户确定导航到该Activity时,而不是返回到它由于离开另一个Activity。 "stateAlwaysHidden" 软键盘总是被隐藏的,当该Activity主窗口获取焦点时。 "stateVisible" 软键盘是可见的,当那个是正常合适的时(当用户导航到Activity主窗口时)。 "stateAlwaysVisible" 当用户选择这个Activity时,软键盘是可见的——也就是,也就是,当用户确定导航到该Activity时,而不是返回到它由于离开另一个Activity。 "adjustUnspecified" 它不被指定是否该Activity主窗口调整大小以便留出软键盘的空间,或是否窗口上的内容得到屏幕上当前的焦点是可见的。系统将自动选择这些模式中一种主要依赖于是否窗口的内容有任何布局视图能够滚动他们的内容。如果有这样的一个视图,这个窗口将调整大小,这样的假设可以使滚动窗口的内容在一个较小的区域中可见的。这个是主窗口默认的行为设置。 "adjustResize" 该Activity主窗口总是被调整屏幕的大小以便留出软键盘的空间 "adjustPan" 该Activity主窗口并不调整屏幕的大小以便留出软键盘的空间。相反,当前窗口的内容将自动移动以便当前焦点从不被键盘覆盖和用户能总是看到输入内容的部分。这个通常是不期望比调整大小,因为用户可能关闭软键盘以便获得与被覆盖内容的交互操作。

上一篇:注册JQuery使用ajax调用后台方法,判断用户名、邮箱是否存在,并显示隐藏提示
下一篇:jquery一款多样式好看图片轮换插件

相关文章

相关评论