欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Android使用手勢監(jiān)聽器GestureDetector遇到的不響應問題

 更新時間:2022年06月30日 14:29:54   作者:louyxlovess  
這篇文章主要介紹了Android使用手勢監(jiān)聽器GestureDetector遇到的不響應問題,具有很好的參考價值,對大家有所幫助。一起跟隨小編過來看看吧

做了一個項目,首頁是使用ResideMenu實現(xiàn),通過菜單欄里的菜單項創(chuàng)建的Fragment;所以一個Activtiy里就包含多個Fragment,想通過手勢也能側滑,就不用點擊菜單按鈕打開menu了;

方法如下:

在activity的oncreate()中初始化手勢監(jiān)聽器

mGestureDetector = new GestureDetector(getApplicationContext(), new MyGestureListener(getApplicationContext()));

然后寫一個類繼承手勢監(jiān)聽器,當然你也可以采用匿名的方法:

/******************************手勢監(jiān)聽器**************************************/

 class MyGestureListener extends GestureDetector.SimpleOnGestureListener {
   Context mContext;
 MyGestureListener(Context context) {
  mContext = context;
 }
 @Override
 public boolean onDown(MotionEvent e) {
  LogUtils.d(TAG,"onDown---DOWN " + e.getAction());
  return false;
 }

 @Override
 public void onShowPress(MotionEvent e) {
  LogUtils.d(TAG, "onShowPress---DOWN " + e.getAction());
 }

 @Override
 public boolean onSingleTapUp(MotionEvent e) {
  LogUtils.d(TAG, "onSingleTapUp---DOWN " + e.getAction());
  return false;
 }

 @Override
 public boolean onScroll(MotionEvent e1, MotionEvent e2,float distanceX, float distanceY) {
  resideMenu.openMenu(ResideMenu.DIRECTION_LEFT);
  LogUtils.d(TAG, "onScroll---DOWN " + e2.getAction());
  return false;
 }

 @Override
 public void onLongPress(MotionEvent e) {
  LogUtils.d(TAG, "onLongPress---DOWN " + e.getAction());
 }

 @Override
 public boolean onFling(MotionEvent e1, MotionEvent e2, float velocityX,float velocityY) {
  LogUtils.d(TAG, "onFling---DOWN " + e2.getAction());
  return false;
 }

 @Override
 public boolean onDoubleTap(MotionEvent e) {
  LogUtils.d(TAG, "onDoubleTap---DOWN " + e.getAction());
  return false;
 }

 @Override
 public boolean onDoubleTapEvent(MotionEvent e) {
  LogUtils.d(TAG, "onDoubleTapEvent---DOWN " + e.getAction());
  return false;
 }

 @Override
 public boolean onSingleTapConfirmed(MotionEvent e) {
  LogUtils.d(TAG, "DOWN " + e.getAction());
  return false;
 }
}

 /********************************************************************/

在onscroll方法中進行你要的滑動監(jiān)聽

注意:這個需要在activity中重寫倆個方法:

 /**
  * 重寫觸摸事件
  * @param event
  * @return
  */
 @Override
 public boolean onTouchEvent(MotionEvent event) {

  return mGestureDetector.onTouchEvent(event);
 }

 /**
  * 如果觸摸事件下有控件點擊事件,則重寫下面方法
  * @param ev
  * @return
  */
 @Override
 public boolean dispatchTouchEvent(MotionEvent ev) {
  if(mGestureDetector.onTouchEvent(ev)){
   return mGestureDetector.onTouchEvent(ev);
  }
  return super.dispatchTouchEvent(ev);
 }

在單個activity中只需要重寫第一個方法就行

補充知識:Android利用GestureDetector處理不太常用的一些點擊事件

關于GestureDetector ,在網上有很多資料是描述如下常見情況下的回調:

點擊一下非常快的(不滑動)Touchup:

onDown->onSingleTapUp->onSingleTapConfirmed

點擊一下稍微慢點的(不滑動)Touchup:

