【Swift】 NSTextView用法和示例

NSTextView 是 macOS 上的一个文本视图控件,用于显示和编辑文本内容。它是 NSText 的子类,提供了更高级的文本处理功能。

1.创建一个简单的例子

import Cocoa

let textView = NSTextView(frame: NSRect(x: 0, y: 0, width: 200, height: 200))

// 设置文本视图的属性
textView.string = "Hello, NSTextView!"
textView.font = NSFont.systemFont(ofSize: 14)
textView.textColor = NSColor.black
textView.alignment = .left
textView.isEditable = true
textView.isSelectable = true

// 将文本视图添加到视图层级中
let window = NSWindow(contentRect: NSRect(x: 0, y: 0, width: 400, height: 400), styleMask: [.titled, .closable, .miniaturizable, .resizable], backing: .buffered, defer: false)
window.center()
window.contentView?.addSubview(textView)
window.makeKeyAndOrderFront(nil)

// 运行应用程序的主事件循环
NSApplication.shared.run()

这段代码创建了一个大小为 200x200 的 NSTextView,并设置了一些常用的属性。然后,将文本视图添加到一个窗口的内容视图中,并显示出来。最后,运行应用程序的主事件循环,以保持窗口的显示。

2.常用的 NSTextView 属性

下面是一下常用的属性

  1. string:文本视图中的字符串内容。
  2. textStorageNSTextStorage 对象,用于访问和修改文本的属性,例如字体、颜色、样式等。
  3. font:文本的字体。
  4. textColor:文本的颜色。
  5. alignment:文本的对齐方式,可以是左对齐、右对齐、居中对齐等。
  6. isEditable:指示文本视图是否可编辑的布尔值。
  7. isSelectable:指示文本视图是否可选择的布尔值。
  8. isRichText:指示文本视图是否支持富文本的布尔值。
  9. allowsUndo:指示文本视图是否支持撤销和重做的布尔值。
  10. isContinuousSpellCheckingEnabled:指示文本视图是否启用连续拼写检查的布尔值。
  11. isAutomaticQuoteSubstitutionEnabled:指示文本视图是否启用自动引号替换的布尔值。
  12. isAutomaticLinkDetectionEnabled:指示文本视图是否启用自动链接检测的布尔值。
  13. isAutomaticDataDetectionEnabled:指示文本视图是否启用自动数据检测的布尔值。
  14. isAutomaticTextReplacementEnabled:指示文本视图是否启用自动文本替换的布尔值。
  15. isAutomaticSpellingCorrectionEnabled:指示文本视图是否启用自动拼写更正的布尔值。
  16. delegateNSTextViewDelegate 对象,用于处理文本视图的事件和行为。

3.添加富文本 

要在 NSTextView 中添加富文本,可以使用 NSAttributedString 类来创建包含富文本属性的字符串,并将其设置为文本视图的内容

import Cocoa

class ViewController: NSViewController {
    
    let textView = NSTextView(frame: NSRect(x: 20, y: 20, width: 300, height: 200))
    
    override func viewDidLoad() {
        super.viewDidLoad()
        
        // 创建富文本字符串
        let attributedString = NSMutableAttributedString(string: "Hello, World!")
        
        // 添加富文本属性
        let attributes: [NSAttributedString.Key: Any] = [
            .font: NSFont.boldSystemFont(ofSize: 18),
            .foregroundColor: NSColor.red,
            .backgroundColor: NSColor.yellow
        ]
        attributedString.addAttributes(attributes, range: NSRange(location: 0, length: attributedString.length))
        
        // 设置文本视图的内容为富文本字符串
        textView.textStorage?.setAttributedString(attributedString)
        
        view.addSubview(textView)
    }
    
    // 其他方法...
}

在上面的示例中,首先创建了一个 NSMutableAttributedString 对象,并使用 NSAttributedString.Key 枚举来指定要添加的富文本属性,例如字体、前景色和背景色。然后,使用 addAttributes(_:range:) 方法将这些属性添加到富文本字符串中。

最后,使用 textStorage?.setAttributedString(_:) 方法将富文本字符串设置为文本视图的内容。

 

4.常用的委托(delegate)方法

  • textDidChange(_:) 方法:当文本视图的内容发生变化时调用。可以在此方法中执行一些逻辑,例如更新相关的 UI 或执行文本处理操作。
func textDidChange(_ notification: Notification) {
    if let textView = notification.object as? NSTextView {
        // 处理文本视图内容变化
    }
}
  • textView(_:clickedOnLink:at:) 方法:当用户点击链接时调用。可以在此方法中处理链接点击事件,例如打开链接的网页或执行其他操作。
func textView(_ textView: NSTextView, clickedOnLink link: Any, at charIndex: Int) -> Bool {
    // 处理链接点击事件
    return true
}
  • textView(_:shouldChangeTextIn:replacementString:) 方法:在文本视图的内容即将发生变化时调用。可以在此方法中检查和修改要插入或删除的文本。
func textView(_ textView: NSTextView, shouldChangeTextIn affectedCharRange: NSRange, replacementString: String?) -> Bool {
    // 检查和修改要插入或删除的文本
    return true
}
  • textView(_:willChangeSelectionFromCharacterRange:toCharacterRange:) 方法:当文本视图的选中范围即将发生变化时调用。可以在此方法中执行一些逻辑,例如限制选中范围或更新相关的 UI。
func textView(_ textView: NSTextView, willChangeSelectionFromCharacterRange oldSelectedCharRange: NSRange, toCharacterRange newSelectedCharRange: NSRange) -> NSRange {
    // 执行一些逻辑,例如限制选中范围或更新相关的 UI
    return newSelectedCharRange
}
  1. textView(_:shouldChangeTextIn:replacementText:) 方法:在文本视图的内容即将发生变化时调用。可以在此方法中检查和修改要插入或删除的文本。
func textView(_ textView: NSTextView, shouldChangeTextIn affectedCharRange: NSRange, replacementString: String?) -> Bool {
    // 检查和修改要插入或删除的文本
    return true
}

你可能感兴趣的:(MacOS开发,控件,Swift,swift,macos,控件)