十年专注于网站建设与互联网应用开发,低调、有情怀的网络应用服务商!
南昌百恒科技微信公众号 扫一扫关注
tel-icon全国服务热线:400-680-9298,0791-88117053
扫一扫关注百恒科技微信公众号

IOS开发之集合视图中的可重用对象

百恒科技 2019-01-21 16:52:16 350
前面我们讲到了表视图的可重用对象,没多大印象的朋友可查看该文《IOS开发之表视图的可重用对象》再温习一遍。今天,南昌APP开发公司主要为大家介绍一下IOS开发中集合视图中的可重用对象。

集合视图在iOS 6之后才可以使用,它也有两种子视图采用可重用对象设计,它们是单元格视图和补充视图,这两个视图都继承自UICollectionReusableView,使用时需要自己编写相关代码。

1、单元格视图
在集合视图中,我们可以使用UICollectionView的dequeueReusableCellWithReuseIdentifier:forIndexPath:方法获得可重用的单元格,模式代码如下:

override func collectionView(collectionView: UICollectionView,
cellForItemAtIndexPathindexPath: NSIndexPath) ->
UICollectionViewCell {
var cell = collectionView.dequeueReusableCellWithReuseIdentifier("Cell",
forIndexPath: indexPath) as Cell
......
return cell
}

- (UICollectionViewCell *)collectionView:(UICollectionView *)
collectionView cellForItemAtIndexPath:(NSIndexPath *)indexPath
{
Cell *cell = [collectionView dequeueReusableCellWithReuseIdentifier:
@"CellIdentifier" forIndexPath:indexPath];
......
return cell;
}

在上述代码中,collectionView:cellForItemAtIndexPath:方法是集合视图的数据源方法,其中Cell是我们自定义的继承自UICollectionReusableView的单元格类。使用dequeueReusableCellWithReuseIdentifier:时,需要使用故事板设计UI,并且需要将单元格的Identifier属性设置为Cell(如图1所示)。

设定集合视图单元格的属性
图1、设定集合视图单元格的属性

2、补充视图
集合视图单元格可以使用UICollectionView的dequeueReusableSupplementaryViewOfKind:withReuseIdentifier:forIndexPath:方法获得可重用的补充视图,模式代码如下:

override func collectionView(collectionView: UICollectionView,
viewForSupplementaryElementOfKind kind: String,
atIndexPath indexPath: NSIndexPath) -> UICollectionReusableView {

var headerView: UICollectionReusableView = collectionView.
dequeueReusableSupplementaryViewOfKind
(UICollectionElementKindSectionHeader,
withReuseIdentifier : "HeaderIdentifier", forIndexPath:indexPath)
as UICollectionReusableView

......
return headerView
}

- (UICollectionReusableView *)collectionView:(UICollectionView
*)collectionView
viewForSupplementaryElementOfKind:(NSString *)kind
atIndexPath: (NSIndexPath *)indexPath
{
HeaderView *headerView = [collectionView
dequeueReusableSupplementaryViewOfKind:
UICollectionElementKindSectionHeader
withReuseIdentifier:@"HeaderIdentifier" forIndexPath:indexPath];
headerView.headerLabel.text = [self.eventDate objectAtIndex:indexPath.section];
return headerView;
}

collectionView:viewForSupplementaryElementOfKind:atIndexPath:方法是集合视图的数据源方法,其中HeaderView是我们自定义的继承自UICollectionReusableView的补充视图类。使用dequeueReusableSupplementaryViewOfKind:withReuseIdentifier:forIndexPath:时,需要使用故事板设计UI,并将补充视图的Identifier属性设置为HeaderIdentifier,如图2所示。

设定补充视图的属性
图2、设定补充视图的属性

400-680-9298,0791-88117053
扫一扫关注百恒网络微信公众号

欢迎您的光顾,我们将竭诚为您服务×

 
 
 
 
 
 
 
 
×
友情链接:    内吧彩票   彩票平台   58彩票   福彩软件   5亿彩票手机app下载