我已经使用TextKit
实现了自定义文本视图。另外,我还使用UILongPressGesture
实现了自定义文本选择。在使用标准弹出菜单UIMenuController
复制所选文本方面,我已经取得了进展。
我想实现自定义文本定义。要么重写标准定义动作(甚至不知道它是否存在),要么使用自定义UIMenuItem
。
到目前为止,我有以下内容:
@objc func longTap(sender: UILongPressGestureRecognizer) {
...
becomeFirstResponder()
let copyItem = UIMenuItem(title: "Copy", action: #selector(copySelector))
let defineItem = UIMenuItem(title: "Define", action: #selector(defineSelector))
UIMenuController.shared.menuItems = [copyItem, defineItem]
UIMenuController.shared.setTargetRect(...)
UIMenuController.shared.setMenuVisible(true, animated: true)
}
override func canPerformAction(_ action: Selector, withSender sender: Any?) -> Bool {
if action == #selector(CenterViewController.copySelector) {
return true
} else if action == #selector(CenterViewController.defineSelector) {
return true
}
return false
}
....
@objc func defineSelector() {
// Use device's dictionary?
// ??
customTextView.clearSelection()
}
这是一个问题:如何实现defineSelector
?
我到处搜索过,但没有答案。 有什么方法可以使用字典和带定义的模式视图?因为它是由系统使用任何选定的文本完成的。
答案 0 :(得分:0)
没关系,我找到了解决方法:
@objc private func defineSelector() {
if let text = textToCopy {
let txt = UITextView(frame: CGRect(x: 100, y: 100, width: 100, height: 100))
txt.isHidden = true
view.addSubview(txt)
txt.text = text
txt.isEditable = false
txt.becomeFirstResponder()
txt.selectedRange = NSRange(0..<text.count)
let selector = Selector(("_define:"))
if txt.canPerformAction(selector, withSender: nil) {
txt.perform(selector, with: nil)
}
txt.removeFromSuperview()
}
customTextView.clearSelection()
}