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

版权声明:本文为博主原创文章,未经博主允许不得转载。 - long for us https://blog.csdn.net/longforus/article/details/70231634

环境:

如图:

这里写图片描述

下面的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);
    }

}

猜你喜欢

转载自blog.csdn.net/longforus/article/details/70231634
今日推荐