IOS应用开发14——使用UICollectionView实现图片列表显示

除了UITableView列表形式外,还常常会用到UICollectionView来显示九宫格样式的结构,也可以用以实现瀑布流。这里先简单的实现基本的UICollectionView,其他的后续记录。有时候我们会实现如下图的界面样式。


是一个典型的UICollectionView结构。那我们就来实现它吧。主要步骤如下:

1.实例化一个UICollectionView对象,设置代理方法等。

2.定制UICollectionViewCell样式。

3.从网络获取图片。

部分代码示例如下:

1.定制一个UICollectionView加入视图中

@interface PictureViewController ()<
UICollectionViewDelegate,
UICollectionViewDataSource>

// 加载collectionView
- (void)loadCollectionView;

@end

@implementation PictureViewController

- (id)initWithNibName:(NSString *)nibNameOrNil bundle:(NSBundle *)nibBundleOrNil{
    self = [super initWithNibName:nibNameOrNil bundle:nibBundleOrNil];
    if (self) {
        // 设置标题
        [self setNavigationBarTitle:@"图片"];
        self.view.backgroundColor = [UIColor whiteColor];
    }
    return self;
}

- (void)viewDidLoad{
    [super viewDidLoad];
    
    // 加载collectionView
    [self loadCollectionView];
}
#pragma  mark - 初始化、加载方法

// 加载collectionView
- (void)loadCollectionView{
    UICollectionViewFlowLayout *layout = [[UICollectionViewFlowLayout alloc] init];
    // 设置每个cell的大小
    layout.itemSize = CGSizeMake(155 , 250);

    CGFloat paddingY = 10;
    //CGFloat paddingX = 10;
    layout.sectionInset = UIEdgeInsetsMake(paddingY, 0, 0, 0);
    // 上左下右

    layout.minimumLineSpacing = paddingY;
    
    _collectionView = [[UICollectionView alloc] initWithFrame:CGRectMake(0, kMarginTop, kScreenWidth, kScreenHeight - kTabBarHeight-kMarginTop)
                                         collectionViewLayout:layout];
    _collectionView.delegate = self;
    _collectionView.dataSource = self;
    _collectionView.backgroundColor = [UIColor whiteColor];
    // 注册cell,否则会报错
    [_collectionView registerClass:[UICollectionViewCell class] forCellWithReuseIdentifier:@"pictureC
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值