AVAssetExportSession.requestExportSession 回调从未调用过(swift 3,iOS10) [英] AVAssetExportSession.requestExportSession callback never called (swift 3, iOS10)

查看:47
本文介绍了AVAssetExportSession.requestExportSession 回调从未调用过(swift 3,iOS10)的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

以下代码从不调用导出回调.导出会话创建得很好.我没有看到任何错误,也没有任何进展.CPU 为 0%.我看没有例外.状态为 1(进行中),进度为 0,错误为零.视频在画廊中播放.我可以成功获得视频的图像.我已将代码提取到单个 UIViewController 中进行测试,见下文:

The following code never calls the callback for export. The export session is created just fine. I see no error, and no progress. The CPU is 0%. I see no exceptions. Status is 1 (in progress), the progress is 0, the error is nil. The video plays in the gallery. I can successfully get an image for the video. I have extracted the code into a single UIViewController for testing, see below:

我使用 iOS10.1.1 和我在 iPad 上录制的视频进行了测试.

I tested using iOS10.1.1 with a video I recorded on the iPad.

import UIKit
import Photos

class ViewController: UIViewController {

override func viewDidLoad() {
    super.viewDidLoad()
    // Do any additional setup after loading the view, typically from a nib.
}

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

// MARK: Properties
@IBOutlet weak var button: UIButton!

// MARK: Actions
@IBAction func onPress(_ sender: UIButton) {
    requestGalleryPermission() {
        (_ hasPermission: Bool) in
        if hasPermission {
            // fetch the asset from Photos
            let fetchResult = PHAsset.fetchAssets(withLocalIdentifiers: ["9FFAD8B5-0941-4A95-830F-4ACFA563B71B/L0/001"], options: nil)

            // if we successfully fetched the asset...
            if let asset = fetchResult.firstObject {

                self.exportAsset(asset)
            }
        }
    }
}

func exportAsset(_ asset: PHAsset) {
    let tempFilename = "full_sized_image.mov"
    var tempURL = URL(fileURLWithPath: NSTemporaryDirectory(), isDirectory: true).appendingPathComponent(tempFilename)
    tempURL = tempURL.standardizedFileURL


    let options = PHVideoRequestOptions()
    options.deliveryMode = .highQualityFormat
    options.isNetworkAccessAllowed = true

    // remove any existing file at that location
    do {
        try FileManager.default.removeItem(at: tempURL)
    }
    catch {
        // most likely, the file didn't exist.  Don't sweat it
    }

    PHImageManager.default().requestExportSession(forVideo: asset, options: options, exportPreset: AVAssetExportPresetHighestQuality) {
        (exportSession: AVAssetExportSession?, _) in

        if exportSession == nil {
            print("COULD NOT CREATE EXPORT SESSION")
            return
        }

        exportSession!.outputURL = tempURL
        exportSession!.outputFileType = AVFileTypeQuickTimeMovie

        print("GOT EXPORT SESSION")
        exportSession!.exportAsynchronously() {
            print("COMPLETION HANDLER!!!!")
        }

        print("progress: \(exportSession!.progress)")
        print("error: \(exportSession!.error)")
        print("status: \(exportSession!.status.rawValue)")
    }
}

func requestGalleryPermission(_ completionHandler: @escaping (_ hasPermission: Bool) -> Void) {

    let authorizationStatus = PHPhotoLibrary.authorizationStatus()
    if authorizationStatus == .denied || authorizationStatus == .restricted {
        completionHandler(false)
    }
    else if authorizationStatus == .authorized {
        completionHandler(true)
    }
    else {
        // ask for authorization
        PHPhotoLibrary.requestAuthorization({ (status: PHAuthorizationStatus) in

            // if the user gave us authorization...
            if status == .authorized {

                print("User gave authorization")

                completionHandler(true)
            }
            else {
                print("User denied authorization")

                completionHandler(false)
            }
        })
    }
}
}

推荐答案

Swift 3对我来说就像一个魅力!

Swift 3 Worked like a charm for me!

func exportVideoAsset(_ asset: PHAsset) {
    let filename = UUID().uuidString.appending(".mp4") // setting random file name

    let documentsUrl = FileManager.default.urls(for: .documentDirectory, in: .userDomainMask).first!

    do {
        var fileurl = try documentsUrl.absoluteString.appending(filename).asURL()
        print("exporting video to ", fileurl)
        fileurl = fileurl.standardizedFileURL


        let options = PHVideoRequestOptions()
        options.deliveryMode = .highQualityFormat
        options.isNetworkAccessAllowed = true

        // remove any existing file at that location
        do {
            try FileManager.default.removeItem(at: fileurl)
        }
        catch {
            // most likely, the file didn't exist.  Don't sweat it
        }

        PHImageManager.default().requestExportSession(forVideo: asset, options: options, exportPreset: AVAssetExportPresetHighestQuality) {
            (exportSession: AVAssetExportSession?, _) in

            if exportSession == nil {
                print("COULD NOT CREATE EXPORT SESSION")
                return
            }

            exportSession!.outputURL = fileurl
            exportSession!.outputFileType = AVFileTypeMPEG4 //file type encode goes here, you can change it for other types

            print("GOT EXPORT SESSION")
            exportSession!.exportAsynchronously() {
                 print("EXPORT DONE")
            }

            print("progress: \(exportSession!.progress)")
            print("error: \(exportSession!.error)")
            print("status: \(exportSession!.status.rawValue)")
        }
    }
    catch {
        // something may happend here, like no disk space
    }
}

这篇关于AVAssetExportSession.requestExportSession 回调从未调用过(swift 3,iOS10)的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