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

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

前端知識|ReactNative手勢響應(yīng)淺析

目前手機市場上,全面屏?xí)r代已經(jīng)勢不可擋,為了增大屏幕,一個個物理按鍵已漸漸消失在手機上。那么,手勢將成為在移動應(yīng)用開發(fā)中一個重要的組成部分,移動設(shè)備上手勢識別要比 web 端復(fù)雜得多,往往用戶的一個手勢,我們在 APP 上要通過好幾個階段去判斷用戶的真實意圖是什么,在 ReactNative (以下簡稱 RN)中針對手勢處理也提供了從最基本的點擊手勢到復(fù)雜的滑動等一系列解決方案,讓我們一起去看看。

成都創(chuàng)新互聯(lián)自成立以來,一直致力于為企業(yè)提供從網(wǎng)站策劃、網(wǎng)站設(shè)計、網(wǎng)站建設(shè)、網(wǎng)站制作、電子商務(wù)、網(wǎng)站推廣、網(wǎng)站優(yōu)化到為企業(yè)提供個性化軟件開發(fā)等基于互聯(lián)網(wǎng)的全面整合營銷服務(wù)。公司擁有豐富的網(wǎng)站建設(shè)和互聯(lián)網(wǎng)應(yīng)用系統(tǒng)開發(fā)管理經(jīng)驗、成熟的應(yīng)用系統(tǒng)解決方案、優(yōu)秀的網(wǎng)站開發(fā)工程師團(tuán)隊及專業(yè)的網(wǎng)站設(shè)計師團(tuán)隊。

RN基本觸控組件

RN 的組件除了 Text,其他組件默認(rèn)是不支持點擊事件的,也不能成為一個觸摸事件的響應(yīng)者。RN 提供了幾個比較直接的處理響應(yīng)事件的組件,基本上能滿足大部分的點擊事件的處理需求。

TouchableHighlight

TouchableNativeFeedback (僅限 Android 平臺)

TouchableOpacity

TouchableWithoutFeedback

這幾個組件的功能和使用方法基本類似,只是就 Touch 的效果反饋上有所差異,他們有如下幾個回調(diào)方法:

onPressIn:用戶觸摸開始的時候,也就是手指剛落在 Touch 點擊區(qū)域內(nèi)的時觸發(fā)

onPressOut:用戶觸摸結(jié)束的時候,也就是手指從 Touch 點擊區(qū)域內(nèi)抬起的時觸發(fā)

onPress:用戶完成一次從 onPressIn 到 onPressOut 的過程,且時間很短,即一次快速點擊操作時觸發(fā)

onLongPress:用戶觸發(fā) onPressIn 且手指一段時間內(nèi)沒有抬起時觸發(fā)

這里以 TouchableHighlight 為例,貼一個 Touch 的基本用法:

前端知識 | React Native手勢響應(yīng)淺析

RN 中提供的 Touch 組件的使用非常簡單,可以參考官方文檔,這里就不做詳細(xì)的介紹了,我們主要來說下用戶的觸摸事件處理。

gesture responder system

在 RN 中,響應(yīng)手勢的基本單位是 responder,具體點說就是最常見的 View 組件。任何的 View 組件都可以成為一個手勢的響應(yīng)者。其實要把一個普通的 View 組件開發(fā)成為一個能響應(yīng)手勢操作的 responder 很簡單,話不多說,我們舉栗子!

前端知識 | React Native手勢響應(yīng)淺析

乍一看,WillMount 里面的這幾個方法名字又長又奇怪,但是等你了解了 RN 手勢響應(yīng)的流程了之后,記憶這幾個方法就非常簡單了。在我們探索這幾個方法之前,我們首先要記住一個重要的點:

一個 RN 應(yīng)用中只能存在一個 responder!

 一次正常的手勢操作的流程如下所示:

是否響應(yīng) Touch 或者 move 手勢->grant(被激活) ->move->release (結(jié)束事件)

與流程相對應(yīng)的方法是:

onStartShouldSetResponder(event) => true:在用戶開始進(jìn)行觸摸操作時(手指剛剛接觸屏幕的瞬間),詢問是否申請成為觸摸事件的響應(yīng)者,返回 true 為需要成為響應(yīng)者。

