도래울

UIScrollview 페이징 처리 본문

개발/iOS

UIScrollview 페이징 처리

도래울 2016. 4. 27. 14:24

UIPageControl와 UIScrollView를 이용하여 페이징 처리를 해보죠.

UIScrollView에 세개의 이미지를 좌우로 넘겨 볼수 있도록 UIPageControl을 이용해 처리하려고 합니다.

우선 Interface builder에서 Library에 있는 Scroll View와 Page Control을 View에 추가 합니다.
그리고 이를 연결할 UIScrollView와 UIPageControl을 정의 하고 
xib의 File's Owner를 클릭한 후 control버튼을 누르고 드레그하여 Scroll View, Page Control을 연결해 해당하는 Outlet을 연결합니다.

HomeView.h

#import <UIKit/UIKit.h>
@interface HomeView : UIViewController <UIScrollViewDelegate> { //UIScrollViewDelegate를 추가
    UIScrollView *scrollView;
    UIPageControl *pageControl;
}

@property(nonatomic, retain) IBOutlet UIScrollView *scrollView;
@property(nonatomic, retain) IBOutlet UIPageControl *pageControl;

@end 

  

HomeView.m

#import "HomeView.h"

@implementation HomeView
@synthesize scrollView, pageControl;

// Implement viewDidLoad to do additional setup after loading the view, typically from a nib.
- (void)viewDidLoad {
 [super viewDidLoad];
  
 // for문을 이용해 이미지를 차례로 불러와 UIImageView에 세개의 이미지를 넣는다.
 // 그 세개의 이미지가 담긴 UIImageView를 UIScrollView에 addSubview메소드를 통해서 추가한다.

 int i=0;
 for (; i<3; i++) {
  UIImage *img = [UIImage imageNamed:[NSString stringWithFormat:@"image%d.png",i+1]];
  UIImageView *imgView = [[UIImageView alloc] initWithImage:img];
  imgView.frame = CGRectMake(scrollView.frame.size.width*i, 0, scrollView.frame.size.width, scrollView.frame.size.height);
  
  [scrollView addSubview:imgView];
  [imgView release];
 }
 
 //scrollView 사이즈를 세개의 이미지가 담긴 UIImageView의 사이즈에 맞게 설정한다.
 // 즉 이미지 세개를 가로로 나열한 전체 크기라고 보면 된다.
 [scrollView setContentSize:CGSizeMake(scrollView.frame.size.width * i, scrollView.frame.size.height)];
 
 //ScrollView에 필요한 옵션을 적용한다. 
 scrollView.showsVerticalScrollIndicator=NO;
 scrollView.showsHorizontalScrollIndicator=YES;
 scrollView.alwaysBounceVertical=NO;             
 scrollView.alwaysBounceHorizontal=NO;         
 scrollView.pagingEnabled=YES;          //페이징 가능 여부 YES
 scrollView.delegate=self;
 
 //pageControl에 필요한 옵션을 적용한다.
 pageControl.currentPage =0;               //현재 페이지 index는 0
 pageControl.numberOfPages=3;          //페이지 갯수는 3개
 [pageControl addTarget:self action:@selector(pageChangeValue:) forControlEvents:UIControlEventValueChanged]; //페이지 컨트롤 값변경시 이벤트 처리 등록
 
 [self.view addSubview:pageControl];
}

//Login Button Action
-(IBAction) ActLogin:(id)sender {
 NSLog(@"Log-in Action");
}

//페이지 컨트롤 값이 변경될때, 스크롤뷰 위치 설정
- (void) pageChangeValue:(id)sender {
 UIPageControl *pControl = (UIPageControl *) sender;
 [scrollView setContentOffset:CGPointMake(pControl.currentPage*320, 0) animated:YES];
}

//스크롤이 변경될때 page의 currentPage 설정
- (void)scrollViewDidScroll:(UIScrollView *)sender {  
 CGFloat pageWidth = scrollView.frame.size.width;  
 pageControl.currentPage = floor((scrollView.contentOffset.x - pageWidth / 3) / pageWidth) + 1;  
}

- (void)didReceiveMemoryWarning {
    // Releases the view if it doesn't have a superview.
    [super didReceiveMemoryWarning];
    
    // Release any cached data, images, etc that aren't in use.
}

- (void)viewDidAppear:(BOOL)animated
{
   [scrollView flashScrollIndicators]; // 스크롤바를 보였다가 사라지게 함
}

- (void)viewDidUnload {
    [super viewDidUnload];
    
 self.scrollView = nil;
 self.pageControl = nil;
}

- (void)dealloc {
 [scrollView release];
 [pageControl release];
    [super dealloc];
}


@end

소스코드의 주석문을 참고하여 이해하자.

정리하자면 scrollView에 페이지 대상이 되는 ImageView등의 컨텐츠를 넣어서 전체 사이즈를 지정하고 
pageControl을 정의하여 pageControl 값이 변경될 때 마다 페이지 위치를 잡아주면 자연스럽게 좌우로 페이징 되는 기능을 만들 수 있다.

Comments