2. 목 차 뷰 스위처 애플리케이션 멀티뷰 애플리케이션의 구조 콘텐츠 뷰 해부 뷰 스위처 만들기 뷰 컨트롤러와 nib 파일 만들기 애플리케이션 델리게이트 수정하기 SwitchViewController.h MainWindow.xib 고치기 SwitchViewController.m작성하기 콘텐츠 뷰 구현하기 전환 시 애니메이션 주기
3. Introduction 아이폰의 기본 애플리케이션 중 주식 애플리케이션은 두 개의 뷰를 가지는데, 하나는 데이터를 보여주고 다른 하나로는 주식종목을 설정한다 전화 애플리케이션은 탭바를 사용하는 멀티뷰 애플리케이션의 한 예이다 메일 애플리케이션은 내비게이션 바를 사용하는 멀티뷰 애플리케이션의 예이다 아이팟 애플리케이션은 내비게이션 바와 탭바를 모두 사용한다
4. 뷰 스위처 애플리케이션 뷰 스위처를 실행한 모습 뷰 바꾸기(Switch View) 버튼 누른 후 가운데 버튼을 눌렀을 때 보여주는 경고창
5. 멀티뷰 애플리케이션의 구조 최상위 컨트롤러 애플리케이션이 실행되고 나서 사용자에게 최초로 보여지는 컨트롤러 UIViewController,UINavigationController나UITabBarController의 인스턴스가 최상위 컨트롤러로 사용 최상위 컨트롤러는 2개 이상의 뷰를 가지며 사용자의 입력에 알맞는 뷰를 보여주는 역할을 한다. 멀티뷰 애플리케이션에서 화면의 대부분은 콘텐츠 뷰로 구성 각각의 콘텐츠 뷰는 아웃렛과 액션을 포함한 자신만의 컨트롤러를 가지고 있다 일반적으로 각각의 콘텐츠 뷰들은 뷰 컨트롤러, nib, UIView의 하위클래스로 구성
6. 뷰 스위처 만들기 새 프로젝트 생성 프로젝트 이름 View Switcher, Window-based Application옵션 선택
7. 뷰 컨트롤러와 nib 파일 만들기 UIViewControllersubclass 를 선택하고XIB for user interface 옵션을 제외 두개의 .xib파일을 생성 BlueView.xib, YellowView.xib
10. MainWindow.xib 고치기 새로 추가할 클래스는 UIViewController의 하위클래스이므로 라이브러리에서 View Controller(그림)를 찾아서 nib의 메인 창에 끌어놓는다. Drag
11. MainWindow.xib 고치기 nib 메인 윈도우의 뷰 컨트롤러 아이콘을 클릭하고⌘4를 눌러 아이덴티티(identity) 인스펙터를 띄운다. UIViewController라고 되어 있는 Class 콤보박스를 클릭하고 클래스를 SwitchViewController로 바꾼다.
12. MainWindow.xib 고치기 최상위 컨트롤러의 컨텐츠 뷰는 화면 하단에 배치될 툴바로 구성 라이브러리에서 뷰를 끌어서 윈도우에 놓는다. 라이브러리에서 툴바를 집은 후 뷰의 바닥으로 끌어서 그림과 같이 만든다. 툴바 버튼을 액션 메서드에 연결 Bar Button Item의 속성 인스펙터를 연다. (⌘1) 버튼에서부터 Switch View 컨트롤러 아이콘으로 컨트롤을 누른 채로 끌어 놓고 switchViews: 액션을 고른다.
30. 콘텐츠 뷰 구현하기 BlueViewController.m #import "BlueViewController.h“ @implementation BlueViewController - (IBAction)blueButtonPressed { UIAlertView *alert = [[UIAlertViewalloc] initWithTitle:@"Blue View Button Pressed" message:@"You pressed the button on the blue view" delegate:nil cancelButtonTitle:@"Yep, I did." otherButtonTitles:nil]; [alert show]; [alert release]; } YellowViewController.m #import "YellowViewController.h“ @implementation YellowViewController -(IBAction)yellowButtonPressed { UIAlertView *alert = [[UIAlertViewalloc] initWithTitle:@"Yellow View Button Pressed" message:@"You pressed the button on the yellow view" delegate:nil cancelButtonTitle:@"Yep, I did." otherButtonTitles:nil]; [alert show]; [alert release]; } ...
31. 전환 시 애니메이션 주기 SwitchViewController.m으로 돌아간다. switchViews: 메소드를 책에 있는 새로운 코드로 바꾼다. 아이폰에서는 다음 네 개의 뷰 트랜지션을 선택할 수 있다 UIViewAnimationTransitionFlipFromLeft UIViewAnimationTransitionFlipFromRight UIViewAnimationTransitionCurlUp UIViewAnimationTransitionCurlDown
32. 전환 시 애니메이션 주기 애니메이션을 진행하는 동안 뷰의 모습이 바뀌지 않으면 항상 캐시를 사용 [UIViewsetAnimationTransition:UIViewAnimationTransitionFlipFromRightforView:self.viewcache:YES]; 트랜지션을 설정한 후 트랜지션할 때 사용하는 뷰별로 각각 한 번씩 메서드를 호출 [self.blueViewControllerviewWillAppear:YES]; [self.yellowViewControllerviewWillDisappear:YES]; 뷰 바꾸기가 끝나면 이 뷰들에 대해 두 번의 호출을 더 한다. [self.yellowViewControllerviewDidDisappear:YES]; [self.blueViewControllerviewDidAppear:YES];