首頁 文章 手势响应系统

手势响应系统

2024-06-12 22:38  瀏覽數:243  來源:许某    

移动设备上的手势识别要比在 web 上复杂得多。用户的一次触摸操作的真实意图是什么,App 要经过好几个阶段才
能判断。比如 App 需要判断用户的触摸到底是在滚动页面,还是滑动一个 widget,或者只是一个单纯的点击。
甚至随着持续时间的不同,这些操作还会转化。此外,还有多点同时触控的情况。手势响应系统可以使组件在不关心父组件或
子组件的前提下自行处理触摸交互。最佳实践用户之所以会觉得 web app 和原生 app 在体验上有巨大的差异
,触摸响应是一大关键因素。用户的每一个操作都应该具有下列属性:反馈/高亮 —— 让用户看到他们到底按到了什么东
西,以及松开手后会发生什么。取消功能 —— 当用户正在触摸操作时,应该是可以通过把手指移开来终止操作。这些特性
使得用户在使用 App 时体验更好,因为它们可以让用户大胆试用,而不必担心点错了什么。TouchableHig
hlight 与 Touchable 系列组件响应系统用起来可能比较复杂。所以我们提供了一个抽象的Toucha
ble实现,用来做“可触控”的组件。这一实现利用了响应系统,使得你可以简单地以声明的方式来配置触控处理。如果要
做一个按钮或者网页链接,那么使用TouchableHighlight就可以。响应者的生命周期一个 View 只
要实现了正确的协商方法,就可以成为触摸事件的响应者。我们通过两个方法去“询问”一个 View 是否愿意成为响应
者:View.props.onStartShouldSetResponder: (evt) => true,
- 在用户开始触摸的时候(手指刚刚接触屏幕的瞬间),是否愿意成为响应者?View.props.onMoveSh
ouldSetResponder: (evt) => true, - 如果 View 不是响应者,那么在每一个
触摸点开始移动(没有停下也没有离开屏幕)时再询问一次:是否愿意响应触摸交互呢?如果 View 返回 true,
并开始尝试成为响应者,那么会触发下列事件之一:View.props.onResponderGrant: (ev
t) => {} - View 现在要开始响应触摸事件了。这也是需要做高亮的时候,使用户知道他到底点到了哪里。
View.props.onResponderReject: (evt) => {} - 响应者现在“另有其人”
而且暂时不会“放权”,请另作安排。如果 View 已经开始响应触摸事件了,那么下列这些处理函数会被一一调用:V
iew.props.onResponderMove: (evt) => {} - 用户正在屏幕上移动手指时(没
有停下也没有离开屏幕)。View.props.onResponderRelease: (evt) => {}
- 触摸操作结束时触发,比如"touchUp"(手指抬起离开屏幕)。View.props.onResponde
rTerminationRequest: (evt) => true - 有其他组件请求接替响应者,当前的 V
iew 是否“放权”?返回 true 的话则释放响应者权力。View.props.onResponderTer
minate: (evt) => {} - 响应者权力已经交出。这可能是由于其他 View 通过onRespo
nderTerminationRequest请求的,也可能是由操作系统强制夺权(比如 iOS 上的控制中心或是
通知中心)。evt是一个合成事件,它包含以下结构:nativeEventchangedTouches - 在上
一次事件之后,所有发生变化的触摸事件的数组集合(即上一次事件后,所有移动过的触摸点)identifier -
触摸点的 IDlocationX - 触摸点相对于当前元素的横坐标locationY - 触摸点相对于当前元素
的纵坐标pageX - 触摸点相对于根元素的横坐标pageY - 触摸点相对于根元素的纵坐标target -
触摸点所在的元素 IDtimestamp - 触摸事件的时间戳,可用于移动速度的计算touches - 当前屏
幕上的所有触摸点的集合捕获 ShouldSet 事件处理onStartShouldSetResponder与o
nMoveShouldSetResponder是以冒泡的形式调用的,即嵌套最深的节点最先调用。这意味着当多个
View 同时在*ShouldSetResponder中返回 true 时,最底层的 View 将优先“夺权”
。在多数情况下这并没有什么问题,因为这样可以确保所有控件和按钮是可用的。但是有些时候,某个父 View 会希望
能先成为响应者。我们可以利用“捕获期”来解决这一需求。响应系统在从最底层的组件开始冒泡之前,会首先执行一个“捕
获期”,在此期间会触发on*ShouldSetResponderCapture系列事件。因此,如果某个父 Vi
ew 想要在触摸操作开始时阻止子组件成为响应者,那就应该处理onStartShouldSetResponder
Capture事件并返回 true 值。View.props.onStartShouldSetResponde
rCapture: (evt) => true,View.props.onMoveShouldSetRespo
nderCapture: (evt) => true,PanResponder要使用更高级的手势功能,请参看P
anResponder.



聲明:以上文章均為用戶自行添加,僅供打字交流使用,不代表本站觀點,本站不承擔任何法律責任,特此聲明!如果有侵犯到您的權利,請及時聯系我們刪除。

字符:    改为:
去打字就可以设置个性皮肤啦!(O ^ ~ ^ O)