ios實現瀑布流

來源:互聯網
上載者:User

標籤:nbsp   ++   content   string   section   ons   ems   register   ext   

好多人都會遇到瀑布流的問題,有些瀑布流的高度是不一樣的,有些是每個cell的高度是一樣的,我這裡的寫的只要改動一個地方就可以了

首先自訂繼承

UICollectionViewLayout的類然後再.m檔案中布局屬性

 

/** 預設的列數 */

static const NSInteger XMGDefaultColumnCount = 2;

/** 每一列之間的間距 */

static const CGFloat XMGDefaultColumnMargin = 10;

/** 每一行之間的間距 */

static const CGFloat XMGDefaultRowMargin = 10;

/** 邊緣間距 */

static const UIEdgeInsets XMGDefaultEdgeInsets = {0, 0, 0, 0};

在類別中定義這幾個全域變數

/** 存放所有cell的布局屬性 */

@property (nonatomic, strong) NSMutableArray *attrsArray;

/** 存放所有列的當前高度 */

@property (nonatomic, strong) NSMutableArray *columnHeights;

接下來就是實現了

- (NSMutableArray *)columnHeights

{

    if (!_columnHeights) {

        _columnHeights = [NSMutableArray array];

    }

    return _columnHeights;

}

 

- (NSMutableArray *)attrsArray

{

    if (!_attrsArray) {

        _attrsArray = [NSMutableArray array];

    }

    return _attrsArray;

}

 

/**

 * 初始化

 */

- (void)prepareLayout

{

    [super prepareLayout];

    

    // 清除以前計算的所有高度

    [self.columnHeights removeAllObjects];

    for (NSInteger i = 0; i < XMGDefaultColumnCount; i++) {

        [self.columnHeights addObject:@(XMGDefaultEdgeInsets.top)];

    }

 

    // 清除之前所有的布局屬性

    [self.attrsArray removeAllObjects];

    // 開始建立每一個cell對應的布局屬性

    NSInteger count = [self.collectionView numberOfItemsInSection:0];

    for (NSInteger i = 0; i < count; i++) {

        // 建立位置

        NSIndexPath *indexPath = [NSIndexPath indexPathForItem:i inSection:0];

        // 擷取indexPath位置cell對應的布局屬性

        UICollectionViewLayoutAttributes *attrs = [self layoutAttributesForItemAtIndexPath:indexPath];

        [self.attrsArray addObject:attrs];

    }

}

 

/**

 * 決定cell的排布

 */

- (NSArray *)layoutAttributesForElementsInRect:(CGRect)rect

{

    return self.attrsArray;

}

 

/**

 * 返回indexPath位置cell對應的布局屬性

 */

- (UICollectionViewLayoutAttributes *)layoutAttributesForItemAtIndexPath:(NSIndexPath *)indexPath

{

    // 建立布局屬性

    UICollectionViewLayoutAttributes *attrs = [UICollectionViewLayoutAttributes layoutAttributesForCellWithIndexPath:indexPath];

    

    // collectionView的寬度

    CGFloat collectionViewW = self.collectionView.frame.size.width;

    

    // 設定布局屬性的frame

    CGFloat w = (collectionViewW - XMGDefaultEdgeInsets.left - XMGDefaultEdgeInsets.right - (XMGDefaultColumnCount - 1) * XMGDefaultColumnMargin) / XMGDefaultColumnCount;

    CGFloat h = 50 + arc4random_uniform(100);

//     CGFloat h = 40 ;//固定高度為40

    

    

    // 找出高度最短的那一列

    NSInteger destColumn = 0;

    CGFloat minColumnHeight = [self.columnHeights[0] doubleValue];

    for (NSInteger i = 1; i < XMGDefaultColumnCount; i++) {

        // 取得第i列的高度

        CGFloat columnHeight = [self.columnHeights[i] doubleValue];

        

        if (minColumnHeight > columnHeight) {

            minColumnHeight = columnHeight;

            destColumn = i;

        }

    }

    

    CGFloat x = XMGDefaultEdgeInsets.left + destColumn * (w + XMGDefaultColumnMargin);

    CGFloat y = minColumnHeight;

    if (y != XMGDefaultEdgeInsets.top) {

        y += XMGDefaultRowMargin;

    }

    attrs.frame = CGRectMake(x, y, w, h);

    

    // 更新最短那列的高度

    self.columnHeights[destColumn] = @(CGRectGetMaxY(attrs.frame));

    

    return attrs;

}

 

- (CGSize)collectionViewContentSize

{

    CGFloat maxColumnHeight = [self.columnHeights[0] doubleValue];

    for (NSInteger i = 1; i < XMGDefaultColumnCount; i++) {

        // 取得第i列的高度

        CGFloat columnHeight = [self.columnHeights[i] doubleValue];

        

        if (maxColumnHeight < columnHeight) {

            maxColumnHeight = columnHeight;

        }

    }

    return CGSizeMake(0, maxColumnHeight + XMGDefaultEdgeInsets.bottom);

}

 好的,下面我們就要在VC中實現

static NSString * const XMGShopId = @"lxtShop";

 

- (void)viewDidLoad {

    [super viewDidLoad];

    

    // 建立布局

    XMGWaterflowLayout *layout = [[XMGWaterflowLayout alloc] init];

    

    // 建立CollectionView

    UICollectionView *collectionView = [[UICollectionView alloc] initWithFrame:self.view.bounds collectionViewLayout:layout];

    collectionView.dataSource = self;

    [self.view addSubview:collectionView];

    

    // 註冊

    [collectionView registerClass:[UICollectionViewCell class] forCellWithReuseIdentifier:XMGShopId];

}

#pragma mark - <UICollectionViewDataSource>

- (NSInteger)collectionView:(UICollectionView *)collectionView numberOfItemsInSection:(NSInteger)section

{

    return 50;

}

 

- (UICollectionViewCell *)collectionView:(UICollectionView *)collectionView cellForItemAtIndexPath:(NSIndexPath *)indexPath

{

    UICollectionViewCell *cell = [collectionView dequeueReusableCellWithReuseIdentifier:XMGShopId forIndexPath:indexPath];

    

    cell.backgroundColor = [UIColor orangeColor];

 

    NSInteger tag = 10;

    UILabel *label = (UILabel *)[cell.contentView viewWithTag:tag];

    if (label == nil) {

        label = [[UILabel alloc] init];

        label.tag = tag;

        [cell.contentView addSubview:label];

    }

 

    label.text = [NSString stringWithFormat:@"%zd", indexPath.item];

    [label sizeToFit];

    

    return cell;

}

 好了,這樣就可以實現了。

 

ios實現瀑布流

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.