Выделение текста и изменение атрибутов ошибка? - PullRequest
1 голос
/ 07 мая 2019

У меня проблемы с выбором простого текста и изменением атрибутов. Кажется, я не могу пройти программу после первого шага. Это говорит о том, что selectedRange ноль. Почему это происходит? Это ошибка с чем-то?

func selectText() {
    if let textRange = textView?.selectedRange {
        let attributes = [NSAttributedString.Key.font: UIFont(name: "Arial", size: 18.0)]
        textView.textStorage.addAttributes(attributes as [NSAttributedString.Key : Any], range: textRange)
    }
}

Редактирование с кодом из @DionizB (не работает)

Я вызываю его из другого файла Swift, который содержит представление для KeyboardAccessory. Код в этом файле:

class KeyboardAccessory: UIView {
let VC = ViewController()
@IBAction func boldButtonTapped(_ sender: Any) {
    print("boldButtonTapped -> Sending to bold()")
    VC.bold()
    }
}

Код теперь в главном ViewController:

var selectedRange: NSRange?

func textViewDidChangeSelection(_ textView: UITextView) {
    selectedRange = textView.selectedRange
    print(selectedRange)
}

func bold() {
    print("Starting bold()")
    print(selectedRange)
    if let textRange = selectedRange {
        print(textRange)
        let attributes = [NSAttributedString.Key.font: UIFont.systemFont(ofSize: 17, weight: UIFont.Weight.thin)]
        textView.textStorage.addAttributes(attributes as [NSAttributedString.Key : Any], range: textRange)
    }
}

textViewDidChangeSelection печатает selectedRange, но при вызове bold () из KeyboardAccessory View он печатает ноль! Как я загружаю AccessoryView.

override func viewDidLoad() {
    super.viewDidLoad()
    textView.inputAccessoryView = Bundle.main.loadNibNamed("KeyboardAccessory", owner: self, options: nil)?.first as! UIView?
}

1 Ответ

1 голос
/ 07 мая 2019

Вкл. viewDidLoad() убедитесь, что вы добавили textView.delegate = self.Также в вашем классе унаследуйте от UITextViewDelegate.

Затем позвоните вашему selectText() в textViewDidChangeSelection(_:)

func textViewDidChangeSelection(_ textView: UITextView) {
    selectText()
}

И он будет работать правильно.

РЕДАКТИРОВАТЬ Обычно это должно работать, даже когда вы вызываете ваш selectText() внутри действия кнопки.Но так как он не работает, давайте сделаем обходной путь: объявите var selectedRange: NSRange? в вашем классе.

Затем в

func textViewDidChangeSelection(_ textView: UITextView) {
    selectedRange = textView.selectedRange
}

И в вашем selectText() сделайте это

func selectText() {
    if let textRange = selectedRange {
        let attributes = [NSAttributedString.Key.font: UIFont(name: "Arial", size: 18.0)]
        textView.textStorage.addAttributes(attributes as [NSAttributedString.Key : Any], range: textRange)
    }
}

РЕДАКТИРОВАТЬ для AccessoryView

Обновите ваш KeyboardAccessory:

class KeyboardAccessory: UIView {
    var boldAction: (() -> Void)? // This is a closure, give it a read after making your button work
    @IBAction func boldButtonTapped(_ sender: Any) {
        print("boldButtonTapped -> Sending to bold()")
        boldAction?()
    }
}

Попробуйте преобразовать загруженный кончик в KeyboardAccessory и получите доступ к своему действию следующим образом:

override func viewDidLoad() {
    super.viewDidLoad()
    var keyboardAccessory = Bundle.main.loadNibNamed("KeyboardAccessory", owner: self, options: nil)?.first as! KeyboardAccessory?
    keyboardAccessory.boldAction = { [weak self] in // to avoid retain cycles, read also about these
        self?.selectText()
    }
    textView.inputAccessoryView = keyboardAccessory
}
...