自定义不等高cell的纯代码步骤(frame)

来源:互联网 发布:d3.js tree demo 编辑:程序博客网 时间:2024/05/22 06:21

给模型增加frame数据

  • 所有子控件的frame
  • cell的高度
@interface XMGStatus : NSObject/**** 文字\图片数据 ****/// ...../**** frame数据 ****//** 头像的frame */@property (nonatomic, assign) CGRect iconFrame;// ...../** cell的高度 */@property (nonatomic, assign) CGFloat cellHeight;@end
  • 重写模型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];    // ......}
0 0