>– (BOOL) application:(UIApplication *)application
>didFinishLaunchingWithOptions:(NSDictionary *)launchOptions{
>FirstViewController *viewController = [[FirstViewController alloc]
>initWithNibName: nil
>bundle: nil];
>self.navigationController = [[UINavigationController alloc]
>initWithRootViewController: viewController];
>self.window = [[UIWindow alloc]
>initWithFrame: [[UIScreen mainScreen] bounds]];
>self.window.rootViewController = self.navigationController;
>self.window.backgroundColor = [UIColor whiteColor];
>[self.window makeKeyAndVisible];
>return YES;
>}
После этого запустим приложение в эмуляторе (рис. 1.33).
Рис. 1.33. Пустой контроллер вида, отображаемый внутри навигационного контроллера
Файл реализации корневого контроллера вида создает кнопку в центре экрана (как показано на рис. 1.33). Чуть позже мы изучим этот файл реализации.
На рис. 1.33 мы в первую очередь замечаем полосу в верхней части экрана. Теперь экран уже не чисто-белый. Что это за новый виджет? Это навигационная панель. Мы будем активно пользоваться ею при навигации, например разместим на ней кнопки и сделаем кое-что еще. Кроме того, на этой панели удобно отображать заголовок. Каждый контроллер вида сам для себя указывает заголовок, а навигационный контроллер будет автоматически отображать заголовок того контроллера вида, который окажется на верхней позиции в стеке.
Переходим к файлу реализации корневого контроллера нашего вида в методе viewDidLoad. В качестве свойства контроллера вида укажем First Controller. Здесь же создадим кнопку. Когда пользователь нажмет эту кнопку, мы отобразим на экране второй контроллер вида:
>#import "FirstViewController.h"
>#import "SecondViewController.h"
>@interface FirstViewController ()
>@property (nonatomic, strong) UIButton *displaySecondViewController;
>@end
>@implementation FirstViewController
>– (void) performDisplaySecondViewController:(id)paramSender{
>SecondViewController *secondController = [[SecondViewController alloc]
>initWithNibName: nil
>bundle: NULL];
>[self.navigationController pushViewController: secondController
>animated: YES];
>}
>– (void)viewDidLoad{
>[super viewDidLoad];
>self.title = @"First Controller";
>self.displaySecondViewController = [UIButton
>buttonWithType: UIButtonTypeSystem];
>[self.displaySecondViewController
>setTitle:@"Display Second View Controller"
>forState: UIControlStateNormal];
>[self.displaySecondViewController sizeToFit];
>self.displaySecondViewController.center = self.view.center;
>[self.displaySecondViewController
>addTarget: self
>action:@selector(performDisplaySecondViewController:)
>forControlEvents: UIControlEventTouchUpInside];
>[self.view addSubview: self.displaySecondViewController];
>}
>@end
А теперь создадим второй контроллер вида, уже без файла XIB, и назовем его SecondViewController. Проделайте тот же процесс, что был показан в разделе 1.9. Когда создадите этот контроллер вида, назовите его Second Controller:
>#import "SecondViewController.h"
>@implementation SecondViewController
>– (void)viewDidLoad{
>[super viewDidLoad];
>self.title = @"Second Controller";
>}
Теперь мы собираемся всплыть из второго контроллера вида обратно в первый контроллер вида через 5 секунд после того, как первый контроллер вида окажется на экране. Для этого используем метод performSelector: withObject: afterDelay: объекта NSObject, чтобы вызвать новый метод goBack. Второй метод будет вызван через 5 секунд после того, как контроллер первого вида успешно отобразит на экране этот первый вид. В методе goBack просто используем свойство navigationController контроллера вида (а оно встроено в UIViewController, и нам самим не приходится его писать), чтобы вернуться к экземпляру FirstViewController. Для этого воспользуемся методом popViewControllerAnimated: навигационного контроллера, который принимает в качестве параметра логическое значение. Если этот параметр имеет значение YES, то переход к предыдущему контроллеру вида будет анимироваться, если NO – не будет. В результате мы увидим примерно такую картинку, как на рис. 1.34.