欧美一级特黄大片做受成人-亚洲成人一区二区电影-激情熟女一区二区三区-日韩专区欧美专区国产专区

Android事件分發(fā)機(jī)制的詳解

Android事件分發(fā)機(jī)制

創(chuàng)新互聯(lián)主營召陵網(wǎng)站建設(shè)的網(wǎng)絡(luò)公司,主營網(wǎng)站建設(shè)方案,成都App制作,召陵h5成都微信小程序搭建,召陵網(wǎng)站營銷推廣歡迎召陵等地區(qū)企業(yè)咨詢

我們只考慮最重要的四個觸摸事件,即:DOWN,MOVE,UP和CANCEL。一個手勢(gesture)是一個事件列,以一個DOWN事件開始(當(dāng)用戶觸摸屏幕時產(chǎn)生),后跟0個或多個MOVE事件(當(dāng)用戶四處移動手指時產(chǎn)生),最后跟一個單獨的UP或CANCEL事件(當(dāng)用戶手指離開屏幕或者系統(tǒng)告訴你手勢(gesture)由于其他原因結(jié)束時產(chǎn)生)。當(dāng)我們說到“手勢剩余部分”時指的是手勢后續(xù)的MOVE事件和最后的UP或CANCEL事件。

在這里我也不考慮多點觸摸手勢(我們只假設(shè)用一個手指)并且忽略多個MOVE事件可以被歸為一組這一實際情況。最后,我們假設(shè)文中的view都沒有注冊onTouchListener。

我們將要討論的視圖層次是這樣的:最外層是一個ViewGroup A,包含一個或多個子view(children),其中一個子view是ViewGroup B,ViewGroupB中又包含一個或多個子view,其中一個子view是 View C,C不是一個ViewGroup。這里我們忽略同層級view之間可能的交叉疊加。

Android事件分發(fā)機(jī)制的詳解

假設(shè)用戶首先觸摸到的屏幕上的點是C上的某個點,該點被標(biāo)記為觸摸點(touch point),DOWN事件就在該點產(chǎn)生。然后用戶移動手指并最后離開屏幕,此過程中手指是否離開C的區(qū)域無關(guān)緊要,關(guān)鍵是手勢(gesture)是從哪里開始的。

默認(rèn)情況

假設(shè)上面的A,B,C都沒有覆寫默認(rèn)的事件傳播行為,那么下面就是事件傳播的過程:

  1. DOWN事件被傳到C的onTouchEvent方法中,該方法返回false,表示“我不關(guān)心這個手勢(gesture)”。
  2. 因此,DOWN事件被傳到B的onTouchEvent方法中,該方法同樣返回false,表示B也不關(guān)心這個手勢。
  3. 同樣,因為B不關(guān)心這個手勢,DOWN事件被傳到A的onTouchEvent方法中,該方法也返回false。

由于沒有view關(guān)心這個手勢(gesture),它們將不再會從“手勢剩余部分”中接收任何事件。

處理事件

現(xiàn)在,讓我們假設(shè)C實際上是關(guān)心這個手勢(gesture)的,原因可能是C被設(shè)置成可點擊的(clickable)或者你覆寫了C的onTouchEvent方法。

  • DOWN事件被傳遞給C的onTouchEvent方法,該方法可以做任何它想做的事情,最后返回true。
  • 因為C說它正在處理這個手勢(gesture),則DOWN事件將不再被傳遞給B和A的onTouchEvent方法。
  • 因為C說它正在處理這個手勢(gesture),所以“手勢剩余部分”的事件也將傳遞給C的onTouchEvent方法,此時該方法返回true或false都無關(guān)緊要了,但是為保持一致最好還是返回true。

個人理解:從這里可以看出,各個View的onTouchEvent方法對DOWN事件的處理,代表了該View對以此DOWN開始的整個手勢(gesture)的處理意愿,返回true代表愿意處理該gesture,返回false代表不愿意處理該gesture。

onInterceptTouchEvent

現(xiàn)在我們將討論一個新的方法:onInterceptTouchEvent,它只存在于ViewGroup中,普通的View中沒有這個方法。在任何一個view的onTouchEvent被調(diào)用之前,它的父輩們(ancestors)將先獲得攔截這個事件的一次機(jī)會,換句話說,它們可以竊取該事件。在剛才的“處理事件”部分中,我們遺漏了這一過程,現(xiàn)在,讓我們把它加上:

  • DOWN事件被傳給A的onInterceptTouchEvent,該方法返回false,表示它不想攔截。
  • DOWN又被傳遞給B的onInterceptTouchEvent,它也不想攔截,因此該方法也返回false。
  • 現(xiàn)在,DOWN事件被傳遞到C的onTouchEvent方法,該方法返回true,因為它想處理以該事件為首的手勢(gesture)。
  • 現(xiàn)在,該手勢的下一個事件MOVE到來了。這個MOVE事件再一次被傳遞給A的onInterceptTouchEvent方法,該方法再一次返回false,B也同樣如此。
  • 然后,MOVE事件被傳遞給C的onTouchEvent,就像在前一部分中一樣。
  • “手勢剩余部分”中其他事件的處理過程和上面一樣,假如A和B的onInterceptTouchEvent方法繼續(xù)返回false的話。       這里有兩點需要注意:
  • 雖然ViewGroup A和B的onInterceptTouchEvent方法對DOWN事件返回了false,后續(xù)的事件依然會傳遞給它們的onInterceptTouchEvent方法,這一點與onTouchEvent的行為是不一樣的。
  • 假如DOWN事件傳給C的onTouchEvent方法時,它返回了false,DOWN事件會繼續(xù)向上傳遞給B和A的onTouchEvent,即使它們在onInterceptTouchEvent方法中說它們不想攔截這個DOWN事件,但沒辦法,沒有子View愿意處理該事件。

