您的位置:首页 > 其它

自定义不等高的cell

2015-08-11 16:40 316 查看

自定义不等高的cell

标签(空格分隔): UI

—每一个cell的高度并非都一样

纯代码方式

frame

给模型增加frame数据

所有子控件的frame

cell的高度

@interface XMGStatus : NSObject
/**** 文字\图片数据 ****/
// .....

/**** frame数据 ****/
/** 头像的frame */
@property (nonatomic, assign) CGRect iconFrame;
// .....
/** cell的高度 */
@property (nonatomic, assign) CGFloat cellHeight;
@end


在模型的.m文件中重写模型cellHeight属性的get方法

- (CGFloat)cellHeight
{
if (_cellHeight == 0) {
// ... 计算所有子控件的frame、cell的高度
}
return _cellHeight;
}


在控制器中

实现一个返回cell高度的代理方法

在这个方法中返回indexPath位置对应cell的高度

/**
*  返回每一行cell的具体高度
*/
- (CGFloat)tableView:(UITableView *)tableView heightForRowAtIndexPath:(NSIndexPath *)indexPath
{
XMGStatus *status = self.statuses[indexPath.row];
return status.cellHeight;
}


给cell传递模型数据

- (UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath
{
static NSString *ID = @"tg";
// 访问缓存池
XMGStatusCell *cell = [tableView dequeueReusableCellWithIdentifier:ID];

// 设置数据(传递模型数据)
cell.status = self.statuses[indexPath.row];

return cell;
}


新建一个继承自
UITableViewCell
的子类,比如XMGStatusCell


@interface XMGStatusCell : UITableViewCell
@end


在XMGStatusCell.m文件中

重写
-initWithStyle:reuseIdentifier:
方法

在这个方法中添加所有需要显示的子控件(把有可能显示的子控件都加上,再根据情况决定显示还是隐藏)

给子控件做一些初始化设置(设置字体、文字颜色等)

/**
*  在这个方法中添加所有的子控件
*/
- (instancetype)initWithStyle:(UITableViewCellStyle)style reuseIdentifier:(NSString *)reuseIdentifier
{
if (self = [super initWithStyle:style reuseIdentifier:reuseIdentifier]) {
// ......
}
return self;
}


在XMGStatusCell.h文件中提供一个模型属性,比如XMGTg模型

@class XMGStatus;

@interface XMGStatusCell : UITableViewCell
/** 团购模型数据 */
@property (nonatomic, strong) XMGStatus *status;
@end


在XMGTgCell.m中重写模型属性的set方法

在set方法中给子控件设置模型数据

- (void)setStatus:(XMGStatus *)status
{
_status = status;

// .......
}


重写
-layoutSubviews
方法


一定要调用
[super layoutSubviews]


在这个方法中设置所有子控件的frame

/**
*  在这个方法中设置所有子控件的frame
*/
- (void)layoutSubviews
{
[super layoutSubviews];

// ......
}


Autolayout

xib方式

storyboard方式

对比自定义等高cell,需要几个额外的步骤(iOS8开始才支持)

添加子控件和contentView之间的间距约束



设置tableViewCell的真实行高和估算行高

// 告诉tableView所有cell的真实高度是自动计算(根据设置的约束来计算)
self.tableView.rowHeight = UITableViewAutomaticDimension;
// 告诉tableView所有cell的估算高度
self.tableView.estimatedRowHeight = 44;


如果要支持iOS8之前

如果cell内部有自动换行的label,需要设置preferredMaxLayoutWidth属性

- (void)awakeFromNib
{
// 手动设置文字的最大宽度(目的是:让label知道自己文字的最大宽度,进而能够计算出自己的frame)
self.text_label.preferredMaxLayoutWidth = [UIScreen mainScreen].bounds.size.width - 20;
}


设置tableView的cell估算高度

// 告诉tableView所有cell的估算高度(设置了估算高度,就可以减少tableView:heightForRowAtIndexPath:方法的调用次数)
self.tableView.estimatedRowHeight = 200;


在代理方法中计算cell的高度

XMGStatusCell *cell;
- (CGFloat)tableView:(UITableView *)tableView heightForRowAtIndexPath:(NSIndexPath *)indexPath
{
// 创建一个cell(cell的作用:根据模型数据布局所有的子控件,进而计算出cell的高度)
if (!cell) {
cell = [tableView dequeueReusableCellWithIdentifier:ID];
}

// 设置模型数据
cell.status = self.statuses[indexPath.row];

return cell.height;
}

- (CGFloat)height
{
// 强制布局cell内部的所有子控件(label根据文字多少计算出自己最真实的尺寸)
[self layoutIfNeeded];

// 计算cell的高度
if (self.status.picture) {
return CGRectGetMaxY(self.pictureImageView.frame) + 10;
} else {
return CGRectGetMaxY(self.text_label.frame) + 10;
}
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: