Подтвердить что ты не робот

Соединение с активами было прервано или активы умерли

Загружаю фотографии из PHAssets. Я получаю этот журнал ошибок, когда загружаю некоторые изображения и передаю их другому контроллеру. Я не могу найти что-нибудь в Интернете об этом. Кто-нибудь сталкивается с этим и знает, что это такое?

Я также получаю эту ошибку вместе с ней:

***** Error: logging directory does not exist /var/mobile/Library/Logs/CrashReporter/DiagnosticLogs/
4b9b3361

Ответ 1

Может быть следующая причина:

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

2.) Также избегать создания слишком большого количества свойств для хранения изображений.

3.) Если нам нужно отправить изображение в другое представление, попробуйте сжать его.

Ответ 2

оставив это здесь, надеясь, что это может помочь:

импортировать фотографии

import Photos

затем в вашем info.plist добавьте описание использования фото, это обязательно из соображений конфиденциальности

создать и очистить массив данных, как это

var imgData = [Data]()

затем в вашей проверке viewdidload для авторизации, как это

if PHPhotoLibrary.authorizationStatus() == .authorized{
        print("already allowed")
        getImages()
    }else{
        PHPhotoLibrary.requestAuthorization { [weak self] (newStatus) in
            if newStatus == .authorized{
                print(newStatus)
                self?.getImages()
            }else{
                print("not accepted")
            }
        }
    }

создать функцию

func getImages(){
        let assetCollection = PHAssetCollection.fetchAssetCollections(with: .smartAlbum, subtype: .smartAlbumDepthEffect, options: nil).firstObject!
            let result = PHAsset.fetchAssets(in: assetCollection, options: nil)
        result.enumerateObjects { (ph_asset, int, unsafe_mutable_pointer) in
            PHImageManager.default().requestImageData(for: ph_asset, options: nil, resultHandler: { (data, string, image_orientation, info) in
                self.imageData.append(data!)
                self.imageString.append(string!)
                DispatchQueue.main.async {
                    self.myCollectionView.reloadData()
                }
            })
        }
    }

расширить вид контроллера, как показано ниже

extension ViewController: UICollectionViewDataSource, UICollectionViewDelegate{
func collectionView(_ collectionView: UICollectionView, numberOfItemsInSection section: Int) -> Int {
    print(imageData.count)
    return imageData.count
}

func collectionView(_ collectionView: UICollectionView, cellForItemAt indexPath: IndexPath) -> UICollectionViewCell {
    let cell = collectionView.dequeueReusableCell(withReuseIdentifier: "cell", for: indexPath) as! CustomCVCell
    cell.myImageView.image = UIImage(data: imageData[indexPath.row])
    return cell
}

func collectionView(_ collectionView: UICollectionView, didSelectItemAt indexPath: IndexPath) {
    print(indexPath.item)
    print(imageString[indexPath.item])
    if let dvc = storyboard?.instantiateViewController(withIdentifier: "Detail") as? DetailViewController{
        dvc.data = imageData[indexPath.item]
        navigationController?.pushViewController(dvc, animated: true)
    }}}

проблема может быть в том, что вы передаете изображение, но если вы передаете данные, это сработает, в вашем контроллере detailview сделайте это

@IBOutlet weak var myImageView: UIImageView!{
    didSet{
        myImageView.image = UIImage(data: data!)
    }
}