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