I've been working with UITextView and TextKit 2, which became the default text engine since iOS 16, and I've encountered performance issues when handling very large text documents.
Even on iPhone 14 Pro, I've noticed stuttering and frame drops when scrolling through the text view containing a large amount of text.
To reproduce the issue, you can use the following code:
// In iOS 16
let textView = UITextView()
textView.text = "some really large string (say 1 million characters)"
The scrolling performance in this scenario is not smooth. However, if you switch to TextKit 1 by accessing the layoutManager property, the performance significantly improves:
// In iOS 16
let textView = UITextView()
let _ = textView.layoutManager // this enables the compatibility mode
textView.text = "some really large string (say 1 million characters)"
With this code, scrolling remains smooth even with large text documents. It's very disappointing to see TextKit 2 performing worse than TextKit 1, even though Apple claims TextKit 2 has significantly improved performance with noncontiguous layout.
Furthermore, the sample code for TextKit 2, available here, crashes when handling very large text due to excessive memory usage.
Has anyone else experienced similar performance issues with TextKit 2, and are there any potential solutions or workarounds to improve the performance?
What's new in TextKit and text views
RSS for tagDiscuss the WWDC22 Session What's new in TextKit and text views
Posts under wwdc2022-10090 tag
2 Posts
Sort by:
Post
Replies
Boosts
Views
Activity
In TextKit 1, I can override drawBackground(forGlyphRange:at:) in NSLayoutManager to do custom background drawing. However, I'm not too sure what the designated way of doing background drawing is in TextKit 2.
One thing I've tried is to do custom drawing in my own CALayer that's used in the configureRenderingSurface delegate callback, but I'm unsure if we are suppose to use this API and steal the textViewportLayoutController.delegate away from _UITextLayoutcanvasView?