环境:
如图:
下面的RecyclerView中的item里面的数字部分是EditText.在刚完成的时候就发现了一个问题.RecyclerView和EditText合用的时候请求焦点冲突,造成输入法软键盘一闪而逝的问题.后来网上找到方法解决了.当时找到的不是这一个,解决方法是一样的
主要是在layout文件的 RecyclerView节点下添加:
android:descendantFocusability="beforeDescendants"
android:fastScrollEnabled="false"
在清单文件的这个Activity下添加:
android:windowSoftInputMode="stateHidden|adjustPan"
确实解决了问题,但是新的问题随之而来:
在输入底部的item的时候,软键盘会把上面的布局顶上去,本来也没什么,但是这里,目标总额是随着输入变化的,让用户看到总额体验会好很多.
试了一些方法,在网上也找了一下,都没有很好的解决方法,要么是无效,要么效果不理想.
后来经过尝试,解决了这个问题.
解决:
- 把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>
在清单文件中修改
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);
}
}