QLPreviewController和touchesBegan方法

时间:2016-07-17 22:37:29

标签: ios objective-c swift uipangesturerecognizer touchesbegan

我正在使用Swift中的QLPreviewController。到目前为止,我能够通过将PDF添加到我的子视图中来显示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)

但我的打印方法仍未出现。

1 个答案:

答案 0 :(得分:2)

我没有声誉可以发表评论。

要回答您的问题,您正确地为QLPreviewController创建子类。但是,您的打印方法不起作用是一个完全不同的问题。任何使用QLPreviewController的手势识别器都非常困难。

如果你让它工作,请告诉我。