collectionView卡片流水布局

卡片式流水布局可以

##自定義布局-繼承UICollectionViewFlowLayout

###重寫prepareLayout方法

-作用:在這個方法中做一些初始化操作

-注意:一定要調(diào)用[super prepareLayout]

###重寫layoutAttributesForElementsInRect:方法

-作用:

-這個方法的返回值是個數(shù)組

-這個數(shù)組中存放的都是UICollectionViewLayoutAttributes對象

- UICollectionViewLayoutAttributes對象決定了cell的排布方式(frame等)

###重寫shouldInvalidateLayoutForBoundsChange:方法

-作用:如果返回YES,那么collectionView顯示的范圍發(fā)生改變時,就會重新刷新布局

-一旦重新刷新布局稠氮,就會按順序調(diào)用下面的方法:

- prepareLayout

- layoutAttributesForElementsInRect:

###重寫targetContentOffsetForProposedContentOffset:withScrollingVelocity:方法

-作用:返回值決定了collectionView停止?jié)L動時最終的偏移量(contentOffset)

-參數(shù):

- proposedContentOffset:原本情況下母蛛,collectionView停止?jié)L動時最終的偏移量

- velocity:滾動速率萧落,通過這個參數(shù)可以了解滾動的方向



.h

#import

@interfaceXMGLineLayout :UICollectionViewFlowLayout

@end



.m

- (instancetype)init

{

if(self= [superinit]) {

}

returnself;

}

/**

*當(dāng)collectionView的顯示范圍發(fā)生改變的時候春寿,是否需要重新刷新布局

*一旦重新刷新布局步脓,就會重新調(diào)用下面的方法:

1.prepareLayout

2.layoutAttributesForElementsInRect:方法

*/

- (BOOL)shouldInvalidateLayoutForBoundsChange:(CGRect)newBounds

{

returnYES;

}

/**

*用來做布局的初始化操作(不建議在init方法中進行布局的初始化操作)

*/

- (void)prepareLayout

{

[superprepareLayout];

//水平滾動

self.scrollDirection=UICollectionViewScrollDirectionHorizontal;

//設(shè)置內(nèi)邊距

CGFloatinset = (self.collectionView.frame.size.width-self.itemSize.width) *0.5;

self.sectionInset=UIEdgeInsetsMake(0, inset,0, inset);

}

/**

UICollectionViewLayoutAttributes *attrs;

1.一個cell對應(yīng)一個UICollectionViewLayoutAttributes對象

2.UICollectionViewLayoutAttributes對象決定了cell的frame

*/

/**

*這個方法的返回值是一個數(shù)組(數(shù)組里面存放著rect范圍內(nèi)所有元素的布局屬性)

*這個方法的返回值決定了rect范圍內(nèi)所有元素的排布(frame)

*/

- (NSArray*)layoutAttributesForElementsInRect:(CGRect)rect

{

//獲得super已經(jīng)計算好的布局屬性

NSArray*array = [superlayoutAttributesForElementsInRect:rect];

//計算collectionView最中心點的x值

CGFloatcenterX =self.collectionView.contentOffset.x+self.collectionView.frame.size.width*0.5;

//在原有布局屬性的基礎(chǔ)上堡僻,進行微調(diào)

for(UICollectionViewLayoutAttributes*attrsinarray) {

// cell的中心點x和collectionView最中心點的x值的間距

CGFloatdelta =ABS(attrs.center.x- centerX);

//根據(jù)間距值計算cell的縮放比例

CGFloatscale =1- delta /self.collectionView.frame.size.width;

//設(shè)置縮放比例

attrs.transform=CGAffineTransformMakeScale(scale, scale);

}

returnarray;

}

/**

*這個方法的返回值,就決定了collectionView停止?jié)L動時的偏移量

*/

- (CGPoint)targetContentOffsetForProposedContentOffset:(CGPoint)proposedContentOffset withScrollingVelocity:(CGPoint)velocity

