Cell自适应高度

让Cell自动适应高度

自定义cell

#import "MyCell.h"
//contentView是每个cell的view
//下面的define是定义成每个cell的高度和宽度
#define WIDTH self.contentView.frame.size.width
#define HEIGHT self.contentView.frame.size.height
@implementation MyCell
-(instancetype)initWithStyle:(UITableViewCellStyle)style reuseIdentifier:(NSString *)reuseIdentifier{
    self = [super initWithStyle:style reuseIdentifier:reuseIdentifier];
    if (self) {
        [self createView];
    }
    return self;
}
-(void)createView{
    self.MyImageView = [[UIImageView alloc]init];
    [self.contentView addSubview:self.MyImageView];
    [self.MyImageView release];

    self.Mylable = [[UILabel alloc]init];
//    指定lable的字体大小,默认是17号
    self.Mylable.font = [UIFont systemFontOfSize:14];
//    0是最大行数
    self.Mylable.numberOfLines = 0;
    [self.Mylable sizeToFit];
    [self.contentView addSubview:self.Mylable];
    [_Mylable release];
}
-(void)layoutSubviews{
    [super layoutSubviews];
//    让imageview的尺寸和cell的图片大小相同
//    因为这个方法是最后一个被执行的,所以执行到这个方法的时候,已经对cell的各个属性进行完赋值操作,所以可以通过imageview.image找到图片的尺寸
    CGSize picSize = self.MyImageView.image.size;
    CGFloat height = picSize.height * self.contentView.frame.size.width / picSize.width;
    self.MyImageView.frame = CGRectMake(0, 0, self.contentView.frame.size.width, height);

    NSDictionary *fontDic = [NSDictionary dictionaryWithObjectsAndKeys:[UIFont systemFontOfSize:14],NSFontAttributeName, nil];

    //    根据文本的大小,计算出文本的尺寸
    //    还需要指定一个尺寸(375,0)
    //    第三个参数:计算高度需要依据字体的哪个特征来确定
    CGRect rect = [self.Mylable.text boundingRectWithSize:CGSizeMake(375, 0) options:NSStringDrawingUsesLineFragmentOrigin attributes:fontDic context:nil];
    self.Mylable.frame = CGRectMake(0, height, self.contentView.frame.size.width, rect.size.height);

}
-(void)dealloc{
    [_MyImageView release];
    [super dealloc];
}

主视图中需要实现的让cell自适应的方法

#pragma mark 这个方法是tableview的delegate所提供的协议方法,主要是用来设置每一行的高度
-(CGFloat)tableView:(UITableView *)tableView heightForRowAtIndexPath:(NSIndexPath *)indexPath{
//根据图片的尺寸设置行高
//
    UIImage *image = [UIImage imageNamed:self.picArr[indexPath.row]];
//    通过cgsize找到image里面的图片尺寸
    CGSize picSize = image.size;
//    计算宽高
    CGFloat rowHeight = picSize.height * self.view.frame.size.width / picSize.width;
//    计算lable的高度
//    根据对应的文字求出cell上lable显示的高度
    NSDictionary *fontDic = [NSDictionary dictionaryWithObjectsAndKeys:[UIFont systemFontOfSize:14],NSFontAttributeName, nil];

//    根据文本的大小,计算出文本的尺寸
//    还需要指定一个尺寸(375,0)
//    第三个参数:计算高度需要依据字体的哪个特征来确定
    CGRect rect = [self.ziArr[indexPath.row]boundingRectWithSize:CGSizeMake(375, 0) options:NSStringDrawingUsesLineFragmentOrigin attributes:fontDic context:nil];
//    把结果作为返回值返回
    return rowHeight + rect.size.height;  
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值