iOS中關于Swift UICollectionView橫向分頁的問題
下面通過圖文并茂的形式給大家介紹UICollectionView橫向分頁的問題,具體內(nèi)容詳情如下所示:
情況
直接看圖

滾前

滾后
已經(jīng)設置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個,要分兩頁需要16個,那我們可以直接添加數(shù)據(jù)到16個,然后在dataSource中返回cell時進行判斷及處理即可。不過對于現(xiàn)在來說太小題大做了,我選第二種方式~
直接修改contentSize
我自定義了一個繼承于UICollectionViewFlowLayout的Layout(LXFChatMoreCollectionLayout),讓UICollectionView在創(chuàng)建的時候使用了它
在 LXFChatMoreCollectionLayout.swift 中我們需要重寫父類的collectionViewContentSize,將contentSize取出來修改為我們自己創(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ù)。ceil(2)=ceil(1.2)=cei(1.5)=2.00
效果

以上所述是小編給大家介紹的iOS中關于Swift UICollectionView橫向分頁的問題,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
相關文章
IOS 屏幕適配方案實現(xiàn)縮放window的示例代碼
這篇文章主要介紹了IOS 屏幕適配方案實現(xiàn)縮放window的示例代碼,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2020-04-04
iOS自定義collectionView實現(xiàn)毛玻璃效果
不知道大家發(fā)現(xiàn)沒有蘋果在iOS7.0之后,很多系統(tǒng)界面都使用了毛玻璃效果,增加了界面的美觀性,所以這篇文章跟大家分享個iOS自定義collectionView實現(xiàn)毛玻璃效果的方法,有需要的可以參考借鑒,下面來一起看看。2016-09-09
在IOS中為什么使用多線程及多線程實現(xiàn)的三種方法
這篇文章給大家介紹在IOS中為什么使用多線程及多線程實現(xiàn)的三種方法,基本上使用這三種方法實現(xiàn)多線程(NSThread Grand Centeral Dispatch(GCD) NSOperation和NSOperationQueue),感興趣的朋友可以參考下本篇文章2015-11-11

