iOS开发UI篇—UIScrollView控件实现图片缩放功能
来源:互联网 发布:波风水门实力 知乎 编辑:程序博客网 时间:2024/05/16 12:50
一、缩放
1.简单说明:
有些时候,我们可能要对某些内容进行手势缩放,如下图所示
UIScrollView不仅能滚动显示大量内容,还能对其内容进行缩放处理。也就是说,要完成缩放功能的话,只需要将需要缩放的内容添加到UIScrollView中
2.缩放原理
当用户在UIScrollView身上使用捏合手势时,UIScrollView会给代理发送一条消息,询问代理究竟要缩放自己内部的哪一个子控件(哪一块内容)
当用户在UIScrollView身上使用捏合手势时,UIScrollView会调用代理的viewForZoomingInScrollView:方法,这个方法返回的控件就是需要进行缩放的控件。
二、实现缩放功能
1.代码示例:
1 #import "YYViewController.h" 2 3 @interface YYViewController () <UIScrollViewDelegate> 4 { 5 UIScrollView *_scrollview; 6 UIImageView *_imageview; 7 } 8 @end 9 10 @implementation YYViewController11 12 - (void)viewDidLoad13 {14 [super viewDidLoad];15 16 //1添加 UIScrollView17 //设置 UIScrollView的位置与屏幕大小相同18 _scrollview=[[UIScrollView alloc]initWithFrame:self.view.bounds];19 [self.view addSubview:_scrollview];20 21 //2添加图片22 //有两种方式23 //(1)一般方式24 // UIImageView *imageview=[[UIImageView alloc]init];25 // UIImage *image=[UIImage imageNamed:@"minion"];26 // imageview.image=image;27 // imageview.frame=CGRectMake(0, 0, image.size.width, image.size.height);28 29 //(2)使用构造方法30 UIImage *image=[UIImage imageNamed:@"minion"];31 _imageview=[[UIImageView alloc]initWithImage:image];32 //调用initWithImage:方法,它创建出来的imageview的宽高和图片的宽高一样33 [_scrollview addSubview:_imageview];34 35 //设置UIScrollView的滚动范围和图片的真实尺寸一致36 _scrollview.contentSize=image.size;37 38 39 //设置实现缩放40 //设置代理scrollview的代理对象41 _scrollview.delegate=self;42 //设置最大伸缩比例43 _scrollview.maximumZoomScale=2.0;44 //设置最小伸缩比例45 _scrollview.minimumZoomScale=0.5;46 47 }48 49 //告诉scrollview要缩放的是哪个子控件50 -(UIView *)viewForZoomingInScrollView:(UIScrollView *)scrollView51 {52 return _imageview;53 }54 55 @end
2.代码说明
实现缩放功能的4个步骤
(1)为scrollview设置代理(self)
(2)让控制器遵守scrollview的代理协议
(3)调用代理方法,返回需要实现缩放功能的子控件
(4)设置缩放的范围(最大和最小比例)
3.思路:
a.需要告诉scrollview要缩放的时哪一个子控件,这里为scrollview内部的imageview控件
b.谁来告诉scrollview缩放哪一个控件?代理
三、补充知识
两种实例化UIImageView的方法:
第一种:
UIImageView *imageview=[[UIImageView alloc]init];
UIImage *image=[UIImage imageNamed:@"minion"];
imageview.image=image;
imageview.frame=CGRectMake(0, 0, image.size.width, image.size.height);
第二种:
UIImage *image=[UIImage imageNamed:@"minion"];
_imageview=[[UIImageViewalloc]initWithImage:image];
调用initWithImage:方法,它创建出来的imageview的宽高和图片的宽高一样
[_scrollviewaddSubview:_imageview];
四、跟缩放相关的其他代理方法
缩放完毕的时候调用
- (void)scrollViewWillBeginZooming:(UIScrollView *)scrollView withView:(UIView *)view
正在缩放的时候调用
- (void)scrollViewDidZoom:(UIScrollView *)scrollView
- iOS开发UI篇—UIScrollView控件实现图片缩放功能
- iOS开发UI篇—UIScrollView控件实现图片缩放功能
- iOS开发UI篇—UIScrollView控件实现图片缩放功能
- IOS开发UI篇—UIScrollView控件实现图片缩放功能
- iOS开发UI篇—UIScrollView控件实现图片缩放功能
- iOS开发UI篇—UIScrollView控件实现图片缩放功能
- iOS开发UI基础—17UIScrollView控件实现图片缩放功能
- UIScrollView控件实现图片缩放功能
- UIScrollView控件实现图片缩放功能
- iOS开发UI篇—UIScrollView控件实现图片轮播
- iOS开发UI篇—UIScrollView控件实现图片轮播
- iOS开发UI篇—UIScrollView控件实现图片轮播
- iOS开发UI篇—UIScrollView控件实现图片轮播
- iOS开发UI篇—UIScrollView控件实现图片轮播
- iOS开发UI基础—29UIScrollView控件实现图片轮播
- UIScrollView控件实现缩放功能
- iOS - UIScrollView控件实现图片缩放功能(还需补充代码)
- iOS开发UI篇—UIScrollView控件介绍
- 第一次邂逅快速傅立叶变换(FFT)
- 字符串的二进制存储读取
- mysql 优化之 profile
- LeetCode OJ: 9. Palindrome Number (C++)
- sqlserver2008r2数据库关联孤立账号的方法
- iOS开发UI篇—UIScrollView控件实现图片缩放功能
- Leetcode之combination-sum-ii
- FFT原理及实现
- 墨菲定律、二八法则、马太效应、手表定理、“不值得”定律、彼得原理、零和游戏、华盛顿合作规律、酒与污水定律、水桶定律、蘑菇管理原理、钱的问题、奥卡姆剃刀等13条是左右人生的金科玉律
- 上传图片,为什么在本地wamp上的图片上传正常,移动到服务器上就出现问题了?
- Android从按下开机键到启动发生了什么
- 【java】字符串查找
- MYSQL启用日志,和查看日志
- Eclipse一直在computing additional info