iOS study Day23- UIScrollView

#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

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值