您好,登錄后才能下訂單哦!
這篇文章主要為大家展示了“如何解決iOS下拉刷新UIScrollVie異常閃動問題”,內容簡而易懂,條理清晰,希望能夠幫助大家解決疑惑,下面讓小編帶領大家一起研究并學習一下“如何解決iOS下拉刷新UIScrollVie異常閃動問題”這篇文章吧。
抖動的原因:
ScrollViewDidEndDragging => setContentInset:
為了保證在“Loading”的狀態下,下拉刷新控件可以展示,我們對contentInset做了修改,增加了inset的top. 那這樣一步操作為什么會導致scrollView抖動一下呢。
我在scrollViewDidScroll:中打了個斷點,來看看在setContentInset:之后發生了什么事情。 我設置的inset.top = 64; 結果發現scrollView的contentOffset發生了這樣的變化:
(0, -64) => (0, -133) => (0, -64)
由以上數據可以看出,contentOffset在這個過程中先被向下移動了一段,再回歸正常。 猜測問題原因:
下拉松開之后, scrollView本身的 bounce 效果 與 當前設置inset沖突了
初步嘗試: async
知道問題的原因后,我第一思路是避開這個沖突,于是我把 setContentInset: 的方法異步調用一下:
dispatch_async(dispatch_get_main_queue(), ^{ [UIView animateWithDuration:kAnimationDuration animations:^{ self.scrollView.contentInset = inset; } completion:^(BOOL finished) { }]; });
嘗試了一下,問題沒有了。但是后來還是有人遇到過這樣的問題, 經過驗證,確實這個問題還是沒有被完全修復。
二次修改: 強設contentOffset
既然是因為contentOffset改變導致的,我就再設置一下contentOffset應該就行了。于是二次嘗試:
dispatch_async(dispatch_get_main_queue(), ^{ [UIView animateWithDuration:kAnimationDuration animations:^{ self.scrollView.contentInset = inset; self.scrollView.contentOffset = CGPointMake(0, -inset.top); } completion:^(BOOL finished) { }]; });
試驗結果發現,沒用,問題還是存在,在這一步耗了不少時間想盡其他辦法都沒搞定問題,直到我將setContentOffset: 方法改為 setConentOffset:animated: 。 問題就解決了,可以看出系統里面這兩個方法的實現是不同的
dispatch_async(dispatch_get_main_queue(), ^{ [UIView animateWithDuration:kAnimationDuration animations:^{ self.scrollView.contentInset = inset; [self.scrollView setContentOffset:CGPointMake(0, -inset.top) animated:NO]; } completion:^(BOOL finished) { }]; });
以上是“如何解決iOS下拉刷新UIScrollVie異常閃動問題”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業資訊頻道!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。