我有一个ScrollView
上的另一视图(顶部Buttons
)。 该ScrollView
走的是整个屏幕,并模糊是它下面的视图。
在我的应用程序某些时候,我需要ScrollView
被禁用(但仍然可见)和转移所有的触摸事件的Buttons
属于下方ScrollView
。 我怎样才能做到这一点? 像一些观点Buttons
会自动这样做,何时停用但ScrollView
没有这样做。
我有一个ScrollView
上的另一视图(顶部Buttons
)。 该ScrollView
走的是整个屏幕,并模糊是它下面的视图。
在我的应用程序某些时候,我需要ScrollView
被禁用(但仍然可见)和转移所有的触摸事件的Buttons
属于下方ScrollView
。 我怎样才能做到这一点? 像一些观点Buttons
会自动这样做,何时停用但ScrollView
没有这样做。
尝试实现自己的ScrollView
具有标志指示状态(禁用/启用),并覆盖onTouchEvent
和dispatchTouchEvent
让触摸事件获得通过ScrollView
。 下面是一个例子:
public class DisabledScrollView extends ScrollView {
private boolean mIsDisable = false;
// if status is true, disable the ScrollView
public void setDisableStatus(boolean status) {
mIsDisable = status;
}
@Override
public boolean onTouchEvent(MotionEvent ev) {
// no more tocuh events for this ScrollView
if (mIsDisable) {
return false;
}
return super.onTouchEvent(ev);
}
public boolean dispatchTouchEvent(MotionEvent ev) {
// although the ScrollView doesn't get touch events , its children will get them so intercept them.
if (mIsDisable) {
return false;
}
return super.dispatchTouchEvent(ev);
}
}
然后,所有你所要做的就是改变标志的值。 看看它是否工作。
就我而言,我只是需要来处理视图A触摸事件,这是overlaping查看B,然后发送事件查看B.这两种观点都是一样的RelativeLayout的孩子,但有一个观点之间没有父子关系和B.这为我工作:
viewA.setOnTouchListener( new OnTouchListener(){
@Override
public boolean onTouch(View v, MotionEvent event) {
// do my stuff here
viewB.dispatchTouchEvent( event );
}
}
在这种情况下,我有一个滚动视图下recyclerview。 滚动视图的顶部处于垂直滚动,并且recyclerview是在水平滚动。 滚动视图有顶级的填充,使得recyclerview是通过滚动视图填充透明度可见。 我不得不做出这种方式,因为当滚动视图滚动的recyclerview将垂直滚动,喜欢的视差效果(这种效果是另一个代码)。 此代码如下工作我的情况下,可能会帮助
scrollView.setOnTouchListener(new View.OnTouchListener() {
float mDownX,mDownY;
boolean mIsSwiping,isDown;
@Override
public boolean onTouch(View v, MotionEvent event) {
if(mIsSwiping){
recyclerView.dispatchTouchEvent(event);
}
switch (event.getActionMasked()) {
case MotionEvent.ACTION_DOWN:
mIsSwiping = false;
isDown = true;
mDownX = event.getX();
mDownY = event.getY();
break;
case MotionEvent.ACTION_MOVE:
if(isDown){
float deltaX = Math.abs(event.getX() - mDownX);
float deltaY = Math.abs(event.getY() - mDownY);
mDownX = event.getX();
mDownY = event.getY();
if(deltaX!=deltaY){
isDown = false;
if(deltaX>deltaY){
mIsSwiping = true;
}
}
}
}
return mIsSwiping;
}
});
这是布局
<FrameLayout
xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
android:orientation="vertical" android:layout_width="match_parent"
android:layout_height="match_parent"
android:background="@color/gray0"
android:clipToPadding="false"
android:clipChildren="false"
android:paddingBottom="70dp">
<android.support.v7.widget.RecyclerView
android:id="@+id/recyclerview"
android:layout_width="match_parent"
android:layout_height="320dp"
android:orientation="horizontal"
app:layoutManager="android.support.v7.widget.LinearLayoutManager"/>
<ScrollView
android:id="@+id/scrollview"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:paddingTop="301.75dp"
android:paddingBottom="23.5dp"
android:clipChildren="false"
android:clipToPadding="false">
。 。 。