OGeek|极客世界-中国程序员成长平台

标题: ios - previewController previewItemAt 未被调用。 iOS 10,swift 3,模拟器 [打印本页]

作者: 菜鸟教程小白    时间: 2022-12-11 19:12
标题: ios - previewController previewItemAt 未被调用。 iOS 10,swift 3,模拟器

我在 Storyboard中创建了一个新的 View Controller 。将其连接到 ListViewController。 ListViewController 将正确的数据填入aboutDict[String:Any]。构建 fileURLs[] 并调用 func numberOfPreviewItems(in: QLPreviewController) -> Int - 调试器显示 fileURLs[] 为预期:

Printing description of self.fileURLs: ▿ 1 element - 0 : file:///Users/kent/Library/Developer/CoreSimulator/Devices/5E23825C-DF99-455A-BEB1-F73398E7759F/data/Containers/Bundle/Application/307ED7DF-C07C-4C0A-BA78-938BABE7C22C/WINSystemInfo.app/ID-51A_E_PLUS2.pdf`

但是 func previewController(_ controller: QLPreviewController, previewItemAt index: Int) -> QLPreviewItemfunc previewController(_ controller: QLPreviewController, shouldOpen url: URL, for item: QLPreviewItem) -> Bool 不被调用。

我得到了一个不错的 ViewController,它被插入导航堆栈,并带有正确的后退按钮名称,以及一个带有居中文本“没有要预览的文件”的灰色页面。

按下“返回”按钮时,会调用 func previewControllerWillDismiss(_ controller: QLPreviewController)。所以一些的委托(delegate)和数据源函数正在被调用。

我一定错过了一些简单的东西......

我在下面附加了我的类 FileViewController.swift:

class FileViewController: QLPreviewController, QLPreviewControllerDelegate, QLPreviewControllerDataSource {

    var aboutDict = [String: Any]()

    // QuickLook data
    var fileURLs = [QLPreviewItem]()

    // MARK: - Lifecycle

    override func viewDidLoad() {
        super.viewDidLoad()
        let filename = aboutDict["filename"] as! String?
        let filetype = aboutDict["filetype"] as! String?

        title = aboutDict["title"] as! String?
        dataSource = self
        delegate = self

        if let fileUrl = Bundle.main.url(forResource: filename, withExtension: filetype, subdirectory: nil, localization: nil)
        {
            let filePreview = fileUrl as QLPreviewItem
            fileURLs.append(filePreview)
        }
    }

    override func didReceiveMemoryWarning() {
        super.didReceiveMemoryWarning()
        // Dispose of any resources that can be recreated.
    }

    // MARK: - Preview controller datasource  functions

    func numberOfPreviewItems(in: QLPreviewController) -> Int {
        return fileURLs.count
    }

    func previewController(_ controller: QLPreviewController, previewItemAt index: Int) -> QLPreviewItem {
        return fileURLs[index]
    }

    // MARK: - Preview controller delegate functions

    func previewControllerWillDismiss(_ controller: QLPreviewController) {
        debug("previewControllerWillDismiss")
    }

    func previewController(_ controller: QLPreviewController, shouldOpen url: URL, for item: QLPreviewItem) -> Bool {
        return true
    }
}

我错过了什么?

谢谢。



Best Answer-推荐答案


我刚遇到这个问题,只是因为我忘记在 QLPreviewController 上设置我的数据源...

关于ios - previewController previewItemAt 未被调用。 iOS 10,swift 3,模拟器,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/42711699/






欢迎光临 OGeek|极客世界-中国程序员成长平台 (http://ogeek.cn/) Powered by Discuz! X3.4