iOS UITextView 渲染富文本-性能优化

在这里插入图片描述

背景

当我们在项目中使用 TextView 渲染样式复杂且内容较长的富文本的时候,可能会出现渲染时间比较长的情况,给人的直观感受就是界面卡住了,在程序员的视角造成这种情况的根本原因是主线程阻塞了。

Xcode调试时会出现下面的日志:

UITextView 0x107d2ce00 is switching to TextKit 1 compatibility mode 
because its layoutManager was accessed. Break on 
void _UITextViewEnablingCompatibilityMode(UITextView *__strong, BOOL) to debug.

这个警告是由于你的 UITextView 实例正在切换到 TextKit 1 兼容模式,因为它的 layoutManager 被访问了。

解决

在你的实例化 UITextView后 ,添加以下代码:

yourTextView.layoutManager.usesFontLeading = false
yourTextView.layoutManager.allowsNonContiguousLayout = false

这些代码将禁用 UITextView 的 layoutManager 相关功能,从而避免出现兼容性警告.

效果对比

问题解决前:震惊居然耗时13秒

请添加图片描述

优化后:震惊秒渲染

请添加图片描述


感谢你的阅读和参与,HH思无邪愿与你一起在技术的道路上不断探索。如果你喜欢这篇博客,不妨点个赞哦!如果你有任何问题或建议,也请在评论区留言,让我们一起进步!

  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
UITextView是UIKit框架中的一个控件,可以用来显示和编辑长文本。而富文本则是指带有丰富样式的文本,可以设置文字的字体、颜色、大小、间距、行高等属性。 要在UITextView中实现富文本,首先需要创建一个NSAttributedString对象,并通过NSMutableAttributedString来设置文字的样式。NSAttributedString是不可变的,而NSMutableAttributedString可以修改和添加样式。 创建NSMutableAttributedString对象后,可以使用其方法来设置文字的样式,比如设置字体可以使用NSFontAttributeName属性,设置颜色可以使用NSForegroundColorAttributeName属性,设置字号可以使用NSFontAttributeName属性,设置段落样式可以使用NSParagraphStyleAttributeName属性等等。 设置完成后,就可以将NSMutableAttributedString对象赋值给UITextView的attributedText属性,以实现富文本的显示。 例如,我们想将某个UITextView的文字样式设置为红色、字号为20、字体为粗体,可以按如下方式设置: ``` NSMutableAttributedString *attributedString = [[NSMutableAttributedString alloc] initWithString:@"这是富文本"]; [attributedString addAttribute:NSForegroundColorAttributeName value:[UIColor redColor] range:NSMakeRange(0, attributedString.length)]; [attributedString addAttribute:NSFontAttributeName value:[UIFont boldSystemFontOfSize:20] range:NSMakeRange(0, attributedString.length)]; textView.attributedText = attributedString; ``` 通过上述代码,就可以在UITextView中显示带有红色、字号为20、字体为粗体的文字。 除了以上示例外,UITextView还支持更多的富文本样式设置,根据具体需求,可以设置更多的属性来实现更丰富的文本效果。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

HH思️️无邪

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值