我正在使用Swift中的QLPreviewController。到目前为止,我可以通过将PDF添加到子视图中来显示它,而不必推动或呈现它。这使我在文档的底部有一个自定义工具栏,在顶部有一个自定义导航。

现在,我需要能够在我的QLPreviewController视图中使用touchesBegan方法。

我正在做一些研究,结果发现我需要创建QLPreviewController的子类,并重写viewDidAppear并添加UITapGestureRecognizer。

我的问题是,如何制作QLPreviewController的子类?

它看起来像这样吗?

import UIKit
import QuickLook

class QLPreview: QLPreviewController  {

    override func viewDidLoad()
    {
        //Do UITapGestureRecognizer
    }

    override func touchesBegan(touches: Set<UITouch>, withEvent event: UIEvent?)
    {
        //Touch QLPreviewController view
    }

    func detectPan(recognizer:UIPanGestureRecognizer)
    {

    }


}

这是我将QLPreviewController视图添加到子视图的方法
viewPDF = QLPreviewController()

        viewPDF.dataSource = self

        viewPDF.delegate = self

        viewPDF.view.frame = CGRectMake(0, 60, 375.0, 667.0)

        self.view.addSubview(viewPDF.view)

        viewPDF.view.userInteractionEnabled = true

        self.navigationController?.toolbarHidden = false
        self.navigationController?.navigationBarHidden = false;

这是我的委托方法
 func numberOfPreviewItemsInPreviewController(controller: QLPreviewController) -> Int {
        return 1
    }

    func previewController(controller: QLPreviewController, previewItemAtIndex index: Int) -> QLPreviewItem {

        PDFTitle.title = fileNameGroup

        let localUrl = String(format:"%@/%@", PDFFilePath, fileNameGroup)
        let url = NSURL.fileURLWithPath(localUrl)

        return url
    }

任何帮助将不胜感激

更新

这是到目前为止我得到的...我重写了我的子类,如下所示:
import UIKit
import QuickLook

class QLPreview: QLPreviewController, UIGestureRecognizerDelegate  {

    override func viewDidLoad()
    {
        super.viewDidLoad()

        self.view.frame = CGRectMake(0, 60, 375.0, 667.0)

        let panRecognizer = UIPanGestureRecognizer(target:self, action: #selector(QLPreview.detectPan))

        self.view.userInteractionEnabled = true

        self.view.addGestureRecognizer(panRecognizer)
    }

    override func touchesBegan(touches: Set<UITouch>, withEvent event: UIEvent?)
    {
        print("touching")
    }

    func detectPan(recognizer:UIPanGestureRecognizer)
    {
        print("detect")
    }

}

并像这样添加它:
let preview = QLPreview()

        preview.delegate = self
        preview.dataSource = self

        self.view.addSubview(preview.view)

但仍然没有出现我的打印方法。

最佳答案

我尚无任何评论的声誉。

为了回答您的问题,您可以正确地对QLPreviewController进行子类化。但是,您的打印方法不起作用是一个完全不同的问题。使用QLPreviewController很难获得任何手势识别器。

如果您可以使用,请告诉我。

关于ios - QLPreviewController和touchesBegan方法,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/38426588/

10-14 23:41