De ce nu funcționează SimpleOnGestureListener meu?

Îmi folosesc propria clasă GestureDetector pentru a detecta un eveniment stânga | pe dreapta. Tot ceea ce văd arată bine în codul meu, dar nu se întâmplă nimic ...?

Am nevoie de funcționalitatea adăugată dincolo de butonul de comutare care se deschide | închide o vedere de navigare în fragmentele mele. Comutatorul cheamă o metodă în clasa mea AnimationLayout după cum urmează:

public void toggleSidebar()
{
if (mContent.getAnimation() != null)
{
return;
}

if (mOpened)
{
/* opened, make close animation */
mAnimation = new TranslateAnimation(0, -mSidebarWidth, 0, 0);
mAnimation.setAnimationListener(mCloseListener);
} else
{
/* not opened, make open animation */
mAnimation = new TranslateAnimation(0, mSidebarWidth, 0, 0);
mAnimation.setAnimationListener(mOpenListener);
}
mAnimation.setDuration(DURATION);
mAnimation.setFillAfter(true);
mAnimation.setFillEnabled(true);
mContent.startAnimation(mAnimation);
}

și...

public void openSidebar()
    {
    if (!mOpened)
    {
    toggleSidebar();
    }
    }

    public void closeSidebar()
    {
    if (mOpened)
    {
    toggleSidebar();
    }
    }

În cadrul activității mele principale, onFling() cheamă pe submeniul de comutare:

public static AnimationLayout mLayout;

   //these constants are used for onFling
    private static final int SWIPE_MIN_DISTANCE = 120;
    private static final int SWIPE_MAX_OFF_PATH = 250;
    private static final int SWIPE_THRESHOLD_VELOCITY = 200;
    private GestureDetector gestureDetector;

@Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.main);

        mLayout = (AnimationLayout) findViewById(R.id.animation_layout);
        gestureDetector = new GestureDetector(this.getApplicationContext(), new MyGestureDetector());
       //Set the touch listener for the main view to be our custom gesture
       //listener
        mLayout.setOnTouchListener(new View.OnTouchListener() {
            public boolean onTouch(View v, MotionEvent event) {
                if (gestureDetector.onTouchEvent(event)) {
                    return true;
                }
                return false;
            }
        });
    }
      class MyGestureDetector extends SimpleOnGestureListener {
        @Override
        public boolean onFling(MotionEvent e1, MotionEvent e2, float velocityX, float velocityY) {

            if (Math.abs(e1.getY() - e2.getY()) > SWIPE_MAX_OFF_PATH) {
                return false;
            }
           //right to left swipe
            if (e1.getX() - e2.getX() > SWIPE_MIN_DISTANCE && Math.abs(velocityX) > SWIPE_THRESHOLD_VELOCITY) {
                Toast.makeText(getApplicationContext(), "right_left", Toast.LENGTH_LONG).show();
                Log.i("MyGestureDetector", "R2L!");
                mLayout.closeSidebar();
               //left to right swipe
            } else if (e2.getX() - e1.getX() > SWIPE_MIN_DISTANCE && Math.abs(velocityX) > SWIPE_THRESHOLD_VELOCITY) {
                Toast.makeText(getApplicationContext(), "left_right", Toast.LENGTH_LONG).show();
                Log.i("MyGestureDetector", "L2R!");
                mLayout.openSidebar();
            }

            return false;
        }

       //Return true from onDown for the onFling event to register
        @Override
        public boolean onDown(MotionEvent e) {
            return true;
        }
    }

Acest buton funcționează bine:

...
case R.id.navToggleBtn : {
                mLayout.toggleSidebar();
            }
...
0
Cred că ați putea fi corect. Voi pune funcția pe un aspect copil și voi vedea.
adăugat autor CelticParser, sursa
Puteți verifica dacă TouchListener primește chiar toate evenimentele pentru a le transmite mai departe? Dacă aspectul dvs. conține copii care sunt de asemenea atingeți, este posibil ca aceștia să fure evenimentele de la părintele lor (aspectul dvs.).
adăugat autor Devunwired, sursa

2 răspunsuri

Cred că un motiv este că Gesture lucrează la onFling care condiția nu este satisfăcută în codul u r Am implementat un OntouchListener încercați acest lucru

yourView.setOnTouchListner(onThumbTouch );




    OnTouchListener onThumbTouch = new OnTouchListener()
        {
            float previouspoint = 0 ;
            float startPoint=0;
            @Override
            public boolean onTouch(View v, MotionEvent event) 
            {   
                switch(v.getId())
                {
                case R.id.tvDetailsalaujairiyat://Give your R.id.sample ...
                {
                    switch(event.getAction())
                    {
                    case MotionEvent.ACTION_DOWN:
                    {          
                        startPoint=event.getX();
                        System.out.println("Action down,..."+event.getX());
                    }
                    break;
                    case MotionEvent.ACTION_MOVE:
                    {       

                    }break;
                    case MotionEvent.ACTION_CANCEL:
                    {                           

                        previouspoint=event.getX();
                        if(previouspoint > startPoint){
                            //Right side swape

                        }else{
                       //Left side swape
                        }

                    }break;

                    }
                    break;
                }
                }
                return true;
            }
        };
0
adăugat

Dau credit lui @Devunwired așa cum a sugerat mai sus:

Dacă aspectul conține copii care sunt, de asemenea, atingeți, pot fi   furtul evenimentelor de la părintele lor (aspectul dvs.).

Așa că am adăugat:

View swipeView = (View) findViewById(R.id.animation_layout_content);
swipeView .setOnTouchListener(new View.OnTouchListener() {...});

Ceea ce funcționează minunat acum.

0
adăugat
Un alt lucru pe care îl puteți privi peInterceptTouchEvent() care este metoda concepută pentru a permite ViewGroups să ia atingeri de la copiii lor atunci când trebuie să se ocupe de gesturi cum ar fi glisarea.
adăugat autor Devunwired, sursa
Android dezvoltatori, România — Moldova
Android dezvoltatori, România — Moldova
27 participanți

Parteneri: ciupacabra.com, @php_ro, @js_ro, @node_ro iOS: @ro_ios Reguli: https://github.com/js-ro/it-telegram/blob/master/RULES.md