真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

Android中觸摸事件與點擊事件有什么區(qū)別

本篇文章給大家分享的是有關(guān)Android中觸摸事件與點擊事件有什么區(qū)別,小編覺得挺實用的,因此分享給大家學(xué)習(xí),希望大家閱讀完這篇文章后可以有所收獲,話不多說,跟著小編一起來看看吧。

成都創(chuàng)新互聯(lián)公司 - 移動服務(wù)器托管,四川服務(wù)器租用,成都服務(wù)器租用,四川網(wǎng)通托管,綿陽服務(wù)器托管,德陽服務(wù)器托管,遂寧服務(wù)器托管,綿陽服務(wù)器托管,四川云主機(jī),成都云主機(jī),西南云主機(jī),移動服務(wù)器托管,西南服務(wù)器托管,四川/成都大帶寬,機(jī)柜大帶寬、租用·托管,四川老牌IDC服務(wù)商

1.  onTouchEvent

onTouchEvent中要處理的最常用的3個事件就是:ACTION_DOWN、ACTION_MOVE、ACTION_UP。

這三個事件標(biāo)識出了最基本的用戶觸摸屏幕的操作,含義也很清楚。雖然大家天天都在用它們,但是有一點請留意,ACTION_DOWN事件作為起始事件,它的重要性是要超過ACTION_MOVE和ACTION_UP的,如果發(fā)生了ACTION_MOVE或者ACTION_UP,那么一定曾經(jīng)發(fā)生了ACTION_DOWN。

從Android的源代碼中能看到基于這種不同重要性的理解而實現(xiàn)的一些交互機(jī)制,SDK中也有明確的提及,例如在ViewGroup的onInterceptTouchEvent方法中,如果在ACTION_DOWN事件中返回了true,那么后續(xù)的事件將直接發(fā)給onTouchEvent,而不是繼續(xù)發(fā)給onInterceptTouchEvent。

2.  onClick、onLongClick與onTouchEvent

曾經(jīng)看過一篇帖子提到,如果在View中處理了onTouchEvent,那么就不用再處理onClick了,因為Android只會觸發(fā)其中一個方法。這個理解是不太正確的,針對某個view,用戶完成了一次觸碰操作,顯然從傳感器上得到的信號是手指按下和抬起兩個操作,我們可以理解為一次Click,也可以理解為發(fā)生了一次ACTION_DOWN和ACTION_UP,那么Android是如何理解和處理的呢?

