0

私のシナリオ:

ダウンローダー オブジェクト関数を非同期的に呼び出して、ファイルのダウンロードを試みます。

ダウンローダの関数内で、ダウンロードのための接続を非同期に開始します。

それでも、UI 要素を操作できません。

たとえば、ダウンロードの進行中にテキスト フィールドを編集できません。

ダウンロード中に UI 要素を操作できるようにしたいと考えています。

どこで見逃したのですか?私は何をすべきか?本当にありがとうございました!


非同期ダウンロード用の ViewController のスニペット

//relevant UI elements I am referring to
@IBOutlet var renderButton: UIButton!
@IBOutlet var urlField: UITextField!

func handleOpenURL(url: NSURL){
    var downloader: aDownloader = aDownloader(url: url)

    //I try to put download to background thread
    dispatch_async(dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_BACKGROUND, 0), {() -> Void in

        //This function initiates a connection call in an attempt to download the file
        downloader.executeConnection({ 
            (dataURL:NSURL!,error:NSError!) -> Void in  

                 dispatch_async(dispatch_get_main_queue(), { () -> Void in
                    self.imageView.image = UIImage(data:NSData(contentsOfURL: url)!)
                 })

                 //rest are nonsense
            }, progress: { (percentage:Double) -> Void in
                 //nonsense
            }
        )

     })
}

関連するコードの aDownloader.swift のスニペット

class aDownloader: NSObject, allOtherProtocols {
    unowned var url: NSURL

    //this block reports the progress as a % number 
    var progressBlock : ((Double)->Void)?

    //this block will return either the destinationFileURL after download finishes,
    //or return error of any sort
    var dataBlock: ((NSURL!,NSError!)->Void)?

    init(url: NSURL) {
        self.url = url
    }

    func executeConnection(received:(NSURL!,NSError!)->Void, progress:(Double)->Void){
        var request : NSURLRequest = NSURLRequest(URL: self.url, 
                                                  cachePolicy: .ReloadIgnoringLocalCacheData,
                                                  timeoutInterval: 60.0)

        //I attempt to async-ly download the file here
        dispatch_async(dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_BACKGROUND, 0), { () -> Void in
            var connectionManager : NSURLConnection? = NSURLConnection(request:request, 
                                                                       delegate: self, 
                                                                       startImmediately: false)
            connectionManager?.scheduleInRunLoop(NSRunLoop.mainRunLoop(), 
                                                 forMode: NSRunLoopCommonModes)
            connectionManager?.start()
        })

        self.dataBlock = received
        self.progressBlock = progress
    }

    //nonsense
}
4

1 に答える 1