UIPageController与UIScrollView的联合使用

  • (id)initWithFrame:(CGRect)frame

{

self = [super initWithFrame:frame];

if (self) {

    // Initialization code

    _backImage = [[UIImageView alloc] initWithFrame:CGRectMake(0, 0, frame.size.width, frame.size.height - 20)];

    _backImage.userInteractionEnabled = YES;

    _backImage.image = [UIImage imageNamed:@"教师讲题-互动.png"];

    [self addSubview:_backImage];



    _statisScrollView = [[UIScrollView alloc] initWithFrame:CGRectMake(7, 9, frame.size.width - 23, frame.size.height - 45)];

    _statisScrollView.contentSize = CGSizeMake(_statisScrollView.frame.size.width * 2, _statisScrollView.frame.size.height);

    _statisScrollView.backgroundColor = [UIColor clearColor];

    _statisScrollView.pagingEnabled = YES;

    _statisScrollView.showsHorizontalScrollIndicator = NO;

    _statisScrollView.delegate = self;

    [self addSubview:_statisScrollView];

    [_statisScrollView release];



    _pageControl = [[UIPageControl alloc] initWithFrame:CGRectMake(0, frame.size.height - 40, frame.size.width, 20)];

    _pageControl.backgroundColor = [UIColor clearColor];

    _pageControl.currentPage = 0;

    _pageControl.numberOfPages = 2;

    [_pageControl addTarget:self action:@selector(getChangePage:) forControlEvents:UIControlEventValueChanged];

    [self addSubview:_pageControl];

    [_pageControl release];



}

return self;

}

  • (void)getChangePage:(UIPageControl *)pageControl

{

int page = pageControl.currentPage;



CGRect frame = _statisScrollView.frame;

frame.origin.x = frame.size.width * page;//根据页数算要显示的第几页在scrollView的初始坐标

frame.origin.y = 0;

[_statisScrollView scrollRectToVisible:frame animated:YES];//根据坐标显示第几页

}

pragma mark UIScrollViewDelagete

  • (void)scrollViewDidScroll:(UIScrollView *)scrollView

{

CGFloat pageWidth = scrollView.frame.size.width;

int page = floor((scrollView.contentOffset.x - pageWidth / 2) / pageWidth) + 1;//根据坐标算页数

_pageControl.currentPage = page;//页数赋值给pageControl的当前页

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值