onDown->onShowPress->onSingleTapUp->onSingleTapConfirmed

長按:

onDown-->onShowPress-->onLongPress

兩次連續(xù)點擊(第二次點擊之后立即抬起):

(第一次點擊)onDown->onSingleTapUp->(第二次點擊)onDoubleTap->onDoubleTapEvent->onDown->onShowPress->onDoubleTapEvent

點擊之后滑動:

onDown->onShowPress->onScroll->......(->onFling)(視速度快慢)

但是這些并不能完美符合我們的需求,我們還會遇到以下需求:

雙擊之后拖動:

我在每個回調函數打上log,雙擊之后拖動的log如下:

(中間若干個都是onTouch: Move)

首先可以看到雙擊(onDoubleTapEvent)被回調之后的Move事件都被傳遞到了onDoubleTapEvent中。但是當你第二次點擊時間達到一定之后,onLongPress會被回調,而當onLongPress被回調之后,MOVE動作就被GestureDetector無視了,直到UP動作出現(xiàn),顯然這不是我們想要的。

那么我們可以在onDoubleTapEvent中接收到Down動作時,利用setIsLongPressEnabled()使LongPress不會觸發(fā),然后在onDoubleTapEvent中接收到Up動作時再恢復即可。

  @Override
  public boolean onDoubleTapEvent(MotionEvent e) {
    Log.d(TAG, "onDoubleTapEvent: ");
    switch (e.getAction()) {
      case MotionEvent.ACTION_DOWN:
        gestureDetector.setIsLongpressEnabled(false);
        //action
        break;
      case MotionEvent.ACTION_MOVE:
        //action
        break;
      case MotionEvent.ACTION_UP:
        //action
        gestureDetector.setIsLongpressEnabled(true);
        break;
    }
    return true;
  }

更改之后,再進行測試,如下:

(中間若干個onTouch: Move,onDoubleTapEvent)

長按拖動:

在onLongPress被回調之后,GestureDetector不會對Move動作調用任何函數,除非直到一個Up動作出現(xiàn),但用戶的習慣不可能是這樣。因此對于這個需求我們需要在onTouch中對Move動作進行識別。

首先修改onLongPress函數,在長按之后更新狀態(tài)為可拖拽,然后對onTouch中的Move動作我們自己調用onScroll(不一定要onScroll),并且在onScroll中完成動作,因此需要記錄上一次的MotionEvent:

  @Override
  public void onLongPress(MotionEvent e) {
    Log.d(TAG, "onLongPress: ");
    lastMotionEvent = e;
    draggable = true;
  }

然后在onTouch函數中:

  @Override
  public boolean onTouch(View v, MotionEvent event) {
    boolean result = gestureDetector.onTouchEvent(event);
    // 如果gestureDetector不消費動作
    if (!result) {
      switch (event.getAction()) {
        case MotionEvent.ACTION_DOWN:
          break;
        case MotionEvent.ACTION_MOVE:
          // 可拖拽狀態(tài)下調用onScroll,同時更新lastMotionEvent
          if (draggable) {
            onScroll(lastMotionEvent, event, lastMotionEvent.getX() - event.getX(), lastMotionEvent.getY() - event.getY());
            lastMotionEvent = MotionEvent.obtain(event);
          }
          result = true;
          break;
        case MotionEvent.ACTION_UP:
          // 恢復為不可拖拽狀態(tài)
          if (draggable) {
            onScroll(lastMotionEvent, event, lastMotionEvent.getX() - event.getX(), lastMotionEvent.getY() - event.getY());
            lastMotionEvent = null;
            draggable = false;
          }
          result = true;
          break;
      }
    }
    return result;
  }

處理點擊-滑動之后的ACTION_UP

滑動的回調是這樣的

onDown->onShowPress->onScroll->......(->onFling)(視速度快慢)

如果onFling沒有被回調的話,我們無法對onScroll之后的Up動作響應,因此對于這個動作,我們也要在onTouch中處理。

