爱程序网

UICollectionViewController

来源: 阅读:

为了增强网格视图开发.从iOS6开始,就开放集合视图API(collectionView).它有4个重要部分组成.

单元格:它是集合视图中的一个单元格
节:它是集合视图中的一个行数据,由多个单元格构成
补充视图:它是节的头和脚
装饰视图:集合视图中的背景视图

 

UICollectionView继承UIScrollView,与选择器类似,集合视图有两个协议;UICollectionViewDelegate委托协议和UICollectionViewDataSource数据源协议.

下面是例子

创建一个Single View Application项目

将viewController改为继承自UICollectionViewController
在main.storyboard中添加一个CollectionView.为方便查看,将背景颜色改为白色,并添加dataSource和delegate协议方法.

选中UIcollectionViewCell设置大小,并在上面添加需要的控件.至此界面设计完毕,开始代码工作.

创建类继承自UICollectionViewCell,命名为myCell,不要忘了把他同设计界面的cell关联

 

因为cell我们不需要显示太多,所以先完成cel

@property (weak, nonatomic) IBOutlet UIImageView *imageView;
@property (weak, nonatomic) IBOutlet UILabel *label;

//初始化init方法

-(id)initWithFrame:(CGRect)frame
{
    self=[super initWithFrame:frame];
    if (self) {
        
    }
    return self;
}

 

 

完成myCell类的工作后,我们继续viewContrller工作

创建数据源数组

@property(nonatomic,retain)NSMutableArray *array;

初始化数据源数组,这里使用的数据来自一个plist文件,plist文件包括名字与图片

_array=[[NSMutableArray alloc]initWithContentsOfFile:[[NSBundle mainBundle] pathForResource:@"events" ofType:@"plist"]];


接着是完成代理方法(一大波代码来袭)

#pragma mark ---UICollectionViewDataSource---
//多少个节
-(NSInteger)numberOfSectionsInCollectionView:(UICollectionView *)collectionView
{
    return _array.count/2;
}
//设置每行显示个数
-(NSInteger)collectionView:(UICollectionView *)collectionView numberOfItemsInSection:(NSInteger)section
{
    return 2;
}
//创建单元格
-(UICollectionViewCell *)collectionView:(UICollectionView *)collectionView cellForItemAtIndexPath:(NSIndexPath *)indexPath
{
   myCell *cell = [collectionView dequeueReusableCellWithReuseIdentifier:@"cell" forIndexPath:indexPath];
    NSDictionary *event=[_array objectAtIndex:(indexPath.section*2 +indexPath.row)];
    cell.label.text=[event objectForKey:@"name"];
    cell.imageView.image=[UIImage imageNamed:[event objectForKey:@"image"]];
    return cell;
}
#pragma mark---UICollectionViewDelegate---
//点击事件
-(void)collectionView:(UICollectionView *)collectionView didSelectItemAtIndexPath:(NSIndexPath *)indexPath
{
    NSDictionary *event=[self.array objectAtIndex:(indexPath.section*2+indexPath.row)];
    NSLog(@"select event name : %@", [event objectForKey:@"name"]);
}

就喜欢这种复制粘贴的感觉

运行后效果如图:

 
 

关于爱程序网 - 联系我们 - 广告服务 - 友情链接 - 网站地图 - 版权声明 - 人才招聘 - 帮助