国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > Swift > 正文

利用Swift如何計算文本的size示例詳解

2020-03-09 17:43:42
字體:
來源:轉載
供稿:網友

前言

對于swift 還處于摸索階段很多語法還不熟悉,本文主要給大家介紹的是關于利用Swift計算文本size的相關內容,分享出來供大家參考學習,下面話不多說了,來一起看看詳細的介紹吧。

iOS 11之前限制寬高計算字符串的size用的是UILabel的textRect(forBounds bounds: CGRect, limitedToNumberOfLines numberOfLines: Int) -> CGRect方法,當時也沒考慮線程安全問題(low爆了),Xcode也沒提示,用了好幾個版本,所幸一直都沒問題。

貼下方法(當時為什么選這個方法就不解釋了):

func textSize(font: UIFont, constrainedSize: CGSize, lineSpacing: CGFloat?, lines: Int) -> CGSize {    if self.isEmpty || lines < 0 {      return CGSize.zero    }        let attributedString = NSMutableAttributedString(string: self)    let range = NSRange(location: 0, length: attributedString.length)    attributedString.addAttributes([NSFontAttributeName: font], range: range)    if lineSpacing != nil {      let paragraphStyle = NSMutableParagraphStyle()      paragraphStyle.lineBreakMode = .byTruncatingTail      paragraphStyle.lineSpacing = lineSpacing!      attributedString.addAttribute(NSParagraphStyleAttributeName, value: paragraphStyle, range: range)    }        let calculatedLabel = UILabel()    calculatedLabel.font = font    calculatedLabel.attributedText = attributedString    calculatedLabel.numberOfLines = lines    let rect = calculatedLabel.textRect(forBounds: CGRect(x: 0, y: 0, width: constrainedSize.width, height: constrainedSize.height), limitedToNumberOfLines: lines)        return rect.size  }

最近升級了Xcode 9,運行時警告我let calculatedLabel = UILabel()要在主線程執行,這時才意識到問題的嚴重性,馬上進行了修改:

extension String {  func boundingRect(with constrainedSize: CGSize, font: UIFont, lineSpacing: CGFloat? = nil) -> CGSize {    let attritube = NSMutableAttributedString(string: self)    let range = NSRange(location: 0, length: attritube.length)    attritube.addAttributes([NSAttributedStringKey.font: font], range: range)    if lineSpacing != nil {      let paragraphStyle = NSMutableParagraphStyle()      paragraphStyle.lineSpacing = lineSpacing!      attritube.addAttribute(NSAttributedStringKey.paragraphStyle, value: paragraphStyle, range: range)    }        let rect = attritube.boundingRect(with: constrainedSize, options: [.usesLineFragmentOrigin, .usesFontLeading], context: nil)    var size = rect.size        if let currentLineSpacing = lineSpacing {      // 文本的高度減去字體高度小于等于行間距,判斷為當前只有1行      let spacing = size.height - font.lineHeight      if spacing <= currentLineSpacing && spacing > 0 {        size = CGSize(width: size.width, height: font.lineHeight)      }    }        return size  }    func boundingRect(with constrainedSize: CGSize, font: UIFont, lineSpacing: CGFloat? = nil, lines: Int) -> CGSize {    if lines < 0 {      return .zero    }        let size = boundingRect(with: constrainedSize, font: font, lineSpacing: lineSpacing)    if lines == 0 {      return size    }    let currentLineSpacing = (lineSpacing == nil) ? (font.lineHeight - font.pointSize) : lineSpacing!    let maximumHeight = font.lineHeight*CGFloat(lines) + currentLineSpacing*CGFloat(lines - 1)    if size.height >= maximumHeight {      return CGSize(width: size.width, height: maximumHeight)    }        return size  }}

參數解釋

  • constrainedSize:限制的size
  • font:字號
  • lineSpacing:默認為nil,使用系統默認的行間距
  • lines:限制的行數

注:代碼版本為Swift 4.0

上面的兩個方法分別取代名:方法1和方法2。

方法1:限制寬高,可設置行間距,計算準確

方法2:比方法1多了限制行數功能。

配合使用UILabel的擴展方法:

extension UILabel {    // 設置`numberOfLines = 0`的原因:  // 配合方法`func boundingRect(with constrainedSize: CGSize, font: UIFont, lineSpacing: CGFloat? = nil, lines: Int) -> CGSize`使用,可以很好的解決不能正常顯示限制行數的問題;  // 如果為label設置了限制行數(大于0的前提),使用上面的計算方法(帶行間距),同時字符串的實際行數大于限制行數,這時候的高度會使label不能正常顯示。  func setText(with normalString: String, lineSpacing: CGFloat?, frame: CGRect) {    self.frame = frame    self.numberOfLines = 0            let paragraphStyle = NSMutableParagraphStyle()    paragraphStyle.lineBreakMode = .byTruncatingTail    if lineSpacing != nil {      if (frame.height - font.lineHeight) <= lineSpacing! {        paragraphStyle.lineSpacing = 0      } else {        paragraphStyle.lineSpacing = lineSpacing!      }    }    let attributedString = NSMutableAttributedString(string: normalString)    let range = NSRange(location: 0, length: attributedString.length)    attributedString.addAttributes([NSAttributedStringKey.font: font], range: range)    attributedString.addAttribute(NSAttributedStringKey.paragraphStyle, value: paragraphStyle, range: range)    self.attributedText = attributedString  }}

在此感謝倉鼠:iOS 行距全攻略 和https://github.com/zhengwenming/WeChat

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,如果有疑問大家可以留言交流,謝謝大家對VEVB武林網的支持。

 

注:相關教程知識閱讀請移步到swift教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 东平县| 万荣县| 疏勒县| 三门峡市| 容城县| 阜新| 荆州市| 平原县| 荃湾区| 合作市| 淮阳县| 湘潭市| 和政县| 北安市| 沙田区| 个旧市| 奇台县| 临猗县| 招远市| 阳山县| 民权县| 杭锦后旗| 友谊县| 巩留县| 永胜县| 寻乌县| 双流县| 沙坪坝区| 华池县| 大余县| 郯城县| 涟源市| 黔西| 柞水县| 达州市| 区。| 盱眙县| 钟山县| 平顺县| 彩票| 宿迁市|