ios – 如何获得尊重可访问性设置的等宽字体

前端之家收集整理的这篇文章主要介绍了ios – 如何获得尊重可访问性设置的等宽字体前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
  1. let bodyFontDescriptor = UIFontDescriptor
  2. .preferredFontDescriptor(withTextStyle: UIFontTextStyle.body)
  3. let bodyMonospacedFontDescriptor = bodyFontDescriptor.addingAttributes(
  4. [
  5. UIFontDescriptorFeatureSettingsAttribute: [
  6. [
  7. UIFontFeatureTypeIdentifierKey: kTextSpacingType,UIFontFeatureSelectorIdentifierKey: kMonospacedTextSelector
  8. ]
  9. ]
  10. ])
  11. let bodyMonospacedFont = UIFont(descriptor: bodyMonospacedFontDescriptor,size: 0.0)
  12. textview.font = bodyMonospacedFont

这将生成带有可变宽度字符的文本.
我需要获得一个monospace字体,而不需要硬编码快递
和固定的大小.
部署目标是ios 9.0

解决方法

这是UIFontDescriptor的扩展,它返回给定文本样式的首选等宽字体描述符.使用UIFont或UIFontDescriptor获取完全等宽字体没有简单的方法.该解决方案试图找到一个好的等宽字体,并在需要时回退到Courier.
  1. extension UIFontDescriptor {
  2. static let monoDescriptor: UIFontDescriptor = {
  3. // Attempt to find a good monospaced,non-bold,non-italic font
  4. for family in UIFont.familyNames {
  5. for name in UIFont.fontNames(forFamilyName: family) {
  6. let f = UIFont(name: name,size: 12)!
  7. let fd = f.fontDescriptor
  8. let st = fd.symbolicTraits
  9. if st.contains(.traitMonoSpace) && !st.contains(.traitBold) && !st.contains(.traitItalic) && !st.contains(.traitExpanded) && !st.contains(.traitCondensed) {
  10. return fd
  11. }
  12. }
  13. }
  14.  
  15. return UIFontDescriptor(name: "Courier",size: 0) // fallback
  16. }()
  17.  
  18. class func preferredMonoFontDescriptor(withTextStyle style: UIFontTextStyle) -> UIFontDescriptor {
  19. // Use the following line if you need a fully monospaced font
  20. let monoDescriptor = UIFontDescriptor.monoDescriptor
  21.  
  22. // Use the following two lines if you only need monospaced digits in the font
  23. //let monoDigitFont = UIFont.monospacedDigitSystemFont(ofSize: 0,weight: .regular)
  24. //let monoDescriptor = monoDigitFont.fontDescriptor
  25.  
  26. // Get the non-monospaced preferred font
  27. let defaultFontDescriptor = preferredFontDescriptor(withTextStyle: style)
  28. // Remove any attributes that specify a font family or name and remove the usage
  29. // This will leave other attributes such as size and weight,etc.
  30. var fontAttrs = defaultFontDescriptor.fontAttributes
  31. fontAttrs.removeValue(forKey: .family)
  32. fontAttrs.removeValue(forKey: .name)
  33. fontAttrs.removeValue(forKey: .init(rawValue: "NSCTFontUIUsageAttribute"))
  34. let monospacedFontDescriptor = monoDescriptor.addingAttributes(fontAttrs)
  35.  
  36. return monospacedFontDescriptor.withSymbolicTraits(defaultFontDescriptor.symbolicTraits) ?? monospacedFontDescriptor
  37. }
  38. }

请注意有关是否需要完全等宽字体的字体或仅具有等宽数字的字体的注释.评论/取消注释这些行以满足您的特定需求.

样品用法

  1. let bodyMonospacedFont = UIFont(descriptor: .preferredMonoFontDescriptor(withTextStyle: .body),size: 0)
  2. textview.font = bodyMonospacedFont

以下是一些测试代码,用于确认preferredMonoFontDescriptor(withTextStyle :)的结果适用于所有样式:

  1. let textStyles: [UIFontTextStyle] = [ .body,.callout,.caption1,.caption2,.footnote,.headline,.subheadline,.largeTitle,.title1,.title2,.title3 ]
  2. for style in textStyles {
  3. let nfont = UIFont(descriptor: .preferredFontDescriptor(withTextStyle: style),size: 0)
  4. let mfont = UIFont(descriptor: .preferredMonoFontDescriptor(withTextStyle: style),size: 0)
  5. print(style)
  6. print(nfont)
  7. print(mfont)
  8. }

如果比较每对结果,它们具有相同的大小,重量和样式,只是不同的字体.

猜你在找的iOS相关文章