0

我在情节提要中有一个 UITextView (属性文本属性,并选中允许编辑属性,选中,可编辑)。当用户按下按钮时,我想“激活”粗体字体。因此,无论用户从那里输入什么,都必须以粗体显示。当按下返回键时,我想转到下一行,UITextView 应该记住所有文本的属性。问题是按回车键后,所有字符都变为粗体。

这是我在代码中的内容。

var isBoldTyping: Bool = false

func textView(_ textView: UITextView, shouldChangeTextIn range: NSRange, replacementText text: String) -> Bool {
    print("text: \(text)", range)
    if text == "\n" {
        textView.text.append("\n")


        if isBoldTyping {
            //textView.typingAttributes = [NSAttributedStringKey.font.rawValue: regularText]
            isBoldTyping = false
        }

    }

    if isBoldTyping {
        textView.textStorage.beginEditing()
        textView.textStorage.addAttributes([NSAttributedStringKey.font: boldText], range: range)
        print("Atttributed adding")
        textView.textStorage.endEditing()
    } else {
        textView.textStorage.beginEditing()
        textView.textStorage.addAttributes([NSAttributedStringKey.font: regularText], range: range)
        print("Atttributed adding")
        textView.textStorage.endEditing()
    }

    return true
}

我试图实现的另一个例子是 stackoverflow 编辑效果。当我按下“{}”图标时,我处于“可编码模式”。当在键盘中按下 enter 时,它会恢复正常。

regularText 和 boldText 属性只是大小为 14 的系统字体。

4

1 回答 1

0

typingAttributes如果我清楚地了解您要达到的目标,那么您需要的只是。\n出现在replacementTextthrough时需要禁用粗体typingAttributes。我给你写一个小例子

class ViewController: UIViewController, UITextViewDelegate {

    let textView = UITextView()
    let boldButton = UIButton(type: .system)

    override func viewDidLoad() {
        super.viewDidLoad()

        textView.translatesAutoresizingMaskIntoConstraints = false
        textView.delegate = self
        textView.typingAttributes = [NSAttributedStringKey.font.rawValue: UIFont.systemFont(ofSize: 14.0)]

        view.addSubview(textView)

        view.addConstraint(NSLayoutConstraint(item: view, attribute: .leading, relatedBy: .equal, toItem: textView, attribute: .leading, multiplier: 1.0, constant: 0.0))
        view.addConstraint(NSLayoutConstraint(item: view, attribute: .top, relatedBy: .equal, toItem: textView, attribute: .top, multiplier: 1.0, constant: 0.0))
        view.addConstraint(NSLayoutConstraint(item: view, attribute: .bottom, relatedBy: .equal, toItem: textView, attribute: .bottom, multiplier: 1.0, constant: 0.0))
        view.addConstraint(NSLayoutConstraint(item: view, attribute: .trailing, relatedBy: .equal, toItem: textView, attribute: .trailing, multiplier: 1.0, constant: 0.0))

        boldButton.setTitle("BOLD", for: .normal)
        boldButton.addTarget(self, action: #selector(toggleBold), for: .touchUpInside)
        boldButton.translatesAutoresizingMaskIntoConstraints = false

        view.addSubview(boldButton)
        view.addConstraint(NSLayoutConstraint(item: view, attribute: .leading, relatedBy: .equal, toItem: boldButton, attribute: .leading, multiplier: 1.0, constant: 0.0))
        view.addConstraint(NSLayoutConstraint(item: boldButton, attribute: .height, relatedBy: .equal, toItem: nil, attribute: .notAnAttribute, multiplier: 1.0, constant: 64.0))
        view.addConstraint(NSLayoutConstraint(item: view, attribute: .bottom, relatedBy: .equal, toItem: boldButton, attribute: .bottom, multiplier: 1.0, constant: 0.0))
        view.addConstraint(NSLayoutConstraint(item: view, attribute: .trailing, relatedBy: .equal, toItem: boldButton, attribute: .trailing, multiplier: 1.0, constant: 0.0))

    }

    @objc func toggleBold() {
        boldButton.isSelected = !boldButton.isSelected
        if boldButton.isSelected {
            textView.typingAttributes = [NSAttributedStringKey.font.rawValue: UIFont.boldSystemFont(ofSize: 14.0)]
        } else {
            textView.typingAttributes = [NSAttributedStringKey.font.rawValue: UIFont.systemFont(ofSize: 14.0)]
        }
    }

    override func didReceiveMemoryWarning() {
        super.didReceiveMemoryWarning()
        // Dispose of any resources that can be recreated.
    }

    func textView(_ textView: UITextView, shouldChangeTextIn range: NSRange, replacementText text: String) -> Bool {
        if text.contains("\n") && boldButton.isSelected {
            toggleBold()
        }
        return true
    }

}
于 2017-12-21T21:26:43.790 回答