Zaimplementowałem interfejs API iOS 6 do zapisywania stanu, działa - po tym, jak opuść aplikację i uruchomię ją z powrotem na kilka milisekund, do której odtworzy się przywrócony kontroler widoku, ale zastąpiony przez główny widok kontroler wyświetlany podczas uruchamiania.iOS 6 - Zachowanie i przywracanie stanu
Ustawię za każdym razem, gdy aplikacja uruchamia główny widok głównego okna, więc to musi być problem.
Oto mój kod:
- (BOOL)application:(UIApplication *)application willFinishLaunchingWithOptions:(NSDictionary *)launchOptions
{
[self commonInitializationLaunching:launchOptions];
return YES;
}
- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions
{
[self commonInitializationLaunching:launchOptions];
return YES;
}
- (void)commonInitializationLaunching:(NSDictionary *)launchOptions
{
static dispatch_once_t onceToken;
dispatch_once(&onceToken, ^{
self.window = [[UIWindow alloc] initWithFrame:[[UIScreen mainScreen] bounds]];
// Override point for customization after application launch.
static NSString *const kKeychainItemName = @"OAuthGoogleReader";
self.viewController = [[ViewController alloc] initWithNibName:@"ViewController" bundle:nil];
self.navController = [[UINavigationController alloc] initWithRootViewController:self.viewController];
GTMOAuth2Authentication *auth;
auth = [GTMOAuth2ViewControllerTouch authForGoogleFromKeychainForName:kKeychainItemName
clientID:kClientID
clientSecret:kClientSecret];
self.window.rootViewController = self.navController;
[self.window makeKeyAndVisible];
BOOL isSignedIn = [auth canAuthorize];
if (isSignedIn) {
NSLog(@"Signed");
}else{
NSString *scope = @"https://www.google.com/reader/api/";
GTMOAuth2ViewControllerTouch *viewController;
viewController = [[GTMOAuth2ViewControllerTouch alloc] initWithScope:scope
clientID:kClientID
clientSecret:kClientSecret
keychainItemName:kKeychainItemName
delegate:self
finishedSelector:@selector(viewController:finishedWithAuth:error:)];
[self.navController pushViewController:viewController animated:YES];
// self.window.rootViewController = viewController;
}
});
}
Można zobaczyć, że w - (void) commonInitializationLaunching: (NSDictionary *) launchOptions mam ustawienie mojego okna widok korzeniowy. Nie wiem, co tam umieścić. Być może sprawdź, czy jest zapisany stan, a następnie załaduj tę metodę? Ale jak?
Dzięki!
Oto co próbowałem po poradę Roba:
- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions
{
if (!self.isRestored) {
self.window = [[UIWindow alloc] initWithFrame:[[UIScreen mainScreen] bounds]];
}
[self commonInitializationLaunching:launchOptions];
[self.window makeKeyAndVisible];
return YES;
}
z niczym w willFinishLaunching
... Ja również usunąć za pomocą kodu z mojego okna metody commonInitializationLaunching
.
Czy moja odpowiedź pomogła? Niektóre opinie będą świetne. – rbrown