下面通過(guò)圖文并茂的形式給大家介紹UICollectionView橫向分頁(yè)的問(wèn)題,具體內(nèi)容詳情如下所示:
情況
直接看圖
滾前
滾后
已經(jīng)設(shè)置collectionView的isPagingEnabled為true了,可是出現(xiàn)了這種情況,原因就是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}>
解決方案
有兩種方式可以解決,數(shù)據(jù)只有11個(gè),要分兩頁(yè)需要16個(gè),那我們可以直接添加數(shù)據(jù)到16個(gè),然后在dataSource中返回cell時(shí)進(jìn)行判斷及處理即可。不過(guò)對(duì)于現(xiàn)在來(lái)說(shuō)太小題大做了,我選第二種方式~
直接修改contentSize
我自定義了一個(gè)繼承于UICollectionViewFlowLayout的Layout(LXFChatMoreCollectionLayout),讓UICollectionView在創(chuàng)建的時(shí)候使用了它
在 LXFChatMoreCollectionLayout.swift 中我們需要重寫(xiě)父類的collectionViewContentSize,將contentSize取出來(lái)修改為我們自己創(chuàng)建的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函數(shù)的作用是求不小于給定實(shí)數(shù)的最小整數(shù)。ceil(2)=ceil(1.2)=cei(1.5)=2.00
效果
以上所述是小編給大家介紹的iOS中關(guān)于Swift UICollectionView橫向分頁(yè)的問(wèn)題,希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)武林網(wǎng)網(wǎng)站的支持!
|
新聞熱點(diǎn)
疑難解答
圖片精選