您好,登錄后才能下訂單哦!
這篇文章主要介紹iOS中如何解決Swift UICollectionView橫向分頁的問題,文中介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們一定要看完!
直接看圖
滾前
滾后
已經設置collectionView的isPagingEnabled為true了,可是出現了這種情況,原因就是collectionView的contentSize不夠。
<UICollectionView: 0x7fc565076000; frame = (0 0; 375 197); clipsToBounds = YES; gestureRecognizers = <NSArray: 0x6180000557e0>; layer = <CALayer: 0x61000022a5a0>; contentOffset: {187.5, 0}; contentSize: {562.5, 192.25} >
解決方案
有兩種方式可以解決,數據只有11個,要分兩頁需要16個,那我們可以直接添加數據到16個,然后在dataSource中返回cell時進行判斷及處理即可。不過對于現在來說太小題大做了,我選第二種方式~
直接修改contentSize
我自定義了一個繼承于UICollectionViewFlowLayout的Layout(LXFChatMoreCollectionLayout),讓UICollectionView在創建的時候使用了它
在 LXFChatMoreCollectionLayout.swift 中我們需要重寫父類的collectionViewContentSize,將contentSize取出來修改為我們自己創建的newSize就可以了代碼如下
override var collectionViewContentSize: CGSize { let size: CGSize = super.collectionViewContentSize let collectionViewWidth: CGFloat = self.collectionView!.frame.size.width let nbOfScreen: Int = Int(ceil(size.width / collectionViewWidth)) let newSize: CGSize = CGSize(width: collectionViewWidth * CGFloat(nbOfScreen), height: size.height) return newSize }
注:ceil函數的作用是求不小于給定實數的最小整數。ceil(2)=ceil(1.2)=cei(1.5)=2.00
效果
以上是“iOS中如何解決Swift UICollectionView橫向分頁的問題”這篇文章的所有內容,感謝各位的閱讀!希望分享的內容對大家有幫助,更多相關知識,歡迎關注億速云行業資訊頻道!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。