#define kCount 5
#import "WViewController.h"
@interface WViewController ()
@property (weak,nonatomic) UIImageView* imgview;
@property (weak, nonatomic) UIPageControl* control;
@property (weak, nonatomic) UIScrollView* scroll;
@end
@implementation WViewController
- (void)viewDidLoad
{
[super viewDidLoad];
[self scrollViewTest];
}
- (void)scrollViewTest
{
CGRect frame = self.view.frame;
// scroll 构造函数
UIScrollView* scroll = [[UIScrollView alloc] initWithFrame:frame];
[self.view addSubview:scroll];
UIImage *imgsango = [UIImage imageNamed:@"tun2map"];
UIImageView* imgview = [[UIImageView alloc] initWithImage:imgsango];
imgview.frame = CGRectMake(0, 0, imgsango.size.width* 2, imgsango.size.height*2);
[scroll addSubview:imgview];
// 设置内容大小
scroll.contentSize = imgview.frame.size;
// 设置屏幕中图像出现的坐标原点
scroll.contentOffset = CGPointMake(1500, 1000);
// 设置内容外边距
scroll.contentInset = UIEdgeInsetsMake(100, 100, 100, 100);
//
self.imgview = imgview;
//<UIScrollViewDeligate> 代理连线
scroll.delegate = self;
// 设置缩放大小 前提实现<UIScrollViewDeligate>
scroll.maximumZoomScale = 3;
scroll.minimumZoomScale = 0.3;
// 下一个案例: 添加图片组至ScrollView并实现滚动翻页效果
CGFloat scrollWdith = scroll.frame.size.width;
CGFloat scrollHeight = scroll.frame.size.height;
_scroll = scroll;
// 添加ImageView
for (int i = 1; i<=kCount; i++) {
NSString *imageName = [NSString stringWithFormat:@"pages.bundle/%d.jpg", i];
UIImage *image = [UIImage imageNamed:imageName];
UIImageView *imageView = [[UIImageView alloc] init];
imageView.image = image;
CGFloat x = (i - 1) * scrollWdith;
imageView.frame = CGRectMake(x, 0, scrollWdith, scrollHeight);
[scroll addSubview:imageView];
}
// 设置滚动范围
scroll.contentSize = CGSizeMake(kCount * scrollWdith, 0);
// 隐藏水平滚动条
scroll.showsHorizontalScrollIndicator = NO;
// 开启分页功能 实现以ScrollWidth为页的分页功能
scroll.pagingEnabled = YES;
// 添加PageControl
UIPageControl *pageControl = [[UIPageControl alloc] init];
// 设置大小
pageControl.bounds = CGRectMake(0, 0, 150, 50);
// 设置中心点
pageControl.center = CGPointMake(scrollWdith * 0.5, scrollHeight - 50);
// 设置页数
pageControl.numberOfPages = kCount;
// 当前选中页码的颜色
pageControl.currentPageIndicatorTintColor = [UIColor redColor];
// 其他页码的颜色
pageControl.pageIndicatorTintColor = [UIColor blackColor];
// 页码改变了ValueChange,就会调用self的pageChange方法
[pageControl addTarget:self action:@selector(pageChange) forControlEvents:UIControlEventValueChanged];
// 添加到控制器的view
[self.view addSubview:pageControl];
_control = pageControl;
// 设置代理连线 <UIScrollViewDeligate>
scroll.delegate = self;
// 不需要弹簧效果
scroll.bounces = NO;
}
// 实现<UIScrollViewDeligate>协议的方法-- 返回缩放的对象 ,必须是scrollView的子对象
-(UIView *)viewForZoomingInScrollView:(UIScrollView *)scrollView
{
return self.imgview;
}
// scrollview减速完毕DidEndDecelerating<UIScrollViewDeligate>
- (void)scrollViewDidEndDecelerating:(UIScrollView *)scrollView
{
// 计算页码
int pageNo = scrollView.contentOffset.x/scrollView.frame.size.width;
// 设置页码
_control.currentPage = pageNo;
}
- (void)pageChange
{
CGFloat offsetX = _control.currentPage * self.view.frame.size.width;
[UIView beginAnimations:nil context:nil];
// 设置滚动位置
_scroll.contentOffset = CGPointMake(offsetX, 0);
[UIView commitAnimations];
}
@end
iOS study Day23- UIScrollView
最新推荐文章于 2016-04-05 09:37:15 发布