iOS-OC之相册,可以放大,不能循环查看
2016-01-12 20:57
423 查看
#import "ViewController.h"
#define kuan [UIScreen mainScreen].bounds.size.width#define gao [UIScreen mainScreen].bounds.size.height@interface ViewController ()<UIScrollViewDelegate>@property (weak, nonatomic) IBOutlet UIScrollView *huaKuang;
@end
@implementation ViewController
- (void)viewDidLoad { [super viewDidLoad]; //设置contentSize _huaKuang.contentSize=CGSizeMake((kuan)*4, gao); _huaKuang.backgroundColor=[UIColor blackColor]; //设置分页 _huaKuang.pagingEnabled=YES; //隐藏滚动条 //滚动时是否显示水平滚动条 _huaKuang.showsHorizontalScrollIndicator=NO; //滚动时是否显示垂直滚动条 _huaKuang.showsVerticalScrollIndicator=NO; //设置代理,需要遵循代理协议<UIScrollViewDelegate>,写在@interface ViewController ()的后面 _huaKuang.delegate=self; //添加子视图,因为是多个所以写了一个方法来实现添加 [self tianJianZiShiTu];}-(void)tianJianZiShiTu{ //假如有六个图片,就要创建六个UIScrollView和六个UIImageView,并且找到六个图片 for(int i=0;i<3;i++) { //创建UIScrollView //为了区分开不同的照片加一个20黑边,需要设置ScrollViewscroll View中的Left和View中的Width UIScrollView *uisv=[[UIScrollView alloc] initWithFrame:CGRectMake((kuan+20)*i, 0, kuan, gao)]; //把创建完成的添加到总的那个UIScrollView上 [_huaKuang addSubview:uisv]; //创建UIImageView UIImageView *uiiv=[[UIImageView alloc] initWithFrame:CGRectMake(0, 0, kuan, gao)]; //把创建的UIImageView添加到UIScrollView中 [uisv addSubview:uiiv]; //设置UIImageView的图片 NSString *imageName = [NSString stringWithFormat:@"new_feature_%d",i + 1]; uiiv.image=[UIImage imageNamed:imageName]; //设置tag值 uiiv.tag=1000; //设置UIScrollView的代理 uisv.delegate=self; //设置缩放范围 uisv.minimumZoomScale=0.5; uisv.maximumZoomScale=1.5; //定义点击事件 UITapGestureRecognizer *tap=[[UITapGestureRecognizer alloc] initWithTarget:self action:@selector(dianJiShiJian:)]; //设置有效点击数(就是双击) tap.numberOfTapsRequired=2; //添加到UIScrollView中 [uisv addGestureRecognizer:tap]; }}-(void)dianJiShiJian:(UITapGestureRecognizer *)tap{ //获取点击事件的view UIScrollView *uisv1=(UIScrollView *)tap.view; if(uisv1.zoomScale!=1.0) { [uisv1 setZoomScale:1.0 animated:YES]; return ; } CGPoint location=[tap locationInView:tap.view]; CGRect rect=CGRectMake(location.x-100, location.y-100, 200, 200); [uisv1 zoomToRect:rect animated:YES];}//指定缩放的视图-(UIView *)viewForZoomingInScrollView:(UIScrollView *)scrollView{ if (scrollView == _huaKuang) { return nil; } UIImageView *imageView = (UIImageView *)[scrollView viewWithTag:1000]; return imageView;}
//滚动结束,把所有的缩放视图的缩放比例置为1.0-(void)scrollViewDidEndDecelerating:(UIScrollView *)scrollView{ if (scrollView == _huaKuang) { for (id obj in _huaKuang.subviews) { if ([obj isKindOfClass:[UIScrollView class]]) { UIScrollView *scaleSC = (UIScrollView *)obj; scaleSC.zoomScale = 1.0; } } }}- (void)didReceiveMemoryWarning { [super didReceiveMemoryWarning];}
@end
#define kuan [UIScreen mainScreen].bounds.size.width#define gao [UIScreen mainScreen].bounds.size.height@interface ViewController ()<UIScrollViewDelegate>@property (weak, nonatomic) IBOutlet UIScrollView *huaKuang;
@end
@implementation ViewController
- (void)viewDidLoad { [super viewDidLoad]; //设置contentSize _huaKuang.contentSize=CGSizeMake((kuan)*4, gao); _huaKuang.backgroundColor=[UIColor blackColor]; //设置分页 _huaKuang.pagingEnabled=YES; //隐藏滚动条 //滚动时是否显示水平滚动条 _huaKuang.showsHorizontalScrollIndicator=NO; //滚动时是否显示垂直滚动条 _huaKuang.showsVerticalScrollIndicator=NO; //设置代理,需要遵循代理协议<UIScrollViewDelegate>,写在@interface ViewController ()的后面 _huaKuang.delegate=self; //添加子视图,因为是多个所以写了一个方法来实现添加 [self tianJianZiShiTu];}-(void)tianJianZiShiTu{ //假如有六个图片,就要创建六个UIScrollView和六个UIImageView,并且找到六个图片 for(int i=0;i<3;i++) { //创建UIScrollView //为了区分开不同的照片加一个20黑边,需要设置ScrollViewscroll View中的Left和View中的Width UIScrollView *uisv=[[UIScrollView alloc] initWithFrame:CGRectMake((kuan+20)*i, 0, kuan, gao)]; //把创建完成的添加到总的那个UIScrollView上 [_huaKuang addSubview:uisv]; //创建UIImageView UIImageView *uiiv=[[UIImageView alloc] initWithFrame:CGRectMake(0, 0, kuan, gao)]; //把创建的UIImageView添加到UIScrollView中 [uisv addSubview:uiiv]; //设置UIImageView的图片 NSString *imageName = [NSString stringWithFormat:@"new_feature_%d",i + 1]; uiiv.image=[UIImage imageNamed:imageName]; //设置tag值 uiiv.tag=1000; //设置UIScrollView的代理 uisv.delegate=self; //设置缩放范围 uisv.minimumZoomScale=0.5; uisv.maximumZoomScale=1.5; //定义点击事件 UITapGestureRecognizer *tap=[[UITapGestureRecognizer alloc] initWithTarget:self action:@selector(dianJiShiJian:)]; //设置有效点击数(就是双击) tap.numberOfTapsRequired=2; //添加到UIScrollView中 [uisv addGestureRecognizer:tap]; }}-(void)dianJiShiJian:(UITapGestureRecognizer *)tap{ //获取点击事件的view UIScrollView *uisv1=(UIScrollView *)tap.view; if(uisv1.zoomScale!=1.0) { [uisv1 setZoomScale:1.0 animated:YES]; return ; } CGPoint location=[tap locationInView:tap.view]; CGRect rect=CGRectMake(location.x-100, location.y-100, 200, 200); [uisv1 zoomToRect:rect animated:YES];}//指定缩放的视图-(UIView *)viewForZoomingInScrollView:(UIScrollView *)scrollView{ if (scrollView == _huaKuang) { return nil; } UIImageView *imageView = (UIImageView *)[scrollView viewWithTag:1000]; return imageView;}
//滚动结束,把所有的缩放视图的缩放比例置为1.0-(void)scrollViewDidEndDecelerating:(UIScrollView *)scrollView{ if (scrollView == _huaKuang) { for (id obj in _huaKuang.subviews) { if ([obj isKindOfClass:[UIScrollView class]]) { UIScrollView *scaleSC = (UIScrollView *)obj; scaleSC.zoomScale = 1.0; } } }}- (void)didReceiveMemoryWarning { [super didReceiveMemoryWarning];}
@end
相关文章推荐
- JS 相册效果 自动播放[本地整合]
- jquery实现相册一下滑动两次的方法
- 用dom+xhtml+css制作的一个相册效果代码打包下载
- jQuery实现带滚动导航效果的全屏滚动相册实例
- js+css实现上下翻页相册代码分享
- android照相、相册获取图片剪裁报错的解决方法
- Android相册效果(使用C#和Java分别实现)
- Android实现调用系统相册和拍照的Demo示例
- 相册cache目录
- Android高手进Android ViewPager控件的使用(基于ViewPager的横向相册)!!!
- android调用系统相机与系统相册
- 中国现代教育个人体会
- csdn 我还真没想到
- Dreamweaver架设网站高级教程
- UCenter HOME 数据调用小技巧
- 免费硬盘
- 继续寻找创业伙伴:重新设计SNS——交友篇
- 陪我看细水长流吧 、
- MP3、MP4、MP5、PSP
- [组图]DB2技术专家沙龙活动(北京站)圆满结束