我实现了一个项目,我使用 PDFKIT 来做一些如何在 pdf 上添加一个 float 文本框,它可以通过用户触摸屏幕使用 GestureRecognizer
进行导航,以移动和放置用户决定的位置。它在 iOS 13 之前运行良好,但在它之后,它不给你移动文本框的机会,我尝试了很多方法来解决它但都失败了。
问题似乎与 GestureRecognizer
有关,但我不确定,而且我真的不知道如何解决它。我在 github 上做这个项目 https://github.com/kishikawakatsumi/BookReader并尝试以某种方式扩展它。
这是我的代码项目,我插入了整个函数,我知道这看起来有点复杂。对此真的很抱歉。但是,如果您认为它可能来自手势识别器,只需查看属于这些功能的代码即可。
func getPDFFrame(todo: String)
{
let pdfSubVws = pdfView.subviews
print("subVws ",pdfSubVws)
for subVws in pdfSubVws
{
if (String(describing: subVws).range(of:"UIPageViewControllerContentView") != nil)
{
let pageVc = subVws.subviews
for subVws in pageVc
{
if (String(describing: subVws).range(of:"UIQueuingScrollView") != nil)
{
let QueueVc = subVws.subviews
// print("QueueVcQueueVc ", QueueVc)
for subVws in QueueVc
{
if (String(describing: subVws).range(of:"UIView") != nil)
{
let viewVc = subVws.subviews
print("\n\nviewVcVcQueueVc ", viewVc) //viewVcVcQueueVc []
for subVws in viewVc
{
if (String(describing: subVws).range(of:"UIView") != nil)
{
let SubviewVc = subVws.subviews
// print("\n\nSubviewVcSubviewVc ", SubviewVc)
for subVws in SubviewVc
{
if (String(describing: subVws).range(of:"UIScrollView") != nil)
{
let finalVw = subVws.subviews
// print("\n\nfinalVw ", finalVw)
//
for subVws in finalVw
{
if (String(describing: subVws).range(of:"UIView") != nil)
{
// print("subVwssubVws ", subVws)
let pagView = subVws.subviews
// pdfLandingView =
for subVws in pagView
{
// print("\n\n EndVwssubVws ", subVws)
if (String(describing: subVws).range(of:"PDFPageView") != nil)
{
let pageLandVw = subVws.subviews
print("\n\n WasVwssubVws ", pageLandVw)
// hideBars()
// Myedit()
for subVws in pageLandVw
{
if (String(describing: subVws).range(of:"UITextView") != nil)
{
print("dddddddd")
let txtVw = subVws as! UITextView
if todo == "firstResponder"
{
let rect = pdfView.currentPage?.bounds(for: .mediaBox)
usingHeightText = txtVw.frame.size.height
usingWidthText = txtVw.frame.size.width
let xPoint = txtVw.frame.origin.x
let yPoint = (rect?.height)! - (txtVw.frame.origin.y) - txtVw.frame.size.height
lastTextAnnoPoint = CGPoint(x: xPoint, y: yPoint)
findHavingTextAnnotation(annoPoint: CGPoint(x: xPoint, y: yPoint))
// txtVw.contentInset = UIEdgeInsetsMake(0, 10, 0, 0)
print("C_Sz ", txtVw.contentSize)
print("C_Off ", txtVw.contentOffset)
let widthMoveView = UIView(frame: CGRect(x: txtVw.frame.size.width - 20, y: 0, width: 20, height: txtVw.frame.size.height))
widthMoveView.backgroundColor = UIColor.brown.withAlphaComponent(0.0)
widthMoveView.tag = 333
let wdImgVw = UIImageView()
wdImgVw.frame.origin.x = 0
wdImgVw.frame.origin.y = 8
wdImgVw.frame.size.width = 20 // widthMoveView.frame.width
wdImgVw.frame.size.height = 20 // widthMoveView.frame.height
wdImgVw.contentMode = .scaleAspectFit
wdImgVw.image = UIImage(named: "widthLeftRight")
wdImgVw.layer.cornerRadius = 10
// wdImgVw.backgroundColor = UIColor.orange
widthMoveView.addSubview(wdImgVw)
txtVw.addSubview(widthMoveView)
//
let tapVw = UIPanGestureRecognizer(target: self, action: #selector(self.handleWidthTapVw(_:)))
widthMoveView.addGestureRecognizer(tapVw)
}
else
//....and here I am going to omit the other parts of my codes
这里我将省略我的代码的其他部分,因为似乎问题出现在这行代码中
for subVws in finalVw
这里是我代码的其他部分,不确定你是否需要它
let linkAnn = PDFAnnotation.init(bounds: CGRect(x: 150, y: 450, width: 180, height: usingHeightText), forType: PDFAnnotationSubtype.widget, withProperties: nil)
linkAnn.widgetFieldType = .text
linkAnn.isMultiline = true
linkAnn.contents = "fileNumber\(pdfClickedRow)PageNumber\(getPagenumber)addtext\(AddTextCount)" //"\(AddTextCount)"
linkAnn.widgetStringValue = NSLocalizedString("placeholder", comment: "")
linkAnn.font = UIFont(name: usingFontName, size: CGFloat(usingFontSize))
linkAnn.fontColor = usingFontColor
linkAnn.backgroundColor = usingBGFontColor.withAlphaComponent(usingBGFontAlpha)
linkAnn.setValue("addtext\(AddTextCount)", forAnnotationKey: PDFAnnotationKey.name)
// print("linkAnn.cont ",linkAnn.contents)
let index = pdfDocument?.index(for: pdfView.currentPage!)
pdfView.document?.page(at: index!)?.addAnnotation(linkAnn)
var createdColorDict = [String : Any]()
createdColorDict["BGColor"] = usingBGFontColor
createdColorDict["BGOpacity"] = usingBGFontAlpha
textAnnoStoredDict["fileNumber\(pdfClickedRow)PageNumber\(getPagenumber)addtext\(AddTextCount)"] = createdColorDict
// pdfView.currentPage?.addAnnotation(linkAnn)
bottomColorView.isHidden = true
bottomColorView.backgroundColor = UIColor(red: 0/255, green: 0/255, blue: 0/255, alpha: 1.0)
sideWidthHeightVw.backgroundColor = UIColor(red: 240/255, green: 240/255, blue: 240/255, alpha: 1.0)
sideWidthHeightVw.isHidden = true
barHideOnTapGestureRecognizer.isEnabled = false
hideBars()
NotificationCenter.default.addObserver(self, selector: #selector(keyboardWillShow),
name: NSNotification.Name.UIKeyboardWillShow, object: nil)
//keyboardWillShow
最佳答案
通过查看您的代码,我很难理解可能是什么问题。这是我的高级建议: 1. 首先备份您的代码,以确保您可以恢复到稳定状态。 2. 开始将代码切成两半——每次都去掉一半的逻辑路径。例如:不使用 PDF View ,而是使用带有文本框的常规 View (以查明问题是否出在 PDF View 上)。不要使用 UITextField,而只使用 UIView 来查看它是否是 UITextField 的问题。
基本上逐渐消除所有复杂性,直到剩下一段允许您移动文本字段的简单代码。
另外:避免使用这么长的方法。我尝试将方法减少到最多 30 行,以及最多 2 层嵌套。否则,您将拥有比您能够维护或理解的更多的逻辑路径...
您还依赖字符串作为对象类型。这是脆弱的。也许有另一种方法可以找到 PDF View ,而不是为它爬取整个 View 层次结构并检查字符串? (它们未经编译器检查,因此 future 的任何更改或操作系统/第三方版本之间的更改都会破坏您的代码)。
如果您的文本字段根本没有移动,请尝试删除您对框架所做的所有数学运算,然后使用手势识别器将其移动到任何坐标(例如:200、200),只需看到有东西将文本字段固定到位(如约束)。你有可以持有它的约束吗?使用“ View 检查器”来检查和验证 View 是如何嵌入的以及它上面/下面的内容。是否有任何东西可以拦截对您的手势识别器的触摸?它是否接收到触摸并触发它的事件?您需要更准确地描述问题所在...请在此处参阅我的回答以了解检查手势识别器本身的内容。 UIPanGestureRecognizer is not working in iOS 13
这个 PDF View 的 View 层次结构非常复杂,很难说它里面的其他 Touch 事件会发生什么。 (除非您确切了解第三方 PDF View 的工作原理)。我会尝试找出问题所在,无论它是否与 PDF View 有关。首先让它在常规 View 中工作。然后使用 hitTest 在 PDF View 上工作,并在其中放置打印语句,以查看谁在竞争 HIT 测试。
关于swift - 在 iOS 13 之后,在 pdf 上导航文本框不再工作 - 使用 PDFKIT 似乎是手势问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58609831/