Before doing any type of iOS 5.0 development using Xcode 4.2, Xcode has provided a "MainWindow.xib" in templates. After downloading and playing with Xcode 4.2 with iOS 5.0, I noticed that none of the templates provided include any "MainWindow.xib" files. Do we need this anymore? I noticed that in the "application didFinishLaunchingWithOptions" method in the App_Delegate that the templates now include code that creates some "UIWindow" and if you have any navigation controllers, it updates the window accordingly.
// code that was pulled from a Master Detail application template
- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions
{
self.window = [[UIWindow alloc] initWithFrame:[[UIScreen mainScreen] bounds]];
// Override point for customization after application launch.
MasterViewController *masterViewController = [[MasterViewController alloc] initWithNibName:@"MasterViewController" bundle:nil];
self.navigationController = [[UINavigationController alloc] initWithRootViewController:masterViewController];
self.window.rootViewController = self.navigationController;
[self.window makeKeyAndVisible];
return YES;
}
I guess my question is, do I need a "MainWindow.xib" any longer, and if so, then why do the Apple templates exclude them?
I think the reason why it's now absent is that creating a window programmatically is much more efficient than opening a xib file and unarchiving the objects. Generally, if you can do it in one line of code, you should do that in code.
Read Matthew Gillingham's answer for instructions on how to manually change an old project to work without the MainWindow.xib.
It is has always been an option not to use MainWindow.xib. The UIWindow could be loaded programmatically by the doing the following:
1) Making sure that the call to UIApplicationMain in main.m looks like this:
UIApplicationMain(argc, argv, nil, @"MyAppDelegateClassName");
rather than this:
UIApplicationMain(argc, argv, nil, nil);
2) Making sure that Info.plist does not have a value of "MainWindow.xib" as the main nib file.
3) Loading the UIWindow programmatically in the app delegate.
So, no, you don't have to use MainWindow.xib and, actually, you never have. You could always do things programmatically.
It is a good question why Apple made this change in the default Xcode settings, and I don't know the answer. But it may have to with performance or the transition to ARC or small application file sizes or something else altogether.
I always feel confused about the usage of MainWindow.xib: even with it I still need to set window's rootViewController or addSubview to it. Isn't that information contained in MainWindow.xib ? Why I still need to tell window about that?
So removing MainWindow.xib seems to make sense.