Please note, this blog entry is from a previous course. You might want to check out the current one.
When the user then chooses a particular photo from the list, display it inside a UIScrollView that allows the user to pan and zoom.
Like in the previous task, you can safe some time be reusing code from Shutterbug.
In storyboard drag out a new view controller. Create a new subclass for it and link them. Add a scroll view and provide an outlet for it in the new class:
@property (weak, nonatomic) IBOutlet UIScrollView *scrollView;
Create a push segue from the cell of the second table to the new view controller and set its identifier to “Show Image”:
Create a public property to hold the URL of the image:
@property (nonatomic, strong) NSURL *imageURL;
… and a private property to actually hold the image view and initialize it lazily:
@property (strong, nonatomic) UIImageView *imageView; ... - (UIImageView *)imageView { if (!_imageView) { _imageView = [[UIImageView alloc] initWithFrame:CGRectZero]; } return _imageView; }
When ever somebody changes this URL, reset the image.
- (void)setImageURL:(NSURL *)imageURL { _imageURL = imageURL; [self resetImage]; }
Finally the controller needs to be declared as delegate for the scroll view:
@interface ImageViewController () <UIScrollViewDelegate> ... - (void)viewDidLoad { [super viewDidLoad]; [self.scrollView addSubview:self.imageView]; self.scrollView.minimumZoomScale = 0.2; self.scrollView.maximumZoomScale = 5.0; self.scrollView.delegate = self; [self resetImage]; }
… and the table view controller needs to set the correct photo:
- (void)prepareForSegue:(UIStoryboardSegue *)segue sender:(id)sender { if ([sender isKindOfClass:[UITableViewCell class]]) { NSIndexPath *indexPath = [self.tableView indexPathForCell:sender]; if (indexPath) { if ([segue.identifier isEqualToString:@"Show Image"]) { if ([segue.destinationViewController respondsToSelector:@selector(setImageURL:)]) { NSURL *url = [FlickrFetcher urlForPhoto:self.photos[indexPath.row] format:FlickrPhotoFormatLarge]; [segue.destinationViewController performSelector:@selector(setImageURL:) withObject:url]; [segue.destinationViewController setTitle:[self titleForRow:indexPath.row]]; } } } } }
Before you do so, check if there is a scroll view – which there is not when the view is not on screen yet, e.g. when preparing a segue … Resetting means removing an old image and its settings in the scroll view, loading it and setting the new properties:
- (void)resetImage { if (self.scrollView) { self.scrollView.contentSize = CGSizeZero; self.imageView.image = nil; NSData *imageData = [[NSData alloc] initWithContentsOfURL:self.imageURL]; UIImage *image = [[UIImage alloc] initWithData:imageData]; if (image) { self.scrollView.zoomScale = 1.0; self.scrollView.contentSize = image.size; self.imageView.image = image; self.imageView.frame = CGRectMake(0, 0, image.size.width, image.size.height); } } }
The complete code is available on github.
data:image/s3,"s3://crabby-images/0463e/0463e68a5d77bbec630deb1cc37d4d49d1933e77" alt="Share on Facebook Facebook"
data:image/s3,"s3://crabby-images/93960/93960774b56bccf62f288efe326475d585239d8b" alt="Share on Twitter twitter"
data:image/s3,"s3://crabby-images/0c920/0c920341ab12cbcb5a3b1d2fb88f22374f2db577" alt="Share on Reddit reddit"
data:image/s3,"s3://crabby-images/d89b8/d89b80500f1626baf2ffa1e4369c261e01677d36" alt="Pin it with Pinterest pinterest"
data:image/s3,"s3://crabby-images/e9270/e92707689a9d88fc53f343370506e7f2aaedb7d1" alt="Share on Linkedin linkedin"
data:image/s3,"s3://crabby-images/f159f/f159fb333858fef1148f2a558ee7fa6a6881800a" alt="Share on tumblr tumblr"
data:image/s3,"s3://crabby-images/c7ab2/c7ab2f6c43fffe17aac7f185fd64ee95565487b9" alt="Share by email mail"
data:image/s3,"s3://crabby-images/6d85a/6d85a390df03e0c75624ac0579180ad35a62eeac" alt="Share on Facebook Facebook"
data:image/s3,"s3://crabby-images/e5f0c/e5f0cd4639d7b3d76b66c05981935f6c2bb06c71" alt="Share on Twitter twitter"
data:image/s3,"s3://crabby-images/40b77/40b7752481674a140035def4b6339fa4accc753f" alt="Share on Reddit reddit"
data:image/s3,"s3://crabby-images/1393f/1393f0291ffd80beac5e1f70b986671c6635d8b7" alt="Pin it with Pinterest pinterest"
data:image/s3,"s3://crabby-images/aa22d/aa22de91a0cd30772c623a5c7979ee81fe426013" alt="Share on Linkedin linkedin"
data:image/s3,"s3://crabby-images/5dc32/5dc32b39b30592e11870503bb4e8e715d50b21a0" alt="Share on tumblr tumblr"
data:image/s3,"s3://crabby-images/56655/56655b42634351b14f9d7507dacc4e33f64b90af" alt="Share by email mail"
Thanks for sharing! Just a note… As stated in lecture 9, I guess a delegate method to specify view to zoom is missing. I added the code below and the zoom worked fine:
– (UIView *)viewForZoomingInScrollView:(UIScrollView *)sender
{
return self.imageView;
}
Thanks again!