UItableView的自适应

本文详细解析了如何在iOS应用中实现图片和文字的高度自适应,包括图片高度自适应的方法以及文字高度计算的过程,确保界面在不同设备上保持良好的视觉效果。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

自适应高度用的比较少,将代码封装好,能够理解就好,自适应高度其实也就是动态设置行高

1.图片高度的自适应

首先要知道在哪个协议方法里写(CGFloat)tableView  heightForRow......

在这个方法里,主要计算图片的尺寸,来设置tableview的行高

1.先定义一个image  UIImage保存着实际图片的尺寸,而imageView是我们看到的图片的尺寸通过它来设置

2.我们需要等比例缩放,通过图片的实际尺寸和屏幕固定的宽高等比例计算

  <span style="font-size:18px;">// 在这个方法里.主要计算图片的尺寸,来设置tableView的行高
    UIImage *image = [UIImage imageNamed:self.picArr[indexPath.row]];
    // UIImage保存着实际图片的尺寸,而UIImageView是我们看到的图片的尺寸都通过它来设置
//    NSLog(@"%g", image.size.height);// 获取图片的尺寸
    
    // 通过图片的实际尺寸和屏幕固定的宽进行等比例计算
    CGFloat rowHeight = self.view.frame.size.width * image.size.height / image.size.width;</span>

3.之后在layoutSubviews执行方法(这是cell走的最后一个方法,我们需要现在主函数协议里求行高,然后在函数里自适应图片)

  <span style="font-size:18px;">UIImage *image = self.picImageView.image;
    CGFloat height = image.size.height * self.contentView.frame.size.width / image.size.width;
    self.picImageView.frame = CGRectMake(0, 0, self.contentView.frame.size.width, height);
</span>

2.文字的自适应

1.计算文字的高度  首先将字体的大小放到一个数组里

2.根据文本的内容和文本的字体进行计算高度

 <span style="font-size:18px;"> // 计算文字的高度
    // 将字体大小写到key - value
    NSDictionary *dic = [NSDictionary dictionaryWithObjectsAndKeys:[UIFont systemFontOfSize:14], NSFontAttributeName, nil];
    // 根据文本的内容和文本的字体进行计算高度
    // 参数一:告诉系统,文本显示的最大范围
    //
    CGRect rect = [self.ziArr[indexPath.row] boundingRectWithSize:CGSizeMake(self.view.frame.size.width, 0) options:NSStringDrawingUsesLineFragmentOrigin attributes:dic context:nil];</span>

然后在cell里执行,对lable进行尺寸设置

 <span style="font-size:18px;">// 计算文字的高度
    // 将字体大小写到key - value
    NSDictionary *dic = [NSDictionary dictionaryWithObjectsAndKeys:[UIFont systemFontOfSize:14], NSFontAttributeName, nil];
    // 根据文本的内容和文本的字体进行计算高度
    // 参数一:告诉系统,文本显示的最大范围
    
    // 这个方法是nsstring的
    CGRect rect = [str boundingRectWithSize:CGSizeMake(self.contentView.frame.size.width, 0) options:NSStringDrawingUsesLineFragmentOrigin attributes:dic context:nil];
    
    // 对lable进行尺寸设置
    self.newsLable.frame = CGRectMake(0, height, self.contentView.frame.size.width, rect.size.height);
</span>


#pragma mark 设置tableView cell每行的高度
- (CGFloat)tableView:(UITableView *)tableView heightForRowAtIndexPath:(NSIndexPath *)indexPath{
    // 在这个方法里.主要计算图片的尺寸,来设置tableView的行高
    UIImage *image = [UIImage imageNamed:self.picArr[indexPath.row]];
    // UIImage保存着实际图片的尺寸,而UIImageView是我们看到的图片的尺寸都通过它来设置
//    NSLog(@"%g", image.size.height);// 获取图片的尺寸
    
    // 通过图片的实际尺寸和屏幕固定的宽进行等比例计算
    CGFloat rowHeight = self.view.frame.size.width * image.size.height / image.size.width;
    
    // 计算文字的高度
    // 将字体大小写到key - value
    NSDictionary *dic = [NSDictionary dictionaryWithObjectsAndKeys:[UIFont systemFontOfSize:14], NSFontAttributeName, nil];
    // 根据文本的内容和文本的字体进行计算高度
    // 参数一:告诉系统,文本显示的最大范围
    //
    CGRect rect = [self.ziArr[indexPath.row] boundingRectWithSize:CGSizeMake(self.view.frame.size.width, 0) options:NSStringDrawingUsesLineFragmentOrigin attributes:dic context:nil];
    
       return rowHeight + rect.size.height;

}


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值