web-dev-qa-db-fra.com

Lancer ViewController à partir d'AppDelegate

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?

12
Elgert

Problème

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. 


Solution

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 ];

11
EridB

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];
7
nikhil84

Écrivez ce code dans didFinishingWithLaunchingOptions

  SecViewController *Vc = [[UIStoryboard storyboardWithName:@"Main" bundle:nil]instantiateViewControllerWithIdentifier:@"second"];
   [(UINavigationController *)self.window.rootViewController pushViewController:Vc animated:YES];
2
Sakshi Singla

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()
1
mike vorisis

Si vous voulez pousser un UIViewController, vous oubliez probablement de l'initialiser avec le NibName:

LoginViewController *loginViewController = [[LoginViewController alloc]initWithNibName:@"LoginViewController" bundle:nil];
0
jomafer

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;
}
0
n.by.n