实现自适应高度的 UITableViewCell 或 UILabel

在使用UILabel存放字符串时,经常需要获取label的长宽数据,本文列出了部分常用的计算方法 

1.实际编程时,有时需要计算一段文字最后一个字符的位置,并在其后添加图片或其他控件(如info图标),下面代码为计算label中最后一个字符后面一位的位置的方法。在iOS7以前的方法:

CGSize sz = [label.text sizeWithFont:label.font                      

constrainedToSize:CGSizeMake(MAXFLOAT, 40)]; 

CGSize linesSz = [label.text sizeWithFont:label.font                         constrainedToSize:CGSizeMake(label.frame.size.width, MAXFLOAT)     

        lineBreakMode:UILineBreakModeWordWrap]; 

if(sz.width <= linesSz.width) //判断是否折行

   lastPoint = CGPointMake(label.frame.origin.x + sz.width, label.frame.origin.y); 

else {

lastPoint = CGPointMake(label.frame.origin.x + (int)sz.width % (int)linesSz.width,linesSz.height - sz.height); 

在iOS7之后原来的方法 sizeWithFont:label 已经不支持,新方法使用如下

NSDictionary *Nameattributes =@{NSFontAttributeName:_name.font};

CGSize nameSize =[model.nameboundingRectWithSize:CGSizeMake(MAXFLOAT,40)options:NSStringDrawingTruncatesLastVisibleLineattributes:Nameattributescontext:nil].size;

_name.frame =CGRectMake(_headImageview.maxX + 10,_headImageview.y, nameSize.width, nameSize.height);

2.设置lable换行,多行的情况

UILabel* lab = [[UILabelalloc]init];

    lab.text =@"text额外热风瓦房噶而过去玩儿过耳光玩儿过去fasfsadsassafdsfs而过去而去";

    lab.font = [UIFontsystemFontOfSize:20];

    lab.textAlignment =NSTextAlignmentLeft;

    lab.numberOfLines =0;

    lab.backgroundColor = [UIColorredColor];

    NSDictionary *Nameattributes =@{NSFontAttributeName:lab.font};

    CGSize labSize = [lab.textboundingRectWithSize:CGSizeMake(200,MAXFLOAT) options:NSStringDrawingUsesLineFragmentOriginattributes:Nameattributescontext:nil].size;

    lab.frame =CGRectMake(20,300, labSize.width, labSize.height);

    [self.viewaddSubview:lab];

    

    UILabel* lab2 = [[UILabelalloc]init];

    lab2.text =@"text额外热风瓦房噶而过去玩儿过耳光玩儿过去sdfasffasfsadsassafdsfs而过去而去";

    lab2.font = [UIFontsystemFontOfSize:20];

    lab2.textAlignment =NSTextAlignmentLeft;

    lab2.numberOfLines =0;

    lab2.frame =CGRectMake(20,100, 200,0);

    lab2.backgroundColor = [UIColorblueColor];

    [lab2 sizeToFit];

    [self.viewaddSubview:lab2];


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
对于UITableViewCell中包含WebView的自适应高度问题,一般的解决方案是在webViewDidFinishLoad方法中计算WebView的高度,并更新UITableViewCell高度。但是这种方法有时会出现计算不准确的情况,以及性能问题。 最新的解决方案是使用iOS 11中引入的UITableViewAutomaticDimension,结合约束自动布局来实现UITableViewCell自适应高度。具体步骤如下: 1. 在Storyboard或XIB中,设置UITableViewCell的约束,包括WebView的顶部、底部、左右两侧的约束,并将WebView的高度设置为大于等于0的值(可以是一个较小的值,比如10)。 2. 在tableView(_:cellForRowAt:)方法中,设置WebView的代理为当前的UITableViewCell,并在webView(_:didFinish:)方法中更新UITableViewCell高度: ```swift func webView(_ webView: WKWebView, didFinish navigation: WKNavigation!) { // 计算WebView的内容高度 webView.evaluateJavaScript("document.readyState") { (result, error) in if result != nil { webView.evaluateJavaScript("document.body.offsetHeight", completionHandler: { (height, error) in if let height = height as? CGFloat { // 更新UITableViewCell高度 self.heightConstraint.constant = height self.setNeedsUpdateConstraints() self.updateConstraintsIfNeeded() self.layoutIfNeeded() self.delegate?.didUpdateHeight() } }) } } } ``` 3. 在tableView(_:estimatedHeightForRowAt:)方法中,返回一个估算的高度(可以是一个较小的值,比如100): ```swift func tableView(_ tableView: UITableView, estimatedHeightForRowAt indexPath: IndexPath) -> CGFloat { return 100 } ``` 4. 在tableView(_:heightForRowAt:)方法中,返回UITableViewAutomaticDimension: ```swift func tableView(_ tableView: UITableView, heightForRowAt indexPath: IndexPath) -> CGFloat { return UITableViewAutomaticDimension } ``` 注意:在使用约束自动布局的情况下,需要保证UITableViewCell高度约束是完整的,即顶部和底部都有约束,否则自适应高度可能会出现问题。同时,在更新UITableViewCell高度时,需要调用setNeedsUpdateConstraints、updateConstraintsIfNeeded和layoutIfNeeded方法,以保证约束的更新及时生效。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值