swift - 在 iOS 13 之后,在 pdf 上导航文本框不再工作 - 使用 PDFKIT 似乎是手势问题

标签 swift ios13 xcode11 pdfkit

我实现了一个项目,我使用 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/

相关文章:

swift - 避免在 Swift Combine 框架中强制解包

ios - 如何隐藏 View 上的状态栏

ios - 在 iOS 应用上显示计算错误时出错

Swift 枚举关联值

swift - 在 Xcode 中导入 Swift 框架 - 在哪里放置 "import"指令?

ios - 无法通过 Objective-C 在 iOS13.x 上获取 AVPlayerLayer

ios - 如何在 iOS 13 中调暗状态栏

SwiftUI:如何使用 .presentation 修饰符进行警报?出现编译器类型检查错误

swift - 更改文本值后,我的 UILabel 未更新

ios - UICollectionView didDeselectItemAt 没有被触发