J'ai un schéma d'URL personnalisé et je veux ouvrir un certain ViewController
qui n'est pas la racine lorsque je vais à cette URL. J'ai pu faire cela et ce qu'il reste à faire, c'est d'insérer cette ViewController
dans la navigationController
à partir de la AppDelegate
où je gère mon URL de la manière suivante:
- (BOOL)application:(UIApplication *)application
openURL:(NSURL *)url
sourceApplication:(NSString *)sourceApplication
annotation:(id)annotation {
if ([[url scheme] isEqualToString:@"njoftime"]) {
NSDictionary *getListingResponse = [[NSDictionary alloc]init];
getListingResponse = [Utils getListing:[url query]];;
if ([[getListingResponse objectForKey:@"status"] isEqualToString:@"success"]) {
ListingViewController *listingView = [[ListingViewController alloc]init];
[self.window.rootViewController.navigationController pushViewController:listingView animated:YES];
return YES;
}
mais cela ne fait que lancer mon application et non la ListingViewController
que je veux lancer. Avez-vous une idée de la façon dont je peux le faire différemment?
Pour manipuler et extraire les viewControllers depuis AppDelegate , vous devez utiliser [UIApplication sharedApplication]
qui garde trace de tous les viewControllers, en commençant par la racine.
To Push ViewController à partir de AppDelegate
ListingViewController *listingVC = [[ListingViewController alloc] init];
[(UINavigationController *)self.window.rootViewController pushViewController:listingVC animated:YES];
PourPOPque ViewController que vous venez de présenter, vous devez utiliser ce code
[(UINavigationController *)[UIApplication sharedApplication].keyWindow.rootViewController popViewControllerAnimated:YES ];
Si vous utilisez Storyboard, vous pouvez utiliser les lignes ci-dessous pour pousser votre VC.
UIStoryboard *storyboard = [UIStoryboard storyboardWithName:@"MainStoryboard" bundle:nil];
YOURCLASS *obj=[storyboard instantiateViewControllerWithIdentifier:@"YOUR_CLASS_STORYBOARD_ID"];
[self.window.rootViewController.navigationController pushViewController:obj animated:YES];
Mettre à jour:-
ListingViewController *listingVC = [[ListingViewController alloc] init];
UINavigationController *navCon = [[UINavigationController alloc] initWithRootViewController:listingVC];
[self.window.rootViewController presentViewController:navCon animated:YES completion:nil];
Écrivez ce code dans didFinishingWithLaunchingOptions
SecViewController *Vc = [[UIStoryboard storyboardWithName:@"Main" bundle:nil]instantiateViewControllerWithIdentifier:@"second"];
[(UINavigationController *)self.window.rootViewController pushViewController:Vc animated:YES];
Pour la version Swift 3:
let mainStoryboardIpad : UIStoryboard = UIStoryboard(name: "Main", bundle: nil)
let initialViewControlleripad : UINavigationController = mainStoryboardIpad.instantiateViewController(withIdentifier: "initial") as! UINavigationController
self.window = UIWindow(frame: UIScreen.main.bounds)
self.window?.rootViewController = initialViewControlleripad
self.window?.makeKeyAndVisible()
Si vous voulez pousser un UIViewController, vous oubliez probablement de l'initialiser avec le NibName:
LoginViewController *loginViewController = [[LoginViewController alloc]initWithNibName:@"LoginViewController" bundle:nil];
Votre AppDelegate.m devrait ressembler à ceci:
#import "TestViewController.h"
@interface AppDelegate ()
@property (strong, nonatomic) TestViewController *viewController;
@end
@implementation AppDelegate
- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions {
self.window = [[UIWindow alloc] initWithFrame:[[UIScreen mainScreen] bounds]];
self.viewController = [[TestViewController alloc]init];
self.window.rootViewController = self.viewController;
[self.window makeKeyAndVisible];
return YES;
}