我正在尝试将 Apple Pencil 与 WKWebView 集成。
期望的行为:
- 使用铅笔可以让您在网页上绘制所有精美的 PencilKit 集成(PKToolPicker 等)
- 使用手指可以滚动浏览网页,并且滚动会同步到 webview。
取 2
因此,在花费了更多时间之后,我得出了一个非常hacky的解决方案,我实际上并不喜欢这个解决方案:
- 在它上面创建一个
WKWebView
和一个透明PKCanvasView
的。 - 覆盖
hitTest
`PKCanvasView 以始终返回 nil。 drawingGestureRecognizer
将 PKCanvasView添加到WKWebView
- 确保
drawingGestureRecognizer.allowedTouchTypes = [NSNumber(value: UITouch.TouchType.pencil.rawValue)]
为PKCanvasView
这种方法有效,但它消除了实施的大量灵活性。
拿 1
到目前为止,我尝试了两种方法:
当我检测到它来自手指时,选择性地取消画布上的用户输入。这不起作用,因为在视图消耗事件之前我无法检测到这一点。
创建一个透明的超级视图,并在我进行检测时为 PKCanvasView 和 WKWebView 手动调用 touchesBegan/touchesMoved/touchesEnded。不幸的是,这也不起作用,因为调用这些方法没有做任何事情。
这是我到目前为止的一些基本代码:
struct SUICanvasView: UIViewControllerRepresentable {
let url: URL?
func makeUIViewController(context: Context) -> ZRCanvasReader {
let canvasReader = ZRCanvasReader()
canvasReader.openUrl(url: url)
return canvasReader
}
func updateUIViewController(_ uiViewController: ZRCanvasReader, context: Context) {
}
typealias UIViewControllerType = ZRCanvasReader
}
class ZRCanvasReader: UIViewController {
lazy var canvas: PKCanvasView = {
let v = PKCanvasView()
v.isOpaque = false
v.backgroundColor = .clear
return v
}()
lazy var toolPicker: PKToolPicker = {
let toolPicker = PKToolPicker()
return toolPicker
}()
lazy var webView: WKWebView = {
let prefs = WKWebpagePreferences()
prefs.allowsContentJavaScript = true
let config = WKWebViewConfiguration()
config.defaultWebpagePreferences = prefs
let webview = WKWebView(frame: .zero, configuration: config)
return webview
}()
override func viewDidLoad() {
super.viewDidLoad()
view.addSubview(webView)
view.addSubview(canvas)
webView.frame = view.frame
canvas.frame = view.frame
toolPicker.addObserver(canvas)
toolPicker.setVisible(true, forFirstResponder: canvas)
}
func openUrl(url: URL?) {
guard let loadingUrl = url else {
return
}
let request = URLRequest(url: loadingUrl)
webView.load(request)
}
}