onMoveShouldSetResponder(event) => true:如果綁定的View不是響應(yīng)者,那么會在用戶的觸摸點開始移動的時候再次詢問是否申請成為觸摸時間的響應(yīng)者,返回true

為需要成為響應(yīng)者。

假設(shè)組件通過上面的方法返回了 true,表示發(fā)出了申請需要成為響應(yīng)者,但是我們前面說過,一個 RN 應(yīng)用中只能有一個 responder,那么接下來就需要協(xié)調(diào)所有組件的請求,看看這個響應(yīng)者的位置給誰。

onResponderGrant:(event) => {}:View 申請成功,并成為了響應(yīng)者。一般情況下,這時開始,組件進(jìn)入了激活狀態(tài),并進(jìn)行一些事件處理或者手勢識別的初始化。

onResponderReject: (event) =>{}:View 申請失敗了,這就意味著有其他的組件正在成為或者已經(jīng)成為了響應(yīng)者,并且他不愿意交出這個權(quán)利。所以你被拒絕了~

如果你成為了響應(yīng)者,那么會收到后續(xù)的事件輸入并由你來決定他的行為動作:

onResponderMove: (event) => 表示觸摸手指的移動事件,這個回調(diào)在一次完成的手勢動作中可能會非常頻繁的調(diào)用,所以這個回調(diào)函數(shù)里面的內(nèi)容需要盡量簡單

onResponderRelease: (event) => 表示觸摸完成,相當(dāng)于前面講的 Touch 里面的 onPressOut 方法,表示用戶已經(jīng)完成了本次的觸摸操作,同時會釋放響應(yīng)者這個權(quán)利。

在你成為響應(yīng)者期間,其他組件也有可能會申請成為響應(yīng)者,那么此時RN會通過回調(diào)來詢問當(dāng)前的響應(yīng)者是否放權(quán)給其他申請者。回調(diào)如下:

onResponderTerminationRequest: (event) => true:如果我們返回的是 true,那就代表當(dāng)前響應(yīng)者同意放權(quán),讓其他的組件來當(dāng)響應(yīng)者,自己回歸平淡的生活,同時也會回調(diào)一個函數(shù),通知組件事件響應(yīng)處理被終止了:

onResponderTerminate: (event) => {}:這個回調(diào)也會發(fā)生在系統(tǒng)直接終止組件的觸摸事件處理中,比如用戶在進(jìn)行觸摸操作的時候,來電話了,或者意外閃退了。

相信大家都發(fā)現(xiàn)了,所有的方法都有一個 event 參數(shù),里面包含了一個觸摸事件數(shù)據(jù) nativeEvent,nativeEvent 具體結(jié)構(gòu)如下圖:

前端知識 | React Native手勢響應(yīng)淺析

chanedTouches:event 數(shù)組,從上次回調(diào)上報的觸摸事件,到這次上報之間的所有事件數(shù)組。因為在用戶觸摸過程中會產(chǎn)生很多事件,有時候可能還沒來得及上報,系統(tǒng)就用這種方式批量上報

identifier:觸摸的 ID,這個 ID 存在周期為從觸摸開始到釋放為止,主要是用來區(qū)別在多點觸控的情況下,區(qū)分是哪個手指的觸摸事件。

locationX 和 locationY:觸摸點相對于組件的位置

pageX 和 pageY:觸摸點相對于屏幕的位置

target:接收當(dāng)前觸摸事件的組件 ID

timestamp:當(dāng)前觸摸的事件的時間戳,可以用來進(jìn)行滑動的相關(guān)計算(速度,停留時長)

touches:event 數(shù)組,多點觸摸的時候,包含當(dāng)前所有觸摸點的事件

冒泡機制和事件捕獲

先前我們都是針對單一組件來說的,但是在實際開發(fā)過程中,我們往往會遇到很多嵌套之類的組件,那如果在我們多重嵌套的組件中,每層組件綁定了一個手勢響應(yīng)且 onStartShouldSetResponder 或者 onMoveShouldSetResponder 回調(diào)都返回了 true 來申請成為響應(yīng)者的話,又會怎么樣呢?我們舉個栗子來看看:

