zoukankan      html  css  js  c++  java
  • Android 软键盘盖住输入框的问题

    当在Android的layout设计里面如果输入框过多,则在输入弹出软键盘的时候,下面的输入框会有一部分被软件盘挡住,从而不能获取焦点输入。

    解决办法:

    方法一:在你的activity中的oncreate中setContentView之前写上这个代码getWindow().setSoftInputMode(WindowManager.LayoutParams.SOFT_INPUT_ADJUST_PAN);

    方法二:在项目的AndroidManifest.xml文件中界面对应的<activity>里加入android:windowSoftInputMode="stateVisible|adjustResize",这样会让屏幕整体上移。如果加上的是

                    android:windowSoftInputMode="adjustPan"这样键盘就会覆盖屏幕。

    方法三:把顶级的layout替换成ScrollView,或者说在顶级的Layout上面再加一层ScrollView的封装。这样就会把软键盘和输入框一起滚动了,软键盘会一直处于底部。

    注:方法一和二应该是同一种方法,不过一个是在代码里实现一个是在xml文件里实现。可能会应为1.5和之前的版本不支持该方法。但是方法三是肯定没有问题的。

    文主要介绍Android中如何解决输入法键盘和activity页面遮挡的问题

    总结:

    不希望遮挡设置activity属性android:windowSoftInputMode="adjustPan"

    希望动态调整高度android:windowSoftInputMode="adjustResize"

    问题:

    我原来的问题是,对于腾讯微博的OAuth验证webView,弹出软键盘后,输入框上移就看不到输入框了,后发现Webview放到了ScrollView中,将ScrollView改为LinearLayout问题解决了,不会在弹出软键盘后大幅滚动。不过下面还是详细介绍下软键盘和activity页面遮挡的问题。

    详细:

    通常情况下如果我们在一个输入框输入内容,输入法键盘弹出时,activity自动设置高度,相当于在activity向上滚动了添加了输入法键盘的高度。但有时可能淹没当前的输入框,如果希望输入法键盘弹出时不自动向上挤压activity,在activty中设置属性android:windowSoftInputMode="adjustPan"即可,如下:

    Java代码  收藏代码
    1. <activity android:name="testActivity"  
    2.       android:windowSoftInputMode="adjustPan">  

    设置属性为android:windowSoftInputMode="adjustResize"即可自动调整高度。

    属性stateVisible表示默认显示输入法键盘,其他属性见:android:windowSoftInputMode

    adjustPan同样存在问题,即可能需要关闭软键盘,定位被挡住的输入框,我希望的是介于adjustPan和adjustResize之间的解决方案,即软键盘会对activity有一定挤压,但是焦点所在输入框始终会显示在屏幕上,有会的朋友欢迎留言分享,个人觉得可能的解决方案是new一个LinearLayout,重写其中的

    Java代码  收藏代码
    1. protected void onSizeChanged(int w, int h, int oldw, int oldh)  

    方法,使得h参数动态变化达到效果,但较耗时,暂不想尝试了。

    该博文转载自:http://blog.csdn.net/stonesharp/article/details/7648384

  • 相关阅读:
    函数高阶(函数,改变函数this指向,高阶函数,闭包,递归)
    案例:新增数组方法
    案例:商品查询
    案例:forEach和some区别
    ES5新增方法(数组,字符串,对象)
    案例:借用父构造函数继承属性和方法
    构造函数 和 原型
    汽车小常识别让六大汽车驾驶软肋阻碍你
    Opencv 图像增强和亮度调整<6>
    C# StringBulider用法<1>
  • 原文地址:https://www.cnblogs.com/xieyuan/p/3787531.html
Copyright © 2011-2022 走看看