2023-03-15(UIColloctionView cell居中布局和左對齊實現(xiàn))

居中對齊

圖片.png
@implementation WYTCollectionViewCenterFlowLayout
- (NSArray<__kindof UICollectionViewLayoutAttributes *> *)layoutAttributesForElementsInRect:(CGRect)rect {
    NSArray *attrsArry = [super layoutAttributesForElementsInRect:rect];
    // 最后一行有幾個
    NSInteger last = attrsArry.count % kLineNum;
    if (last == 0) {
        return attrsArry;
    }
    CGFloat itemW = self.itemSize.width;
    CGFloat spacing = self.minimumInteritemSpacing;
    CGFloat totalW = spacing*(last-1) + itemW*last;
    CGFloat startX = (kCollectionViewW - totalW) * 0.5;
    // 最后一行起始位置
    NSInteger startIndex = attrsArry.count - last;
    for (NSInteger i=startIndex; i<attrsArry.count; i++) {
        CGFloat x = startX + (attrsArry.count-i-1) * (itemW+spacing);
        UICollectionViewLayoutAttributes *curAttr = attrsArry[i];
        CGRect frame = curAttr.frame;
        frame.origin.x = x;
        curAttr.frame = frame;
    }
    return attrsArry;
}
@end

左對齊

圖片.png
@implementation WYTCollectionViewLeftFlowLayout
-(NSArray<__kindof UICollectionViewLayoutAttributes *> *)layoutAttributesForElementsInRect:(CGRect)rect {
    NSArray *attrsArry = [super layoutAttributesForElementsInRect:rect];
    for (int i=0; i<attrsArry.count; i++) {
        if (i+1 < attrsArry.count) {
            UICollectionViewLayoutAttributes *curAttr = attrsArry[i];
            UICollectionViewLayoutAttributes *nextAttr = attrsArry[i+1];
            //如果下一個在同一行則調(diào)整,不在同一行則跳過
            if (CGRectGetMinY(curAttr.frame) == CGRectGetMinY(nextAttr.frame)) {
                if (CGRectGetMinX(nextAttr.frame) - CGRectGetMaxX(curAttr.frame) > self.minimumInteritemSpacing){
                    CGRect frame = nextAttr.frame;
                    frame.origin.x = CGRectGetMaxX(curAttr.frame) + self.minimumInteritemSpacing;
                    nextAttr.frame = frame;
                }
            }
        }
    }
    return attrsArry;
}
@end

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容