如何将触摸事件传输到RelativeLayout下面的视图?

时间:2012-10-11 07:52:56

标签: android events touch android-scrollview

我在另一个视图(ScrollView)之上有一个ButtonsScrollView占据整个屏幕并遮挡其下方的视图。

在我的应用中的某个时刻,我需要ScrollView被禁用(但仍然可见)并将所有触摸事件传输到Buttons下方的ScrollView。我怎样才能做到这一点?像Buttons这样的某些视图会在禁用时自动执行,但ScrollView不会这样做。

3 个答案:

答案 0 :(得分:11)

尝试实现您自己的ScrollView,其中有一个标志以指示状态(已禁用/已启用),还会覆盖onTouchEventdispatchTouchEvent以让触摸事件通过{ {1}}。这是一个例子:

ScrollView

然后你所要做的就是改变那个标志的值。看看它是否有效。

答案 1 :(得分:2)

在我的情况下,我只需要处理View A中的触摸事件,该事件覆盖View B,然后将事件发送到View B.两个视图都是相同RelativeLayout的子视图,但没有父子关系在视图A和B之间。这对我有用:

viewA.setOnTouchListener( new OnTouchListener(){

        @Override
        public boolean onTouch(View v, MotionEvent event) {
          // do my stuff here

          viewB.dispatchTouchEvent( event );
        }
}

答案 2 :(得分:0)

在这种情况下,我在scrollview下有一个recyclerview。 scrollview的顶部是垂直滚动,Recyclerview是水平滚动。 scrollview具有顶部填充,通过scrollview填充中的透明度可以看到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">

。 。 。