{

//計算出最終顯示的矩形框

CGRectrect;

rect.origin.y=0;

rect.origin.x= proposedContentOffset.x;

rect.size=self.collectionView.frame.size;

//獲得super已經(jīng)計算好的布局屬性

NSArray*array = [superlayoutAttributesForElementsInRect:rect];

//計算collectionView最中心點的x值

CGFloatcenterX = proposedContentOffset.x+self.collectionView.frame.size.width*0.5;

//存放最小的間距值

CGFloatminDelta =MAXFLOAT;

for(UICollectionViewLayoutAttributes*attrsinarray) {

if(ABS(minDelta) >ABS(attrs.center.x- centerX)) {

minDelta = attrs.center.x- centerX;

}

}

//修改原有的偏移量

proposedContentOffset.x+= minDelta;

returnproposedContentOffset;

}

-文章轉(zhuǎn)自小碼哥

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末实撒,一起剝皮案震驚了整個濱河市姊途,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌知态,老刑警劉巖捷兰,帶你破解...
    沈念sama閱讀 217,277評論 6 503
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異负敏,居然都是意外死亡贡茅,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,689評論 3 393
  • 文/潘曉璐 我一進店門原在,熙熙樓的掌柜王于貴愁眉苦臉地迎上來友扰,“玉大人,你說我怎么就攤上這事庶柿〈骞郑” “怎么了?”我有些...
    開封第一講書人閱讀 163,624評論 0 353
  • 文/不壞的土叔 我叫張陵浮庐,是天一觀的道長甚负。 經(jīng)常有香客問我,道長审残,這世上最難降的妖魔是什么梭域? 我笑而不...
    開封第一講書人閱讀 58,356評論 1 293
  • 正文 為了忘掉前任,我火速辦了婚禮搅轿,結(jié)果婚禮上病涨,老公的妹妹穿的比我還像新娘。我一直安慰自己璧坟,他們只是感情好既穆,可當(dāng)我...
    茶點故事閱讀 67,402評論 6 392
  • 文/花漫 我一把揭開白布赎懦。 她就那樣靜靜地躺著,像睡著了一般幻工。 火紅的嫁衣襯著肌膚如雪励两。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,292評論 1 301
  • 那天囊颅,我揣著相機與錄音当悔,去河邊找鬼。 笑死踢代,一個胖子當(dāng)著我的面吹牛盲憎,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播奸鬓,決...
    沈念sama閱讀 40,135評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼焙畔,長吁一口氣:“原來是場噩夢啊……” “哼掸读!你這毒婦竟也來了串远?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 38,992評論 0 275
  • 序言:老撾萬榮一對情侶失蹤儿惫,失蹤者是張志新(化名)和其女友劉穎澡罚,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體肾请,經(jīng)...
    沈念sama閱讀 45,429評論 1 314
  • 正文 獨居荒郊野嶺守林人離奇死亡留搔,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,636評論 3 334
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了铛铁。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片隔显。...
    茶點故事閱讀 39,785評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖饵逐,靈堂內(nèi)的尸體忽然破棺而出括眠,到底是詐尸還是另有隱情,我是刑警寧澤倍权,帶...
    沈念sama閱讀 35,492評論 5 345
  • 正文 年R本政府宣布掷豺,位于F島的核電站,受9級特大地震影響薄声,放射性物質(zhì)發(fā)生泄漏当船。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 41,092評論 3 328
  • 文/蒙蒙 一默辨、第九天 我趴在偏房一處隱蔽的房頂上張望德频。 院中可真熱鬧,春花似錦缩幸、人聲如沸壹置。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,723評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽蒸绩。三九已至衙四,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間患亿,已是汗流浹背传蹈。 一陣腳步聲響...
    開封第一講書人閱讀 32,858評論 1 269
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留步藕,地道東北人惦界。 一個月前我還...
    沈念sama閱讀 47,891評論 2 370
  • 正文 我出身青樓,卻偏偏與公主長得像咙冗,于是被迫代替她去往敵國和親沾歪。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 44,713評論 2 354

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