在Android中,onClick、onLongClick的觸發(fā)是和ACTION_DOWN及ACTION_UP相關(guān)的,在時序上,如果我們在一個View中同時覆寫了onClick、onLongClick及onTouchEvent的話,onTouchEvent是***捕捉到ACTION_DOWN和ACTION_UP事件的,其次才可能觸發(fā)onClick或者onLongClick。主要的邏輯在View.java中的onTouchEvent方法中實現(xiàn)的:

  1. case MotionEvent.ACTION_DOWN: 

  2.     mPrivateFlags |= PRESSED; 

  3.     refreshDrawableState(); 

  4.     if ((mViewFlags & LONG_CLICKABLE) == LONG_CLICKABLE) { 

  5.          postCheckForLongClick();  

  6.     } 

  7.     break; 

  8. case MotionEvent.ACTION_UP: 

  9.     if ((mPrivateFlags & PRESSED) != 0) { 

  10.          boolean focusTaken = false; 

  11.          if (isFocusable() && isFocusableInTouchMode() && !isFocused()) { 

  12.                focusTaken = requestFocus(); 

  13.          } 

  14.     if (!mHasPerformedLongPress) { 

  15.        if (mPendingCheckForLongPress != null) { 

  16.              removeCallbacks(mPendingCheckForLongPress); 

  17.        } 

  18.        if (!focusTaken) { 

  19.               performClick(); 

  20.        } 

  21.     } 

  22.     … 

  23.     break;

  可以看到,Click的觸發(fā)是在系統(tǒng)捕捉到ACTION_UP后發(fā)生并由performClick()執(zhí)行的,performClick里會調(diào)用先前注冊的監(jiān)聽器的onClick()方法:

  1. public boolean performClick() { 

  2.     … 

  3.     if (mOnClickListener != null) { 

  4.         playSoundEffect(SoundEffectConstants.CLICK); 

  5.         mOnClickListener.onClick(this); 

  6.         return true; 

  7.     } 

  8.         return false; 

  9. }

LongClick的觸發(fā)則是從ACTION_DOWN開始,由postCheckForLongClick()方法完成:

private void postCheckForLongClick() {      mHasPerformedLongPress = false;      if (mPendingCheckForLongPress == null) {          mPendingCheckForLongPress = new CheckForLongPress();      }      mPendingCheckForLongPress.rememberWindowAttachCount();      postDelayed(mPendingCheckForLongPress, ViewConfiguration.getLongPressTimeout()); }

可以看到,在ACTION_DOWN事件被捕捉后,系統(tǒng)會開始觸發(fā)一個postDelayed操作,delay的時間在Eclair2.1上為500ms,500ms后會觸發(fā)CheckForLongPress線程的執(zhí)行:

  1. class CheckForLongPress implements Runnable { 

  2.  

  3. … 

  4.         public void run() { 

  5.             if (isPressed() && (mParent != null) 

  6.                     && mOriginalWindowAttachCount == mWindowAttachCount) { 

  7.                 if (performLongClick()) { 

  8.                     mHasPerformedLongPress = true; 

  9.                 } 

  10.             } 

  11.         } 

  12. … 

  13. }

如果各種條件都滿足,那么在CheckForLongPress中執(zhí)行performLongClick(),在這個方法中將調(diào)用onLongClick():

  1. public boolean performLongClick() { 

  2.       … 

  3.       if (mOnLongClickListener != null) { 

  4.           handled = mOnLongClickListener.onLongClick(View.this); 

  5.       } 

  6.       … 

  7. }

從實現(xiàn)中可以看到onClick()和onLongClick()方法是由ACTION_DOWN和ACTION_UP事件捕捉后根據(jù)各種情況最終確定是否觸發(fā)的,也就是說如果我們在一個Activity或者View中同時監(jiān)聽或者覆寫了onClick(),onLongClick()和onTouchEvent()方法,并不意味著只會發(fā)生其中一種。

下面是一個onClick被觸發(fā)的基本時序的Log:

04-05 05:57:47.123: DEBUG/TSActivity(209): onTouch ACTION_DOWN

04-05 05:57:47.263: DEBUG/TSActivity(209): onTouch ACTION_UP

04-05 05:57:47.323: DEBUG/TSActivity(209): onClick

可以看出是按ACTION_DOWN -> ACTION_UP -> onClick的次序發(fā)生的。

下面是一個onLongClick被觸發(fā)的基本時序的Log:

04-05 06:00:04.133: DEBUG/TSActivity(248): onTouch ACTION_DOWN

04-05 06:00:04.642: DEBUG/TSActivity(248): onLongClick

04-05 06:00:05.083: DEBUG/TSActivity(248): onTouch ACTION_UP

可以看到,在保持按下的狀態(tài)一定時間后會觸發(fā)onLongClick,之后抬起手才會發(fā)生ACTION_UP。

3.  onClick和onLongClick能同時發(fā)生嗎?

  要弄清楚這個問題只要理解Android對事件處理的所謂消費(consume)概念即可,一個用戶的操作會被傳遞到不同的View控件和同一個控件的不同監(jiān)聽方法處理,任何一個接收并處理了該次事件的方法如果在處理完后返回了true,那么該次event就算被完全處理了,其他的View或者監(jiān)聽方法就不會再有機(jī)會處理該event了。

  onLongClick的發(fā)生是由單獨的線程完成的,并且在ACTION_UP之前,而onClick的發(fā)生是在ACTION_UP后,因此同一次用戶touch操作就有可能既發(fā)生onLongClick又發(fā)生onClick。這樣是不是不可思議?所以及時向系統(tǒng)表示“我已經(jīng)完全處理(消費)了用戶的此次操作”,是很重要的事情。例如,我們?nèi)绻趏nLongClick()方法的***return true,那么onClick事件就沒有機(jī)會被觸發(fā)了。

下面的Log是在onLongClick()方法return false的情況下,一次觸碰操作的基本時序:

04-05 06:00:53.023: DEBUG/TSActivity(277): onTouch ACTION_DOWN

04-05 06:00:53.533: DEBUG/TSActivity(277): onLongClick

04-05 06:00:55.603: DEBUG/TSActivity(277): onTouch ACTION_UP

04-05 06:00:55.663: DEBUG/TSActivity(277): onClick

以上就是Android中觸摸事件與點擊事件有什么區(qū)別,小編相信有部分知識點可能是我們?nèi)粘9ぷ鲿姷交蛴玫降?。希望你能通過這篇文章學(xué)到更多知識。更多詳情敬請關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道。


本文題目:Android中觸摸事件與點擊事件有什么區(qū)別
文章起源:http://weahome.cn/article/ippdoj.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部