UIScrollView实现图片放大、缩小
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了UIScrollView实现图片放大、缩小,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含2124字,纯文字阅读大概需要4分钟。
内容图文

UIScrollView实现图片放大、缩小
一、 在storyboard中添加Scroll View或者用懒加载创建 UIScrollView
- (
UIScrollView
*)scrollView
{
if ( _scrollView == nil ) {
_scrollView = [[ UIScrollView alloc ] initWithFrame : self . view . bounds ];
// 设置代理
_scrollView . delegate = self ;
// 设置最大 / 最小缩放比例
_scrollView . maximumZoomScale = 2.0 ;
_scrollView . minimumZoomScale = 0.2 ;
[ self . view addSubview : _scrollView ];
}
return _scrollView ;
}
// 让图像视图根据图像自动调整大小
[ self . imageView sizeToFit ];
// 告诉 scrollView 内部内容的实际大小
self . scrollView . contentSize = image. size ;
}
{
if ( _scrollView == nil ) {
_scrollView = [[ UIScrollView alloc ] initWithFrame : self . view . bounds ];
// 设置代理
_scrollView . delegate = self ;
// 设置最大 / 最小缩放比例
_scrollView . maximumZoomScale = 2.0 ;
_scrollView . minimumZoomScale = 0.2 ;
[ self . view addSubview : _scrollView ];
}
return _scrollView ;
}
注意:
UIScrollView的frame大小和父窗口view的frame大小一致
二、把
imageView懒加载添加到
UIScrollView
- (
UIImageView
*)imageView
{
if ( _imageView == nil ) {
_imageView = [[ UIImageView alloc ] init ];
[ self . scrollView addSubview : _imageView ];
}
return _imageView ;
}
{
if ( _imageView == nil ) {
_imageView = [[ UIImageView alloc ] init ];
[ self . scrollView addSubview : _imageView ];
}
return _imageView ;
}
三、设置图片
//
图像的
setter
- ( void )setImage:( UIImage *)image
{
_image = image;
// 设置图像视图的内容
self . imageView . image = image;
- ( void )setImage:( UIImage *)image
{
_image = image;
// 设置图像视图的内容
self . imageView . image = image;
// 让图像视图根据图像自动调整大小
[ self . imageView sizeToFit ];
// 告诉 scrollView 内部内容的实际大小
self . scrollView . contentSize = image. size ;
}
注意:
设置
图像视图根据图像自动调整大小,因为
UIImageView的frame没有设置。
[ self . imageView sizeToFit ];
[ self . imageView sizeToFit ];
告诉
scrollView
内部内容的实际大小
self . scrollView . contentSize = image. size ;
self . scrollView . contentSize = image. size ;
self
.
scrollView和_
scrollView的区别。
四、设置图像
- (
void
)viewDidLoad
{
[ super viewDidLoad ];
// 设置图像
self . image = [ UIImage imageNamed : @"minion" ];
}
{
[ super viewDidLoad ];
// 设置图像
self . image = [ UIImage imageNamed : @"minion" ];
}
五、实现
UIScrollView的代理方法
#pragma mark - UIScrollView
的代理方法
/**
1> 设置了代理
2> 指定了最大、最小的缩放比例
表示 ScrollView 是可以缩放的
代理方法的 " 返回值 " 实际上就是控制器告诉滚动视图,要缩放的是 UIImageView
*/
// 告诉 ScrollView 要缩放的视图是谁,具体的缩放实现,是由 ScrollView 来完成的
// 1> scrollView 要知道缩放谁
- ( UIView *)viewForZoomingInScrollView:( UIScrollView *)scrollView
{
return self . imageView ;
}
// 2> 滚动视图即将开始缩放,通常不需要写
- ( void )scrollViewWillBeginZooming:( UIScrollView *)scrollView withView:( UIView *)view
{
NSLog ( @"%s" , __func__);
}
// 3> 正在缩放,通常也不需要实现
- ( void )scrollViewDidZoom:( UIScrollView *)scrollView
{
// NSLog(@"%s", __func__);
NSLog ( @"%@" , NSStringFromCGAffineTransform ( self . imageView . transform ));
}
// 4> 完成缩放,通常也不需要实现
- ( void )scrollViewDidEndZooming:( UIScrollView *)scrollView withView:( UIView *)view atScale:( CGFloat )scale
{
NSLog ( @"%s" , __func__);
}
/**
1> 设置了代理
2> 指定了最大、最小的缩放比例
表示 ScrollView 是可以缩放的
代理方法的 " 返回值 " 实际上就是控制器告诉滚动视图,要缩放的是 UIImageView
*/
// 告诉 ScrollView 要缩放的视图是谁,具体的缩放实现,是由 ScrollView 来完成的
// 1> scrollView 要知道缩放谁
- ( UIView *)viewForZoomingInScrollView:( UIScrollView *)scrollView
{
return self . imageView ;
}
// 2> 滚动视图即将开始缩放,通常不需要写
- ( void )scrollViewWillBeginZooming:( UIScrollView *)scrollView withView:( UIView *)view
{
NSLog ( @"%s" , __func__);
}
// 3> 正在缩放,通常也不需要实现
- ( void )scrollViewDidZoom:( UIScrollView *)scrollView
{
// NSLog(@"%s", __func__);
NSLog ( @"%@" , NSStringFromCGAffineTransform ( self . imageView . transform ));
}
// 4> 完成缩放,通常也不需要实现
- ( void )scrollViewDidEndZooming:( UIScrollView *)scrollView withView:( UIView *)view atScale:( CGFloat )scale
{
NSLog ( @"%s" , __func__);
}
原文:http://blog.csdn.net/itcontend/article/details/41858009
内容总结
以上是互联网集市为您收集整理的UIScrollView实现图片放大、缩小全部内容,希望文章能够帮你解决UIScrollView实现图片放大、缩小所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。
来源:【匿名】