iOS UIScrollView和控制器返回手勢(shì)沖突解決方法
開發(fā)中,有部分UI,會(huì)將UIScrollView橫向鋪在底層,上面放tableView 或一些視圖左右滾動(dòng)切換,底層的scrollView會(huì)和Nav ViewController原有的返回手勢(shì)沖突
解決辦法,重寫UIScrollView 的gestureRecognizerShouldBegin,在ScrollView滾動(dòng)到頭的時(shí)候,屏蔽ScrollView的手勢(shì)
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 代表左滑即手指從屏幕右向左移動(dòng) 反之一樣 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和控制器返回手勢(shì)沖突解決方法的文章就介紹到這了,更多相關(guān)iOS UIScrollView和控制器手勢(shì)沖突內(nèi)容請(qǐng)搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!
相關(guān)文章:
1. 不同瀏覽器對(duì)XML的解析是不同的2. XML入門的常見問(wèn)題(一)3. ASP中if語(yǔ)句、select 、while循環(huán)的使用方法4. 告別AJAX實(shí)現(xiàn)無(wú)刷新提交表單5. 讀寫xml文件的2個(gè)小函數(shù)6. asp讀取xml文件和記數(shù)7. IE6/IE7/IE8/IE9中tbody的innerHTML不能賦值的完美解決方案8. asp使用Weekday函數(shù)計(jì)算項(xiàng)目的結(jié)束時(shí)間9. ASP 信息提示函數(shù)并作返回或者轉(zhuǎn)向10. 低版本IE正常運(yùn)行HTML5+CSS3網(wǎng)站的3種解決方案