首先要明確:從點A滑動到點B,并且在點B松手的話,在沒有觸發(fā)onFling的情況下,會回調onScroll(eA, eB, distanceX, distanceY),然后GestureDetector不消費點B的Up事件,此時我們在onTouch中處理這個Up事件。

代碼也很簡單,在長按拖動的基礎上增加一個else即可:

        case MotionEvent.ACTION_UP:
          if (draggable) {
            onScroll(lastMotionEvent, event, lastMotionEvent.getX() - event.getX(), lastMotionEvent.getY() - event.getY());
            lastMotionEvent = null;
            draggable = false;
          } else {
            afterScroll(event);
          }
          result = true;
          break;

具體需要處理何種點擊事件可根據實際修改,希望分享的內容能給你一點idea。

以上這篇Android使用手勢監(jiān)聽器GestureDetector遇到的不響應問題就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關文章

  • Android自定義View設定到FrameLayout布局中實現(xiàn)多組件顯示的方法 分享

    Android自定義View設定到FrameLayout布局中實現(xiàn)多組件顯示的方法 分享

    Android自定義View設定到FrameLayout布局中實現(xiàn)多組件顯示的方法 分享,需要的朋友可以參考一下
    2013-05-05
  • Android RecyclerView滾動定位

    Android RecyclerView滾動定位

    這篇文章主要為大家詳細介紹了Android RecyclerView滾動定位的相關資料,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-01-01
  • Android sdcard實現(xiàn)圖片存儲 、聯(lián)網下載

    Android sdcard實現(xiàn)圖片存儲 、聯(lián)網下載

    這篇文章主要介紹了Android sdcard實現(xiàn)圖片存儲 、聯(lián)網下載功能,感興趣的小伙伴們可以參考一下
    2016-02-02
  • Compose?動畫藝術探索之可見性動畫示例詳解

    Compose?動畫藝術探索之可見性動畫示例詳解

    這篇文章主要為大家介紹了Compose?動畫藝術探索之可見性動畫示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-09-09
  • Flutter質感設計之列表項

    Flutter質感設計之列表項

    這篇文章主要為大家詳細介紹了Flutter質感設計之列表項,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-08-08
  • Android ProgressBar組件使用教程

    Android ProgressBar組件使用教程

    Android ProgressBar分為水平進度條和圓形進度條, 看官方的劃分是Indeterminate Progress(不確定的進度) 和 Determinate Progress(決定進度)下面有2個demo一個是圓形的進度條和一個水平的進度條
    2022-11-11
  • 深入理解Android熱修復技術原理之代碼熱修復技術

    深入理解Android熱修復技術原理之代碼熱修復技術

    在各種 Android 熱修復方案中,Andfix的即時生效令人印象深刻,它稍顯另類, 并不需要重新啟動,而是在加載補丁后直接對方法進行替換就可以完成修復,然而它的使用限制也遭遇到更多的質疑
    2021-06-06
  • Android編程自定義搜索框實現(xiàn)方法【附demo源碼下載】

    Android編程自定義搜索框實現(xiàn)方法【附demo源碼下載】

    這篇文章主要介紹了Android編程自定義搜索框實現(xiàn)方法,涉及Android界面布局、數據加載、事件響應等相關操作技巧,并附帶完整demo源碼供讀者下載參考,需要的朋友可以參考下
    2017-12-12
  • Android MIUI通知類短信權限的坑

    Android MIUI通知類短信權限的坑

    本篇文章主要介紹了Android MIUI通知類短信權限的坑,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-03-03
  • Android中的JSON詳細總結

    Android中的JSON詳細總結

    一種輕量級的數據交換格式,具有良好的可讀和便于快速編寫的特性。業(yè)內主流技術為其提供了完整的解決方案(有點類似于正則表達式,獲得了當今大部分語言的支持),從而可以在不同平臺間進行數據交換
    2013-01-01

最新評論