Лучший способ получить тысячи изображений из телефонов фото галерея Swift 5 - PullRequest
0 голосов
/ 06 ноября 2019

Я пытаюсь создать приложение с функцией загрузки изображений. Я хочу создать экран, который загружает все изображения, которые могут быть более 1000 изображений из галереи фотографий. А затем загрузить все те, что в представлении коллекции отсортированы и сгруппированы по дате.

Я пробовал пакетную загрузку, но она не работает, загружается только первая партия. Есть ли другой способ сделать это? Есть ли урок, на который я могу сослаться?

 var myCollectionView: UICollectionView!
    var photosDict = Dictionary<String,[Photo]>()
    var photoAssets: PHFetchResult<PHAsset>?
    let itemsPerBatch = 20
    var batchNumber = 0

   func grabPhotos() {
        DispatchQueue.global(qos: .background).async {
            let imgManager=PHImageManager.default()

            let requestOptions=PHImageRequestOptions()
            requestOptions.isSynchronous=true
            requestOptions.deliveryMode = .highQualityFormat

            let fetchOptions=PHFetchOptions()
            fetchOptions.sortDescriptors=[NSSortDescriptor(key:"creationDate", ascending: false)]

            self.photoAssets = PHAsset.fetchAssets(with: .image, options: fetchOptions)

            self.loadMorePhotos(imgManager: imgManager, requestOptions: requestOptions)

            self.batchNumber = self.batchNumber + 1
        }
    }


    func loadMorePhotos(imgManager: PHImageManager, requestOptions: PHImageRequestOptions) {
        photosDict.removeAll()
        let formatter = DateFormatter()
        formatter.dateFormat = "dd-MMM-yyyy"

        if let photoAssetsUW = self.photoAssets, photoAssetsUW.count > 0 {
            print(photoAssetsUW)
            print(photoAssetsUW.count)
            for i in (self.batchNumber * self.itemsPerBatch)..<(self.itemsPerBatch * (self.batchNumber + 1)) {
                if i < photoAssetsUW.count {
                    let photoAsset = photoAssetsUW.object(at: i)
                    if let creationDate = photoAsset.creationDate {
                        let stringDate = formatter.string(from: creationDate)
                        var imageURL: String = ""
                        photoAsset.requestContentEditingInput(with: PHContentEditingInputRequestOptions()) { (eidtingInput, info) in
                            if let input = eidtingInput, let imgURL = input.fullSizeImageURL {
                                imageURL = imgURL.absoluteString
                            }
                        }

                        imgManager.requestImage(for: photoAssetsUW.object(at: i) , targetSize: CGSize(width:500, height: 500),contentMode: .aspectFill, options: requestOptions, resultHandler: { (image, error) in
                            if let imageUW = image {
                                if self.photosDict[stringDate] == nil {
                                    self.photosDict[stringDate] = [Photo(image: imageUW,imagePath: imageURL)]
                                } else {
                                    self.photosDict[stringDate]?.append(Photo(image: imageUW,imagePath: imageURL))
                                }
                            }
                        })
                    }
                }
            }
        } else {
            print("You got no photos.")
        }
        print("photosDict count: \(self.photosDict.count) \(self.photosDict)")

        DispatchQueue.main.async {
            self.myCollectionView.reloadData()
        }
    }

 func collectionView(_ collectionView: UICollectionView, cellForItemAt indexPath: IndexPath) -> UICollectionViewCell {
        let keys = Array(photosDict.keys).sorted(by: <)
        let currentKey = keys[indexPath.section]
        let imageList = photosDict[currentKey]
        if indexPath.row == imageList?.count {
            let cell = collectionView.dequeueReusableCell(withReuseIdentifier: "Cell", for: indexPath) as! PhotoItemCell

            let requestOptions=PHImageRequestOptions()
            requestOptions.isSynchronous=true
            requestOptions.deliveryMode = .highQualityFormat

            loadMorePhotos(imgManager: PHImageManager.default(), requestOptions: requestOptions)
            return cell
        }


        let cell=collectionView.dequeueReusableCell(withReuseIdentifier: "Cell", for: indexPath) as! PhotoItemCell
        cell.img.image = imageList?[indexPath.row].image
        return cell
    }

Я хочу создать экран, который будет выглядеть точно так же, как приложение Apple Photos, и загружать все изображения и видео из приложения фотографий.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...