RecyclerView和EditText焦点冲突和输入法软键盘把布局顶出屏幕之外的解决

环境:

如图:

这里写图片描述

下面的RecyclerView中的item里面的数字部分是EditText.在刚完成的时候就发现了一个问题.RecyclerView和EditText合用的时候请求焦点冲突,造成输入法软键盘一闪而逝的问题.后来网上找到方法解决了.当时找到的不是这一个,解决方法是一样的

主要是在layout文件的 RecyclerView节点下添加:

 android:descendantFocusability="beforeDescendants"
 android:fastScrollEnabled="false"

在清单文件的这个Activity下添加:

android:windowSoftInputMode="stateHidden|adjustPan"

确实解决了问题,但是新的问题随之而来:

这里写图片描述

在输入底部的item的时候,软键盘会把上面的布局顶上去,本来也没什么,但是这里,目标总额是随着输入变化的,让用户看到总额体验会好很多.

试了一些方法,在网上也找了一下,都没有很好的解决方法,要么是无效,要么效果不理想.
后来经过尝试,解决了这个问题.

解决:

这里写图片描述

  1. 把RecyclerView套入一个Scrollview:
 <ScrollView
  android:layout_width="match_parent"
  android:layout_height="wrap_content"
  >
  <android.support.v7.widget.RecyclerView
            android:id="@+id/rv"
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:layout_marginTop="@dimen/view_dp_10"
            android:descendantFocusability="beforeDescendants"//这2句还是保留的
            android:fastScrollEnabled="false"
           />
      </ScrollView>
  1. 在清单文件中修改

    android:windowSoftInputMode=”stateHidden|adjustPan”

    为:

    android:windowSoftInputMode=”stateHidden|adjustResize”

这2步缺一不可,就可以解决焦点混乱和布局被顶上去的问题了.

但是仅仅这样使用的话又会出现新的滑动冲突的问题,导致滑动失去惯性,丝滑的感觉就再也没有了,进一步了为了牛奶般的丝滑,把ScrollView 替换为下面的自定义ScrollView 就可以了:

public class NestingScrollview  extends ScrollView {
    private int downX;
    private int downY;
    private int mTouchSlop;
    private boolean autoScroll = true;

    /**
     * 多层嵌套时的自动滚动
     * @param autoScroll
     */
    public void setAutoScroll(boolean autoScroll) {
        this.autoScroll = autoScroll;
    }

    /**
     * 防止多层嵌套时候的自动滚动
     * @param rect
     * @return
     */
    @Override
    protected int computeScrollDeltaToGetChildRectOnScreen(Rect rect) {
            return autoScroll?super.computeScrollDeltaToGetChildRectOnScreen(rect):0;
    }


    public NestingScrollview(Context context) {
        super(context);
        mTouchSlop = ViewConfiguration.get(context).getScaledTouchSlop();
    }

    public NestingScrollview(Context context, AttributeSet attrs) {
        super(context, attrs);
        mTouchSlop = ViewConfiguration.get(context).getScaledTouchSlop();
    }

    public NestingScrollview(Context context, AttributeSet attrs, int defStyleAttr) {
        super(context, attrs, defStyleAttr);
        mTouchSlop = ViewConfiguration.get(context).getScaledTouchSlop();
    }

    @Override
    public boolean onInterceptTouchEvent(MotionEvent e) {
        int action = e.getAction();
        switch (action) {
            case MotionEvent.ACTION_DOWN:
                downX = (int) e.getRawX();
                downY = (int) e.getRawY();
                break;
            case MotionEvent.ACTION_MOVE:
                int moveY = (int) e.getRawY();
                if (Math.abs(moveY - downY) > mTouchSlop) {
                    return true;
                }
        }
        return super.onInterceptTouchEvent(e);
    }

}
  • 4
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
EditText默认获取焦点并弹出软键盘,在Android开发中非常常见和实用。当我们在布局文件中使用EditText控件时,默认情况下,该控件会自动获取焦点并弹出软键盘。 这种默认行为可以方便用户直接对EditText进行输入操作,提高用户的交互体验。当用户点击EditText或切换到包含EditText布局时,EditText会自动获得焦点,这样用户可以直接进行输入操作。 在代码中,我们可以通过设置android:focusable属性为true来保证EditText默认获取焦点。同时,还可以设置android:focusableInTouchMode属性为true,确保用户触摸到屏幕上的EditText时,它会获取焦点并弹出软键盘。 例如,在布局文件中可以这样设置: <EditText android:id="@+id/editText" android:layout_width="match_parent" android:layout_height="wrap_content" android:focusable="true" android:focusableInTouchMode="true" /> 这样,当布局加载完成后,EditText会自动获取焦点,用户可以直接对其进行输入操作。 需要注意的是,如果你希望EditText不再获取焦点和弹出软键盘,则可以将android:focusable和android:focusableInTouchMode属性设置为false。 尽管EditText默认获取焦点和弹出软键盘在很多情况下非常方便,但有些场景可能不适用,比如登录界面中的密码框,我们可能更愿意让用户手动点击密码框来输入密码,而不是自动弹出软键盘。 总之,EditText默认获取焦点并弹出软键盘是一个很方便的功能,可以提高用户的交互体验,但在一些特殊场景中需要谨慎使用。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值