zoukankan      html  css  js  c++  java
  • [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 }
  • 相关阅读:
    E-Eating Together(POJ 3670)
    F-Dining Cows(POJ 3671)
    I-MooFest(POJ 1990)
    A-Apple Catching(POJ 2385)
    H-The Cow Lineup(POJ 1989)
    LOOPS(HDU 3853)
    Card Collector(HDU 4336)
    Help Me Escape (ZOJ 3640)
    Collecting Bugs(POJ 2096)
    c#大圣之路笔记——c# 从DataGrid中导出数据 Session
  • 原文地址:https://www.cnblogs.com/strengthen/p/11166074.html
Copyright © 2011-2022 走看看