iOS UI-UIScrollView控件实现图片缩放功能
一、縮放
1.簡單說明:
有些時候,我們可能要對某些內(nèi)容進行手勢縮放,如下圖所示
?
UIScrollView不僅能滾動顯示大量內(nèi)容,還能對其內(nèi)容進行縮放處理。也就是說,要完成縮放功能的話,只需要將需要縮放的內(nèi)容添加到UIScrollView中
2.縮放原理
當用戶在UIScrollView身上使用捏合手勢時,UIScrollView會給代理發(fā)送一條消息,詢問代理究竟要縮放自己內(nèi)部的哪一個子控件(哪一塊內(nèi)容)
當用戶在UIScrollView身上使用捏合手勢時,UIScrollView會調(diào)用代理的viewForZoomingInScrollView:方法,這個方法返回的控件就是需要進行縮放的控件。
二、實現(xiàn)縮放功能
1.代碼示例:
1 #import "YYViewController.h"2 3 @interface YYViewController () <UIScrollViewDelegate>4 {5 UIScrollView *_scrollview;6 UIImageView *_imageview;7 }8 @end9 10 @implementation YYViewController 11 12 - (void)viewDidLoad 13 { 14 [super viewDidLoad]; 15 16 //1添加 UIScrollView 17 //設(shè)置 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)使用構(gòu)造方法 30 UIImage *image=[UIImage imageNamed:@"minion"]; 31 _imageview=[[UIImageView alloc]initWithImage:image]; 32 //調(diào)用initWithImage:方法,它創(chuàng)建出來的imageview的寬高和圖片的寬高一樣 33 [_scrollview addSubview:_imageview]; 34 35 //設(shè)置UIScrollView的滾動范圍和圖片的真實尺寸一致 36 _scrollview.contentSize=image.size; 37 38 39 //設(shè)置實現(xiàn)縮放 40 //設(shè)置代理scrollview的代理對象 41 _scrollview.delegate=self; 42 //設(shè)置最大伸縮比例 43 _scrollview.maximumZoomScale=2.0; 44 //設(shè)置最小伸縮比例 45 _scrollview.minimumZoomScale=0.5; 46 47 } 48 49 //告訴scrollview要縮放的是哪個子控件 50 -(UIView *)viewForZoomingInScrollView:(UIScrollView *)scrollView 51 { 52 return _imageview; 53 } 54 55 @end2.代碼說明
實現(xiàn)縮放功能的4個步驟
(1)為scrollview設(shè)置代理(self)
(2)讓控制器遵守scrollview的代理協(xié)議
(3)調(diào)用代理方法,返回需要實現(xiàn)縮放功能的子控件
(4)設(shè)置縮放的范圍(最大和最小比例)
3.思路:
a.需要告訴scrollview要縮放的時哪一個子控件,這里為scrollview內(nèi)部的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];
? ??調(diào)用initWithImage:方法,它創(chuàng)建出來的imageview的寬高和圖片的寬高一樣
? ? [_scrollviewaddSubview:_imageview];
四、跟縮放相關(guān)的其他代理方法
縮放完畢的時候調(diào)用?
- (void)scrollViewWillBeginZooming:(UIScrollView?*)scrollView withView:(UIView?*)view
正在縮放的時候調(diào)用
- (void)scrollViewDidZoom:(UIScrollView?*)scrollView
轉(zhuǎn)載于:https://www.cnblogs.com/oc-bowen/p/5096962.html
總結(jié)
以上是生活随笔為你收集整理的iOS UI-UIScrollView控件实现图片缩放功能的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 计算机网络之网络层:11、移动IP
- 下一篇: vijos1055 奶牛浴场