我在故事板中有一个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的系统字体。
答案 0 :(得分:0)
只有你需要的是typingAttributes
,如果我清楚地了解你想要实现的目标。在\n
到replacementText
出现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
}
}