1

ScrollView の inisde に ViewPager がありますが、ViewPager は正しく動作しません。私は知っています、この質問は似ています、そして私はグーグルでいくつかの解決策を読みました. また、ScrollView の背後には、スタックされたフラグメントがいくつかあります。このHorizo​​ntalScrollView を ScrollView Touch Handling (viewpager と scrollview を拡張) 内で試してみましたが、うまく機能しますが、完全ではありません。スタックされたフラグメントが Touch イベントをキャプチャしていると思います。

誰かにこの問題がありますか?ありがとう

編集: コードを追加します。

カスタムスクロールビュー:

public class ScrollViewS extends ScrollView {
    /* THIS COMMENT CODE IS THE OTHER SOLUTION
    private GestureDetector mGestureDetector;
    View.OnTouchListener mGestureListener;

    public ScrollViewS(Context context, AttributeSet attrs) {
        super(context, attrs);
        mGestureDetector = new GestureDetector(context, new YScrollDetector());
        setFadingEdgeLength(0);
    }

    @Override
    public boolean onInterceptTouchEvent(MotionEvent ev) {
        return super.onInterceptTouchEvent(ev) && mGestureDetector.onTouchEvent(ev);
    }

    // Return false if we're scrolling in the x direction  
    class YScrollDetector extends SimpleOnGestureListener {
        @Override
        public boolean onScroll(MotionEvent e1, MotionEvent e2, float distanceX, float distanceY) {
            if(Math.abs(distanceY) > Math.abs(distanceX)) {
                return true;
            }
            return false;
        }
    }
    */
    private float xDistance, yDistance, lastX, lastY;

    public ScrollViewS(Context context, AttributeSet attrs) {
        super(context, attrs);
    }

    @Override
    public boolean onInterceptTouchEvent(MotionEvent ev) {
        switch (ev.getAction()) {
            case MotionEvent.ACTION_DOWN:
                xDistance = yDistance = 0f;
                lastX = ev.getX();
                lastY = ev.getY();
                break;
            case MotionEvent.ACTION_MOVE:
                final float curX = ev.getX();
                final float curY = ev.getY();
                xDistance += Math.abs(curX - lastX);
                yDistance += Math.abs(curY - lastY);
                lastX = curX;
                lastY = curY;
                if(xDistance > yDistance)
                    return false;
        }

        return super.onInterceptTouchEvent(ev);
    }
}

ViewPager コード:

public class ViewPagerS extends ViewPager {

    public ViewPagerS(Context context, AttributeSet attrs) {
        super(context, attrs);
    }

    public boolean onInterceptTouchEvent(MotionEvent ev) {
        // Tell our parent to stop intercepting our events!
        boolean ret = super.onInterceptTouchEvent(ev);
        if (ret) {
            getParent().requestDisallowInterceptTouchEvent(true);
        }
        return ret;
    }
}

XML は次のとおりです。

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:background="@color/fondoapp"
    android:orientation="vertical" >


    <com.geo.sov.customviews.ScrollViewS
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:background="@drawable/borde_redondeado"
        android:id="@+id/scrollview_fragmentaccounts"
         >

       <LinearLayout
            android:id="@+id/x"
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:layout_gravity="center_horizontal"
            android:layout_margin="5dp"
            android:orientation="vertical" 
        >

            <TextView
                android:id="@+id/title_accounts"
                android:layout_width="match_parent"
                android:layout_height="wrap_content"
                android:textColor="#000000"
                android:textSize="14dp"
                android:textStyle="bold" />

            <com.geo.sov.customviews.ViewPagerS
                android:id="@+id/pager"
                android:layout_width="wrap_content"
                android:layout_height="95dp"
                android:background="#FFFFFFFF" /> 

            <com.viewpagerindicator.CirclePageIndicator
                android:id="@+id/indicator"
                android:layout_width="fill_parent"
                android:layout_height="20dp"
                android:padding="10dip"
                app:pageColor="#88FF0000"
                app:radius="3dp"
                app:strokeColor="#FF666666"
                app:strokeWidth="1dp" />

(........)

アプリを起動すると、フラグメントが 1 つあり、ユーザーが正しくログオンした場合は、次のコードで変更します。

FragmentManager fragmentManager = getFragmentManager();
FragmentTransaction fragmentTransaction = fragmentManager.beginTransaction();

Fragment f = new AccountsFragment();

fragmentTransaction.add(R.id.fragment, f);
fragmentTransaction.commit();  

そして、フラグメントを使っていくつかの問題を実験します。AccountsFragments に変更すると、空のスペースをタッチすると、タッチ イベントがログオン フラグメントに渡されます。scrollview と viewpager は正しいと思います。問題は、それらがイベントをインターセプトしているフラグメントです。

4

0 に答える 0