zoukankan      html  css  js  c++  java
  • collectionView布局

    关于 collectionView的layout布局方法:

    设置cell的间距,行间距,组与组之间的间距,都是在layout里面来设置.

    包括,滚动方向.

    -(void)prepareLayout

        [super prepareLayout]

        //最小行间距

        self.minimumLineSpacing =1;

        //最小cell间距

        self.minimumInteritemSpacing =1;

        //组与组之间的间距

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

    }

    设置cell的大小有两种方法

    一种在layout布局里面来通过方法,设置cell的大小

    方法名称比较长,只要记住layout的关键字返回值是一个数组

    -(NSArray<UICollectionViewLayoutAttributes *> *)layoutAttributesForElementsInRect:(CGRect)rect{

        

       NSArray *attrs =[super layoutAttributesForElementsInRect:rect];

        

        for (UICollectionViewLayoutAttributes *attr in attrs) {

            

            //如果是第一组,进行操作..

            //获取frame

            CGRect frame = attr.frame;

            CGFloat height =100;

            CGFloat width =(self.collectionView.frame.size.width -3)/4;

            

            if (attr.indexPath.section ==1) {

               

                //frame = CGRectMake(0, 0, self.collectionView.frame.size.width, 100);//不要修改他的位置,只需要修改他的大小

                //修改frame

                frame.size =CGSizeMake(self.collectionView.frame.size.width, height);

                

            }else{

                

                frame.size =CGSizeMake(width, height);

           }

            //赋值回去

            attr.frame =frame;

        }

        

        return attrs;

    }

     第二种方法:

    遵守协议

    //实现代理方法

    -(CGSize)collectionView:(UICollectionView *)collectionView layout:(UICollectionViewLayout *)collectionViewLayout sizeForItemAtIndexPath:(NSIndexPath *)indexPath{

        CGFloat height = 100;

        CGFloat width =(collectionView.frame.size.width-3)/4;

        if (indexPath.section ==1) {

            

            return CGSizeMake(collectionView.frame.size.width, 120);

            

        }

        

        return CGSizeMake(width, height);

    }

    -(void)prepareLayout{

        

        [super prepareLayout];

        

        //最小行间距

        self.minimumLineSpacing =1;

        //最小cell间距

        self.minimumInteritemSpacing =1;

        

        //组与组之间的间距

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

        

        

        CGFloat height =100;

        CGFloat width =(self.collectionView.frame.size.width -3)/4;

        self.itemSize =CGSizeMake(width, height);

        

    }

     ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~

    //上面的布局问题:需要初始时候先指定一个大小. 当初始位置有了大小,让布局,按照这个大小来进行布局

    //没有给大小,他会按照默认的大小,50,50来计算,所以会导致cell直接压在一起.

    -(NSArray<UICollectionViewLayoutAttributes *> *)layoutAttributesForElementsInRect:(CGRect)rect{

        

        NSArray *attrs =[super layoutAttributesForElementsInRect:rect];

        

        for (UICollectionViewLayoutAttributes *attr in attrs) {

            

            //如果是第一组,进行操作..

            //获取frame

            CGRect frame = attr.frame;

            if (attr.indexPath.section ==1) {

                

                frame.size =CGSizeMake(self.collectionView.frame.size.width, 100);

                

            }

            //赋值回去

            attr.frame =frame;

        }

        

        return attrs;

    }

    @end

  • 相关阅读:
    你试过不用if撸代码吗?
    Chrome开发者工具Debug入门
    我为什么推荐Prettier来统一代码风格
    使用JSDoc自动生成代码文档
    Async/Await是这样简化JavaScript代码的
    C#泛型约束 (转载)
    DateTime , DateTime2 ,DateTimeOffset 之间的小区别 (转载)
    允许跨域资源共享(CORS)携带 Cookie (转载)
    C#中如何利用操作符重载和转换操作符 (转载)
    EF Core 2.1 Raw SQL Queries (转自MSDN)
  • 原文地址:https://www.cnblogs.com/xu-antong/p/6351510.html
Copyright © 2011-2022 走看看