当按下键盘上的返回键时,UITextView不记得字体样式

时间:2017-10-14 14:21:47

标签: swift uitextview nsattributedstring nstextstorage

我在故事板中有一个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编辑效果。当我按下" {}"图标,我处于"可编码模式"。当按下键盘进入键盘时,它恢复正常。

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

1 个答案:

答案 0 :(得分:0)

只有你需要的是typingAttributes,如果我清楚地了解你想要实现的目标。在\nreplacementText出现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
    }

}