是否可以在 UIViewRepresentable 中使用 Coordinator 检测 PDFView 通知?
Is it possible to detect PDFView notifications with Coordinator in UIViewRepresentable?
我很难弄清楚如何使用 UIViewRepresentable 实现 PDFView。
我知道我可以通过简单的绑定从 SwiftUI -> UIKit 获取变量。
我知道我需要使用协调器来检测 PDFView 通知,例如 PDFViewPageChanged 等,然后使用绑定将数据传回。
我找不到有关如何使用协调器接收通知的示例。任何帮助将不胜感激。
谢谢
编辑
我已经尝试过 - 不幸的是我从未收到通知
func makeUIView(context: Context) -> PDFView {
let pdfView = PDFView()
pdfView.document = pdfDocument
pdfView.autoScales = true
NotificationCenter.default.publisher(for: .PDFViewPageChanged)
.map {[=10=].object as? PDFView}
.sink { (view) in
print("notification received")
}
return pdfView
}
像这样:
struct SPDFView: UIViewRepresentable {
let document: PDFDocument
@Binding var selection: String?
func makeUIView(context: Context) -> PDFView {
let view = PDFView()
view.document = document
NotificationCenter.default.publisher(for: .PDFViewSelectionChanged)
.map { [=10=].object as? PDFView }
.sink { (view) in
// or do something else
self.selection = view?.currentSelection?.string
}
.store(in: &cancellables)
// or, if you don't want to use Combine:
// NotificationCenter.default.addObserver(forName: .PDFViewSelectionChanged, object: nil, queue: nil) { (notification) in
// guard let pdfView = notification.object as? PDFView else { return }
// self.selection = pdfView.currentSelection?.string
// }
return view
}
func updateUIView(_ uiView: PDFView, context: Context) {}
}
我很难弄清楚如何使用 UIViewRepresentable 实现 PDFView。
我知道我可以通过简单的绑定从 SwiftUI -> UIKit 获取变量。
我知道我需要使用协调器来检测 PDFView 通知,例如 PDFViewPageChanged 等,然后使用绑定将数据传回。
我找不到有关如何使用协调器接收通知的示例。任何帮助将不胜感激。
谢谢
编辑
我已经尝试过 - 不幸的是我从未收到通知
func makeUIView(context: Context) -> PDFView {
let pdfView = PDFView()
pdfView.document = pdfDocument
pdfView.autoScales = true
NotificationCenter.default.publisher(for: .PDFViewPageChanged)
.map {[=10=].object as? PDFView}
.sink { (view) in
print("notification received")
}
return pdfView
}
像这样:
struct SPDFView: UIViewRepresentable {
let document: PDFDocument
@Binding var selection: String?
func makeUIView(context: Context) -> PDFView {
let view = PDFView()
view.document = document
NotificationCenter.default.publisher(for: .PDFViewSelectionChanged)
.map { [=10=].object as? PDFView }
.sink { (view) in
// or do something else
self.selection = view?.currentSelection?.string
}
.store(in: &cancellables)
// or, if you don't want to use Combine:
// NotificationCenter.default.addObserver(forName: .PDFViewSelectionChanged, object: nil, queue: nil) { (notification) in
// guard let pdfView = notification.object as? PDFView else { return }
// self.selection = pdfView.currentSelection?.string
// }
return view
}
func updateUIView(_ uiView: PDFView, context: Context) {}
}