• [Swift]UILabel文字截断


    ★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★
    ➤微信公众号:山青咏芝(shanqingyongzhi)
    ➤博客园地址:山青咏芝(https://www.cnblogs.com/strengthen/
    ➤GitHub地址:https://github.com/strengthen/LeetCode
    ➤原文地址:https://www.cnblogs.com/strengthen/p/11166074.html 
    ➤如果链接不是山青咏芝的博客园地址,则可能是爬取作者的文章。
    ➤原文已修改更新!强烈建议点击原文地址阅读!支持作者!支持原创!
    ★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★

    对 UILabel 进行扩展,增加一个 isTruncated 属性来表示当前内容是否被截断。其内部逻辑就是比较下面两种行数的大小:
    • 所有文字如果要完全显示的话需要的行数
    • 实际能显示的行数
     1 extension UILabel {
     2     //判断文本标签的内容是否被截断
     3     var isTruncated: Bool {
     4         guard let labelText = text else {
     5             return false
     6         }
     7          
     8         //计算理论上显示所有文字需要的尺寸
     9         let rect = CGSize( self.bounds.width, height: CGFloat.greatestFiniteMagnitude)
    10         let labelTextSize = (labelText as NSString)
    11             .boundingRect(with: rect, options: .usesLineFragmentOrigin,
    12                           attributes: [NSAttributedStringKey.font: self.font], context: nil)
    13          
    14         //计算理论上需要的行数
    15         let labelTextLines = Int(ceil(CGFloat(labelTextSize.height) / self.font.lineHeight))
    16          
    17         //实际可显示的行数
    18         var labelShowLines = Int(floor(CGFloat(bounds.size.height) / self.font.lineHeight))
    19         if self.numberOfLines != 0 {
    20             labelShowLines = min(labelShowLines, self.numberOfLines)
    21         }
    22          
    23         //比较两个行数来判断是否需要截断
    24         return labelTextLines > labelShowLines
    25     }
    26 }
  • 相关阅读:
    不等高cell的搭建(一)
    重复点击主界面(TabBar)按钮刷新界面--点击状态栏回到顶部
    如何学习新框架(保存图片到相册)
    上下拉刷新
    MVVM框架思想
    不等高cell的tableView界面搭建
    UITabBarController底层实现
    封装业务类
    RSS阅读器
    构造队列
  • 原文地址:https://www.cnblogs.com/strengthen/p/11166074.html
Copyright © 2020-2023  润新知