Скачивание аудио файлов - PullRequest
       65

Скачивание аудио файлов

0 голосов
/ 20 сентября 2018

У меня есть аудиоприложение с несколькими контроллерами, контроллером VCMain, в котором отображаются все книги и контроллер VCBook о книге, в которой есть функция загрузки аудиофайлов (книга может иметь много файлов).

При нажатии на кнопку загрузки появляется круглый индикатор выполнения.

Как сделать так, чтобы, когда я возвращаюсь в VCMain и возвращаюсь к загруженной книге, у меня были все необходимые данныедля настроек индикатора выполнения (какие книги все еще загружаются или они загружаются вообще).Я могу одновременно скачать несколько книг

var progressIndicatorView:CircularProgressView!
lazy var sizeBytes:Int64 = 0
lazy var dowloandedSizeBytes:Int64 = 0


@objc func progressBar(){
    DispatchQueue.main.async {
        self.progressIndicatorView = CircularProgressView(frame: CGRect(x: 5, y: -20, width: 50, height: 50))
        self.view.addSubview(self.progressIndicatorView)
        self.download.isEnabled = false
        self.download.isHidden = true

    }

}

@objc func downloadBook(){

    progressBar()

    for i in UrlName{

        Func.getDownloadSize(url: URL(string: i)!, completion: { [weak self] (size, error) in
            self!.sizeBytes += size
        })

        if let audioUrl = URL(string: i) {
            // create your document folder url
            let documentsUrl = try! FileManager.default.url(for: .documentDirectory, in: .userDomainMask, appropriateFor: nil, create: true)
            // your destination file url
            let destination = documentsUrl.appendingPathComponent(audioUrl.lastPathComponent)
            // check if it exists before downloading it
            if FileManager().fileExists(atPath: destination.path) {
                print("The file already exists at path")
                bookMarkLoad()
                Func.getDownloadSize(url: URL(string: i)!, completion: { [weak self] (size, error) in
                    self!.dowloandedSizeBytes += size
                })
            } else {
                //  if the file doesn't exist
                //  just download the data from your url
                var url = URLRequest(url: audioUrl)
                url.timeoutInterval = Double.infinity
                let config = URLSessionConfiguration.background(withIdentifier: i)
                let session = URLSession(configuration: config, delegate: self, delegateQueue: nil)
                let task = session.downloadTask(with: url)
                task.taskDescription = String(format:"%@" , i )
                task.resume()
                registerBackgroundTask()
              //  let _ = Timer.scheduledTimer(timeInterval: 0.5, target: self, selector: #selector(backgraundState), userInfo: nil, repeats: true)
            }
        }
    }
}


func urlSession(_ session: URLSession, downloadTask: URLSessionDownloadTask, didWriteData bytesWritten: Int64, totalBytesWritten: Int64, totalBytesExpectedToWrite: Int64) {
    if UrlName.contains(downloadTask.taskDescription!){
        if totalBytesExpectedToWrite > 0 {
            dowloandedSizeBytes += bytesWritten
            let progress = Float(dowloandedSizeBytes) / Float(sizeBytes)
            //  print("Progress \(downloadTask) \(progress)")
            DispatchQueue.main.async {
                if self.progressIndicatorView != nil {
                    self.progressIndicatorView.progress = CGFloat(progress)
                }
            }
        }

    }

}

1 Ответ

0 голосов
/ 20 сентября 2018

Это довольно широкий вопрос, но я бы предложил начать с перемещения всей логики, связанной с загрузкой, в отдельный сервис.Рекомендуется хранить такую ​​логику в стороне от ваших представлений / контроллеров представлений.

Эта служба будет отвечать за загрузку и может уведомлять другие части приложений (например, viewcontrollers) о ходе выполнения, например, с помощью уведомлений.

Затем MainVC может запросить информацию о состоянии у службы и обновить представление, например, методом viewWillAppear(_:).

Некоторые примеры того, как начать структурирование вашего приложения и сервисов, можно найти по адресу:

...