個人理解:感謝@編程世界的孩子 的提醒,由此可見,DOWN事件的處理實際上經(jīng)歷了一下一上兩個過程,下是指A->B的onInterceptTouchEvent,上是指C->B->A的onTouchEvent,當(dāng)然,任意一步的方法中返回true,都能阻止它繼續(xù)傳播。

攔截事件

現(xiàn)在,讓我們更進(jìn)一步,假設(shè)B沒有攔截DOWN事件,但它攔截了接下來的MOVE事件。原因可能是B是一個scrolling view。當(dāng)用戶僅僅在它的區(qū)域內(nèi)點擊(tap)時,被點擊到的元素應(yīng)當(dāng)能處理該點擊事件。但是當(dāng)用戶手指移動了一定的距離后,就不能再視該手勢(gesture)為點擊了——很明顯,用戶是想scroll。這就是為什么B要接管該手勢(gesture)。
下面是事件被處理的順序:

  • DOWN事件被依次傳到A和B的onInterceptTouchEvent方法中,它們都返回的false,因為它們目前還不想攔截。
  • DOWN事件傳遞到C的onTouchEvent方法,返回了true。
  • 在后續(xù)到來MOVE事件時,A的onInterceptTouchEvent方法仍然返回false。
  • B的onInterceptTouchEvent方法收到了該MOVE事件,此時B注意到用戶手指移動距離已經(jīng)超過了一定的threshold(或者稱為slop)。因此,B的onInterceptTouchEvent方法決定返回true,從而接管該手勢(gesture)后續(xù)的處理。
  • 然后,這個MOVE事件將會被系統(tǒng)變成一個CANCEL事件,這個CANCEL事件將會傳遞給C的onTouchEvent方法。
  • 現(xiàn)在,又來了一個MOVE事件,它被傳遞給A的onInterceptTouchEvent方法,A還是不關(guān)心該事件,因此onInterceptTouchEvent方法繼續(xù)返回false。
  • 此時,該MOVE事件將不會再傳遞給B的onInterceptTouchEvent方法,該方法一旦返回一次true,就再也不會被調(diào)用了。事實上,該MOVE以及“手勢剩余部分”都將傳遞給B的onTouchEvent方法(除非A決定攔截“手勢剩余部分”)。
  • C再也不會收到該手勢(gesture)產(chǎn)生的任何事件了。

下面的一些小事情可能會令你感到吃驚:

  • 如果一個ViewGroup攔截了最初的DOWN事件,該事件仍然會傳遞到該ViewGroup的onTouchEvent方法中。
  • 另一方面,如果ViewGroup攔截了一個半路的事件(比如,MOVE),這個事件將會被系統(tǒng)變成一個CANCEL事件,并傳遞給之前處理該手勢(gesture)的子View,而且不會再傳遞(無論是被攔截的MOVE還是系統(tǒng)生成的CANCEL)給ViewGroup的onTouchEvent方法。只有再到來的事件才會傳遞到ViewGroup的onTouchEvent方法中。

從此開始,你可以更進(jìn)一步。比如對mouthful-method (實在不知道該怎么翻譯啦?。﹔equestDisallowInterceptTouchEvent,C可以用該方法阻止B竊取事件。如果你想更加瘋狂一點,你可以在你自己的ViewGroup中直接覆寫dispatchTouchEvent方法,并對傳遞進(jìn)來的事件做任何你想做的處理。但這樣的話你可能會破壞一些約定,所以應(yīng)當(dāng)小心。

如有疑問請留言或者到本站社區(qū)交流討論,感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!

網(wǎng)站名稱:Android事件分發(fā)機(jī)制的詳解
本文地址:http://aaarwkj.com/article48/isjpep.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供域名注冊網(wǎng)站改版、虛擬主機(jī)自適應(yīng)網(wǎng)站、網(wǎng)站設(shè)計、移動網(wǎng)站建設(shè)

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

網(wǎng)站托管運(yùn)營
少妇太爽高潮在线播放| 国产熟女av一区二区| 亚洲国产精品一区二区首页| 日韩电影在线一本二本三本| 黄色国产一区二区三区| 美国一级二级三级黄片| 91久久国产综合久久91| 国产精品自产拍在线网站| 婷婷色爱区综合五月激情| 亚洲国产精品成人久久蜜臀| 日韩精品欧美精品一区二区| 成人在线观看一区二区三区| 在线观看日韩三级av| 日吊视频在线免费观看| 国产精品一区二区婷婷| 午夜精品久久福利视频| 亚洲av资源一区二区| 色日韩在线观看视频| 中文字幕精品一区二区三区视频| 97成人在线视频免费播放| 91中文字幕在线一区| 亚洲色图熟女激情另类| 精品毛片久久久久久久久| 美女视频一区二区三区在线观看| 亚洲七七久久精品中文国产| 亚洲精品一区二区三区中文字幕| 成人av在线播放亚洲| 国产日韩欧美国产精品| 麻豆剧传媒国产精选av| 人妻熟女一区二区aⅴ在线视频| 日日嗨av特一级黄淫片| 人妻少妇一区二区三区四区| 国产高清学生三级一区二区| 免费国产成人高清在线视频| 日本人妻免费在线观看| 丰满多毛熟妇的大阴户| 中文字幕中文字幕久久不卡| 高潮内射主播自拍一区| 国产亚洲加勒比久久精品| 久草福利在线观看免费| av黄色天堂在线观看|