Das folgende ist ein triviales Beispiel für ein UITextView, das von einem NSTextStorage unterstützt wird. Die "doAction1" wird durch Klicken auf einen UI-Button ausgelöst. Als ich die Dokumente gelesen habe, hatte ich den Eindruck, dass sich die Ansicht automatisch aktualisiert, wenn NSTextStorage in einem Anfangs-/Ende-Bearbeitungsblock aktualisiert wird.UITextView von NSTextStorage unterstützt nicht aktualisiert, wenn Text angefügt wurde
Es scheint jedoch nicht zu passieren - das Beispiel unten hängt "... World!" zu NSTextStorage, aber die UITextView spiegelt das nicht wider - und zeigt weiterhin nur "Hello" an. Irgendeine Idee?
import UIKit
class ViewController: UIViewController {
let TEXT = "Hello"
var m_layoutManager: NSLayoutManager!
var m_textView: UITextView!
@IBAction func doAction1(_ sender: AnyObject) {
let ts = m_layoutManager.textStorage
ts?.beginEditing()
ts?.append(AttributedString(string:"...World!"))
ts?.endEditing()
// These two don't make a difference either:
//
// m_layoutManager.invalidateDisplay(forCharacterRange: NSRange(location: 0, length: (ts?.length)!))
// m_textView.setNeedsDisplay()
//
}
override func viewDidLoad() {
super.viewDidLoad()
let textStorage = NSTextStorage(string: TEXT)
let textContainer = NSTextContainer(
size: CGSize(width: 200, height: 300))
m_layoutManager = NSLayoutManager()
m_layoutManager.textStorage = textStorage
m_layoutManager.addTextContainer(textContainer)
m_textView = UITextView(
frame: CGRect(x: 0, y: 20, width: 200, height: 300),
textContainer: textContainer)
view.addSubview(m_textView)
}
override func didReceiveMemoryWarning() {
super.didReceiveMemoryWarning()
}
}