應(yīng)對復(fù)雜布局的瀑布流Layout

公司的項目中涉及到多列瀑布流趣斤、UITableView與sectionHeader的混合布局,之前的實現(xiàn)方式是以UITableView作為骨架执俩,將帶有瀑布流的UICollectionView封裝到自定義的UITableViewCell中蚂维,但是出現(xiàn)的問題就是當cell中瀑布流的元素過多時,會出現(xiàn)明顯的卡頓毙籽,而且布局復(fù)雜洞斯,層次較多,難以維護坑赡。故而重新自定義了collectionView的Layout烙如,在僅有一個collectionView的情況下完成了上述的布局。

這是我們項目.gif

更新:

2016-12-23
1毅否、加入了collectionHeaderView亚铁,類似UITableView 中的 tableHeaderView
2、將 sideMargin 改為 sectionInsets螟加,提高布局靈活度

項目基于Swift3.0~~

使用

閑話不多說徘溢,上代碼:
1、首先定義一個collectionview捆探,并設(shè)置layout的代理:

let layout = ZJFlexibleLayout(delegate: self)
//如果需要有 headerView 的話然爆,直接傳入即可,需提前設(shè)置frame
layout.collectionHeaderView = headerView
collectionView = UICollectionView(frame: kScreenBounds, collectionViewLayout: layout)

2黍图、遵守對應(yīng)的協(xié)議:

protocol ZJFlexibleLayoutDataSource: class{

//控制對應(yīng)section的瀑布流列數(shù)
    func numberOfCols(at section: Int) -> Int
    //控制每個cell的尺寸曾雕,實際上就是獲取寬高比
    func sizeOfItemAtIndexPath(at indexPath : IndexPath) -> CGSize
    //控制瀑布流cell的間距
    func spaceOfCells(at section: Int) -> CGFloat
    //section 內(nèi)邊距
    func sectionInsets(at section: Int) -> UIEdgeInsets
    //每個section的header尺寸
    func sizeOfHeader(at section: Int) -> CGSize
    //每個cell的額外高度
    func heightOfAdditionalContent(at indexPath : IndexPath) -> CGFloat
}

協(xié)議詳解:

1.瀑布流列數(shù)

可以隨意設(shè)置瀑布流列數(shù),如果是單列的話就相當于tableView了

     func numberOfCols(at section: Int) -> Int

2.cell尺寸

這個應(yīng)該不用多講吧雌隅,因為cell的寬度在列數(shù)確定時就已經(jīng)算出來了翻默,所以這個方法實質(zhì)上是獲取cell的寬高比

    func sizeOfItemAtIndexPath(at indexPath : IndexPath) -> CGSize
Paste_Image.png

3.cell間距

cell 的上下左右間距缸沃,注意不要跟sectionInsets搞混了

    func spaceOfCells(at section: Int) -> CGFloat
Paste_Image.png

4.section 內(nèi)邊距

這個是最近才加上的,可以讓每個section都有一個內(nèi)邊距

    func sectionInsets(at section: Int) -> UIEdgeInsets
Paste_Image.png

5.每個section的header尺寸

sectionHeader如果寬度小于屏寬修械,會自動居中

    func sizeOfHeader(at section: Int) -> CGSize

6.cell的額外高度

此方法是專門公司項目的需求提出的趾牧,圖中標明的部分高度是不固定的,需要根據(jù)數(shù)據(jù)進行判斷

    func heightOfAdditionalContent(at indexPath : IndexPath) -> CGFloat
Paste_Image.png

結(jié)束語

代碼寫的沒什么條理肯污,所有東西都寫到一個文件里了(⊙﹏⊙)b翘单,后續(xù)應(yīng)該會用pod來管理
Demo已經(jīng)放到GitHub上了,歡迎大家Star蹦渣,也請大家不要吝嗇好的建議哈~~

這是demo.gif
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末哄芜,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子柬唯,更是在濱河造成了極大的恐慌认臊,老刑警劉巖,帶你破解...
    沈念sama閱讀 211,123評論 6 490
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件锄奢,死亡現(xiàn)場離奇詭異失晴,居然都是意外死亡,警方通過查閱死者的電腦和手機拘央,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,031評論 2 384
  • 文/潘曉璐 我一進店門描沟,熙熙樓的掌柜王于貴愁眉苦臉地迎上來林艘,“玉大人友浸,你說我怎么就攤上這事梢杭。” “怎么了栏账?”我有些...
    開封第一講書人閱讀 156,723評論 0 345
  • 文/不壞的土叔 我叫張陵帖族,是天一觀的道長。 經(jīng)常有香客問我挡爵,道長盟萨,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 56,357評論 1 283
  • 正文 為了忘掉前任了讨,我火速辦了婚禮,結(jié)果婚禮上制轰,老公的妹妹穿的比我還像新娘前计。我一直安慰自己,他們只是感情好垃杖,可當我...
    茶點故事閱讀 65,412評論 5 384
  • 文/花漫 我一把揭開白布男杈。 她就那樣靜靜地躺著,像睡著了一般调俘。 火紅的嫁衣襯著肌膚如雪伶棒。 梳的紋絲不亂的頭發(fā)上旺垒,一...
    開封第一講書人閱讀 49,760評論 1 289
  • 那天,我揣著相機與錄音肤无,去河邊找鬼先蒋。 笑死,一個胖子當著我的面吹牛宛渐,可吹牛的內(nèi)容都是我干的竞漾。 我是一名探鬼主播,決...
    沈念sama閱讀 38,904評論 3 405
  • 文/蒼蘭香墨 我猛地睜開眼窥翩,長吁一口氣:“原來是場噩夢啊……” “哼业岁!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起寇蚊,我...
    開封第一講書人閱讀 37,672評論 0 266
  • 序言:老撾萬榮一對情侶失蹤笔时,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后仗岸,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體允耿,經(jīng)...
    沈念sama閱讀 44,118評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,456評論 2 325
  • 正文 我和宋清朗相戀三年爹梁,在試婚紗的時候發(fā)現(xiàn)自己被綠了右犹。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 38,599評論 1 340
  • 序言:一個原本活蹦亂跳的男人離奇死亡姚垃,死狀恐怖念链,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情积糯,我是刑警寧澤掂墓,帶...
    沈念sama閱讀 34,264評論 4 328
  • 正文 年R本政府宣布,位于F島的核電站看成,受9級特大地震影響君编,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜川慌,卻給世界環(huán)境...
    茶點故事閱讀 39,857評論 3 312
  • 文/蒙蒙 一吃嘿、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧梦重,春花似錦兑燥、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,731評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至蚓胸,卻和暖如春挣饥,著一層夾襖步出監(jiān)牢的瞬間除师,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 31,956評論 1 264
  • 我被黑心中介騙來泰國打工扔枫, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留汛聚,地道東北人。 一個月前我還...
    沈念sama閱讀 46,286評論 2 360
  • 正文 我出身青樓茧吊,卻偏偏與公主長得像贞岭,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子搓侄,可洞房花燭夜當晚...
    茶點故事閱讀 43,465評論 2 348

推薦閱讀更多精彩內(nèi)容