![](/img/trans.png)
[英]SimpleOnGestureListener.onScroll receives a null value and crashes
[英]SimpleOnGestureListener.OnScroll isn't calling properly on fast scrolling
當用戶從左向右滑動時,我需要更改圖像; 這就是我使用SimpleOnGestureListener
來檢測ImageView
上的滑動事件的原因。
在這個過程中,當我慢慢地滑動圖像時, onScroll()
方法經常調用並且每個東西都工作正常但是當我快速地滑動這個圖像時, onScroll()
方法只調用了兩次三次,請讓我知道應該怎么做我用來根據swipe的速度調用onScroll()
方法。
由於有很多細節要說,我在這里發布我的答案而不是添加評論。
onFling
為您提供了四個有用的參數:兩個MotionEvent
和兩個速度數。 有了這些有用的信息,您可以撥打fling
一個Scroller
。 滾動對象將為您完成其余工作(例如,在一段時間后獲取當前x / y值)。
對於您的情況,您可以調用computeScrollOffset
和getCurrX/getCurrY
來處理“滑動動畫”。 只需在視圖的x / y到達邊界時更改顯示圖像。
例如,假設您的指針向上位置是(0,0)並且初始x速度是1000像素/秒。 在500毫秒之后,你調用computeScrollOffset
(它肯定會返回true)並且getCurrX
可能會返回600(因為getCurrX
不會線性移動)。更改圖像的確切時間取決於你。
有關Scroller
詳細用法,那里應該有很多例子。 一個很好的例子當然是正式的培訓教訓
我可以想到實現你想要的其他方法
onFling()
為您提供X
和Y
的速度:如果它大於4000,則計為快速滾動,然后您可以為連續圖像設置動畫,其效果類似於快速滑動。
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.