func viewPhotoDetalController(index: Int) -> PhotoDetailViewController? {
if let storyboard = storyboard,
detailController = storyboard.instantiateViewControllerWithIdentifier("PhotoDetail")
as? PhotoDetailViewController {
//loadPhoto()
return detailController
}
return nil
}
, когда по экрану влево или вправо, в UIPageViewController
называется код выше, перед возвращением detailController Я хочу, чтобы загрузить фото и установить переменную фото detailController как этоКак загрузить изображение в ИО UIPageViewController
func loadPhoto (index:Int) {
let imgManager = PHCachingImageManager()
imgManager.requestImageForAsset(self.devicePhotosAsset[self.index] as! PHAsset, targetSize: PHImageManagerMaximumSize, contentMode: .AspectFit, options: nil, resultHandler: {(result, info) -> Void in
// set the detailController's photo here
})
}
, но проблема requestImageForAsset
- это асинхронный api, к тому времени, когда фото загрузится, возвращается функция detailController. также тип возвращаемого requestImageForAsset
API, если недействительным, так что я не могу сделать что-то вроде
imgManager.requestImageForAsset(self.devicePhotosAsset[self.index] as! PHAsset, targetSize: PHImageManagerMaximumSize, contentMode: .AspectFit, options: nil, resultHandler: {(result, info) -> Void in
detailController.photo = result
return detailController
})
так, как я могу установить переменную фото detailController в?
здесь полный код detailController, я следую за UIScrollView Аркадам here
import UIKit
import Photos
class PhotoDetailViewController : UIViewController {
@IBOutlet weak var scrollView: UIScrollView!
@IBOutlet weak var imageViewBottomConstraint: NSLayoutConstraint!
@IBOutlet weak var imageViewLeadingConstraint: NSLayoutConstraint!
@IBOutlet weak var imageViewTopConstraint: NSLayoutConstraint!
@IBOutlet weak var imageViewTrailingConstraint: NSLayoutConstraint!
var devicePhotosAsset : PHFetchResult!
var index = 0
var photo : UIImage!
@IBOutlet weak var imageView : UIImageView!
override func viewDidLoad() {
super.viewDidLoad()
self.displayPhoto()
}
override func viewDidLayoutSubviews() {
super.viewDidLayoutSubviews()
updateMinZoomScaleForSize(view.bounds.size)
}
func displayPhoto() {
let imgManager = PHCachingImageManager()
_ = imgManager.requestImageForAsset(self.devicePhotosAsset[self.index] as! PHAsset, targetSize: PHImageManagerMaximumSize, contentMode: .AspectFit, options: nil, resultHandler: {(result, info) -> Void in
self.imageView.image = result
})
}
private func updateMinZoomScaleForSize(size: CGSize) {
let widthScale = size.width/imageView.bounds.width
let heightScale = size.height/imageView.bounds.height
let minScale = min(widthScale, heightScale)
scrollView.minimumZoomScale = minScale
scrollView.zoomScale = minScale
}
private func updateConstraintsForSize(size: CGSize) {
let yOffset = max(0, (size.height - imageView.frame.height)/2)
imageViewTopConstraint.constant = yOffset
imageViewBottomConstraint.constant = yOffset
let xOffset = max(0, (size.width - imageView.frame.width)/2)
imageViewLeadingConstraint.constant = xOffset
imageViewTrailingConstraint.constant = xOffset
view.layoutIfNeeded()
}
}
extension PhotoDetailViewController: UIScrollViewDelegate {
func viewForZoomingInScrollView(scrollView: UIScrollView) -> UIView? {
return imageView
}
func scrollViewDidZoom(scrollView: UIScrollView) {
updateConstraintsForSize(view.bounds.size)
}
}
Почему вы не выполнить загрузку логики изображения внутри DetailViewController? –