前端知識 | React Native手勢響應(yīng)淺析

前端知識 | React Native手勢響應(yīng)淺析

在這個大栗子中,我們嵌套了兩層組件,使得組件布局如圖:

前端知識 | React Native手勢響應(yīng)淺析

在RN中,默認(rèn)情況下會遵循冒泡機制,也就是嵌套最深的組件最先開始響應(yīng),那么我們栗子中的三層組件的 onStartShouldSetResponder 或者 onMoveShouldSetResponder 全部都返回 true 的情況下,那么 C 組件會優(yōu)先成為事件響應(yīng)者。但在我們的實際開發(fā)中,可能你需要的是父組件去處理觸控事件,而禁止子組件響應(yīng),那腫么辦?。RN 給我們提供了一個事件捕獲機制,也就是在觸摸事件通過冒泡機制往下傳遞的時候,先詢問上層有申請的組件是否捕獲該事件,不給子組件傳遞事件,即上面的栗子中,正常情況下通過冒泡機制,我們的觸控事件會 A->B->C 這樣傳遞到 C 去響應(yīng)事件,當(dāng) A 傳遞到 B 時,會詢問 A 是否捕獲這個觸控事件并且不再向下傳遞給 B 和 C,如果 A確認(rèn)捕獲,那么 A 即成為這個事件的響應(yīng)者。具體的回調(diào)是:

onStartShouldSetResponderCapture: () => true :在觸摸事件開始的時候,RN 容器的組件就會收到這么一個回調(diào)函數(shù),詢問是否捕獲事件成為響應(yīng)者,如果返回true,表示確認(rèn)捕獲事件

onMoveShouldSetResponderCapture: () =>true :在觸摸事件開始移動的時候,再次詢問是否捕獲事件成為響應(yīng)者,如果返回 true,表示確認(rèn)捕獲事件

PanResponder

除了 gesture responder system 之外,RN 還抽象出了一套 PanResponder 方法,這套方法的好處在于,使用起來更方便,在不改變原有的邏輯和流程的前提下,提供了更多的參數(shù),包含了手勢進(jìn)行過程中更多的信息,讓我們更好的去理解和處理用戶的手勢意圖,話不多說,直接上栗子。

前端知識 | React Native手勢響應(yīng)淺析

前端知識 | React Native手勢響應(yīng)淺析

在上面的栗子中,我們實現(xiàn)了在一個白色有邊框的事件響應(yīng)者開始響應(yīng)事件而變成綠色,然后實現(xiàn)拖拽效果并且在拖拽過程中變成紅色,最后在釋放手指又變回白色的這么一個過程。

大體上和 gesture responder system 一樣,我們要注意的就是幾個方法的寫法加上了 Pan,并且?guī)讉€回調(diào)函數(shù)多了一個 gesture 參數(shù),他具體長這樣的:

前端知識 | React Native手勢響應(yīng)淺析

dx 和 dy:從觸摸操作開始到現(xiàn)在的累積橫向/縱向路程

moveX 和 moveY:最近一次移動時的屏幕橫/縱坐標(biāo)

numberActiveTouches:當(dāng)前在屏幕上的有效觸摸點的數(shù)量

stated:和之前一樣,用來識別手指的ID

vx 和 vy:當(dāng)前橫向/縱向移動的速度

x0 和 y0:當(dāng)觸摸操作開始時組件相對于屏幕的橫/縱坐標(biāo)

總結(jié)

以上是我對 RN 的一些基礎(chǔ)學(xué)習(xí)和理解,只舉了一些簡單的栗子,要在項目里實現(xiàn)一些更為復(fù)雜的手勢操作,還需要進(jìn)一步的摸索研究。另外需要注意的是,上述的回調(diào)函數(shù)都是在 JS 線程中進(jìn)行的,可能會有些許延遲。

【海說軟件接受各種技術(shù)咨詢及開發(fā)業(yè)務(wù)】

-END- 


網(wǎng)站標(biāo)題:前端知識|ReactNative手勢響應(yīng)淺析
鏈接地址:http://weahome.cn/article/jpsoed.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部