2017-02-05 1 views
1

Я столкнулся странное поведение:Загрузка изображения из галереи по местному URL (Swift)

imagePicker возвращает PHAsset, и я делаю следующее, и удается представить ImageView с изображением из данных:

asset.requestContentEditingInput(with: PHContentEditingInputRequestOptions()) { (input, _) in 
    let url = input?.fullSizeImageURL 

    let imgV = UIImageView() 

    let test_url = URL(string: (url?.absoluteString)!) 

    print("><><><^^^><><>\(test_url)") 
    //prints: ><><><^^^><><>Optional(file:///var/mobile/Media/DCIM/107APPLE/IMG_7242.JPG) 
    let data = NSData(contentsOf: test_url! as URL) 
    imgV.image = UIImage(data: data! as Data) 
    imgV.backgroundColor = UIColor.cyan 

    att.imageLocalURL = url?.absoluteString//// saving the string to use in the other class 

    imgV.frame = CGRect(x: 0, y: 0, width: 100, height: 100) 

    self.view.addSubview(imgV) /// just to test that the file exists and can produce an image 

Однако, когда я делаю следующее в другом классе:

if((NSURL(string: self.attachment.imageLocalURL!) as URL!).isFileURL)// checking if is Local URL 
    { 


     let test_url = URL(string: self.attachment.imageLocalURL!) // reading the value stored from before 
     print("><><><^^^><><>\(test_url)") 
     //prints :><><><^^^><><>Optional(file:///var/mobile/Media/DCIM/107APPLE/IMG_7242.JPG) 
     let data = NSData(contentsOf: test_url! as URL) 
     imageView.image = UIImage(data: data! as Data) 

    } 

данные ноль! Что я делаю неправильно, строка для URL-адреса идентична в обоих случаях!

+0

Пробовали ли вы с точкой останова и увидеть шаг за шагом, где она производит неожиданный результат? – d00dle

+0

Класс A: url_a -> string_a -> data -> image, но класс B: string_a -> data -> nil, это неожиданное поведение. –

ответ

0

PHAsset объекты должны быть доступны через класс PHImageManager. Если вы хотите загрузить изображение синхронно я рекомендую вам сделать что-то вроде этого:

func getImage(assetUrl: URL) -> UIImage? { 
     let asset = PHAsset.fetchAssets(withALAssetURLs: [assetUrl], options: nil) 

     guard let result = asset.firstObject else { 
      return nil 
     } 
     var assetImage: UIImage? 
     let options = PHImageRequestOptions() 
     options.isSynchronous = true 
     PHImageManager.default().requestImage(for: result, targetSize: UIScreen.main.bounds.size, contentMode: PHImageContentMode.aspectFill, options: options) { image, info in 
      assetImage = image 
     } 

     return assetImage 
    } 

Можно даже написать расширение UIImageView, чтобы загрузить изображение непосредственно из URL PHAsset.

0

вар изображение: NSMutableArray = NSMutableArray() // держать неправдоподобные изображения

func fetchPhotos() 
{ 
    images = NSMutableArray() 
    //totalImageCountNeeded = 3 
    self.fetchPhotoAtIndexFromEnd(0) 
} 

func fetchPhotoAtIndexFromEnd(index:Int) 
{ 
    let status : PHAuthorizationStatus = PHPhotoLibrary.authorizationStatus() 
    if status == PHAuthorizationStatus.Authorized 
    { 
    let imgManager = PHImageManager.defaultManager() 
    let requestOptions = PHImageRequestOptions() 
    requestOptions.synchronous = true 

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

    if let fetchResult: PHFetchResult = PHAsset.fetchAssetsWithMediaType(PHAssetMediaType.Image, options: fetchOptions) 
    { 
     if fetchResult.count > 0 
     { 
       imgManager.requestImageForAsset(fetchResult.objectAtIndex(fetchResult.count - 1 - index) as! PHAsset, targetSize: CGSizeMake(self.img_CollectionL.frame.size.height/3, self.img_CollectionL.frame.size.width/3), contentMode: PHImageContentMode.AspectFill, options: requestOptions, resultHandler: { (image, _) in 
       //self.images.addObject(image!) 
       if image != nil 
       { 
        self.images.addObject(image!) 
       } 
       if index + 1 < fetchResult.count && self.images.count < 20 //self.totalImageCountNeeded 
       { 
        self.fetchPhotoAtIndexFromEnd(index + 1) 
       } 
       else 
       { 
       } 
      }) 
      self.img_CollectionL.reloadData() 

     } 
    } 
    } 
} 
Смежные вопросы