溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

iOS中如何解決Swift UICollectionView橫向分頁的問題

發(fā)布時間:2021-07-22 11:36:12 來源:億速云 閱讀:584 作者:小新 欄目:移動開發(fā)

這篇文章主要介紹iOS中如何解決Swift UICollectionView橫向分頁的問題,文中介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們一定要看完!

直接看圖

iOS中如何解決Swift UICollectionView橫向分頁的問題

滾前

iOS中如何解決Swift UICollectionView橫向分頁的問題

滾后

已經(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個,要分兩頁需要16個,那我們可以直接添加數(shù)據(jù)到16個,然后在dataSource中返回cell時進(jìn)行判斷及處理即可。不過對于現(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橫向分頁的問題

以上是“iOS中如何解決Swift UICollectionView橫向分頁的問題”這篇文章的所有內(nèi)容,感謝各位的閱讀!希望分享的內(nèi)容對大家有幫助,更多相關(guān)知識,歡迎關(guān)注億速云行業(yè)資訊頻道!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI