首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >QLPreviewController和touchesBegan方法

QLPreviewController和touchesBegan方法
EN

Stack Overflow用户
提问于 2016-07-18 06:37:29
回答 1查看 735关注 0票数 2

我在斯威夫特和QLPreviewController一起工作。到目前为止,我可以通过将PDF添加到我的子视图中来显示它,而不是推送或呈现它。这允许我在文档底部有一个自定义工具栏,在顶部有一个自定义导航。

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

我做了一些研究,发现我需要创建一个QLPreviewController的子类,覆盖viewDidAppear并添加一个UITapGestureRecognizer。

我的问题是,如何创建QLPreviewController的子类?

它看起来像这样吗?

代码语言:javascript
复制
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视图添加到子视图中

代码语言:javascript
复制
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;

下面是我的委托方法

代码语言:javascript
复制
 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
    }

任何帮助都将不胜感激

更新

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

代码语言:javascript
复制
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")
    }

}

并像这样添加:

代码语言:javascript
复制
let preview = QLPreview()

        preview.delegate = self
        preview.dataSource = self

        self.view.addSubview(preview.view)

但是我的print方法仍然没有出现。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2016-07-20 00:08:59

我还没有名气来发表评论。

为了回答您的问题,您正确地划分了QLPreviewController的子类。但是,打印方法不起作用则是一个完全不同的问题。让任何手势识别器与QLPreviewController一起工作是非常困难的。

如果你把它修好了,请告诉我。

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/38426588

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档