iOS UIScrollView和控制器返回手勢沖突解決方法
開發(fā)中,有部分UI,會將UIScrollView橫向鋪在底層,上面放tableView 或一些視圖左右滾動切換,底層的scrollView會和Nav ViewController原有的返回手勢沖突
解決辦法,重寫UIScrollView 的gestureRecognizerShouldBegin,在ScrollView滾動到頭的時候,屏蔽ScrollView的手勢
class GesturesConflictScrollView: UIScrollView { override func gestureRecognizerShouldBegin(_ gestureRecognizer: UIGestureRecognizer) -> Bool { back(by: gestureRecognizer) } private final func back(by gestureRecognizer: UIGestureRecognizer) -> Bool {guard gestureRecognizer == panGestureRecognizer else { return true } // point.x < 0 代表左滑即手指從屏幕右向左移動 反之一樣 let point: CGPoint = panGestureRecognizer.translation(in: self) let state: UIGestureRecognizer.State = gestureRecognizer.state let locDistance: CGFloat = UIScreen.main.bounds.size.widthif state == .began || state == .possible { let locationPoint = gestureRecognizer.location(in: self) if point.x > 0 && locationPoint.x < locDistance && contentOffset.x <= 0 {return false } let pageCount = contentSize.width / UIScreen.main.bounds.size.width let criticalPoint = pageCount < 2 ? locDistance : locDistance * (pageCount - 1) if point.x < 0 && contentOffset.x == criticalPoint {return false } } return true }}
到此這篇關(guān)于iOS UIScrollView和控制器返回手勢沖突解決方法的文章就介紹到這了,更多相關(guān)iOS UIScrollView和控制器手勢沖突內(nèi)容請搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!
相關(guān)文章:
1. python中scrapy處理項目數(shù)據(jù)的實例分析2. 教你在 IntelliJ IDEA 中使用 VIM插件的詳細(xì)教程3. IntelliJ IDEA導(dǎo)入jar包的方法4. js抽獎轉(zhuǎn)盤實現(xiàn)方法分析5. Python requests庫參數(shù)提交的注意事項總結(jié)6. vue-electron中修改表格內(nèi)容并修改樣式7. iOS實現(xiàn)點贊動畫特效8. 通過Python pyecharts輸出保存圖片代碼實例9. SpringBoot參數(shù)校驗與國際化使用教程10. PHP橋接模式Bridge Pattern的優(yōu)點與實現(xiàn)過程
