it-swarm.com.ru

Предупреждение: попытка представить ViewController, чье представление не находится в иерархии окон

В одном из моих приложений я вызываю viewController из метода application didReceiveLocalNotification. Страница успешно загружается, но отображается предупреждение:

 Warning: Attempt to present <blankPageViewController: 0x1fda5190> on 
 <ViewController: 0x1fd85330> whose view is not in the window hierarchy!

Мой код выглядит следующим образом:

 -(void) application:(UIApplication *)application didReceiveLocalNotification:(UILocalNotification *)notification {

    blankPageViewController *myView = [[blankPageViewController alloc] 
               initWithNibName:@"blankPageViewController" bundle: nil];
    myView.modalTransitionStyle = UIModalTransitionStyleFlipHorizontal;
    [self.viewController presentViewController:myView animated:NO completion:nil];  
}
31
Vinoy Alexander

Наконец я решил эту проблему с помощью следующего кода.

-(void) application:(UIApplication *)application didReceiveLocalNotification:(UILocalNotification *)notification {
       self.window = [[UIWindow alloc] initWithFrame:[[UIScreen mainScreen] bounds]];
       self.blankviewController = [[blankPageViewController alloc] initWithNibName:@"blankPageViewController" bundle:nil];
       self.window.rootViewController = self.blankviewController;
       [self.window makeKeyAndVisible];
}
21
Vinoy Alexander

Положил

[self.viewController presentViewController:myView animated:NO completion:nil];  

в функцию, например.

- (void)yourNewFunction
{
    [self.viewController presentViewController:myView animated:NO completion:nil];
}

и затем назовите это так:

[self performSelector:@selector(yourNewFunction) withObject:nil afterDelay:0.0];

Проблема была описана здесь и почему этот performSelector:withObject:afterDelay решает эту проблему? Потому что селектор не будет вызываться до следующего запуска цикла выполнения. Так что все успевает успокоиться, и вы просто пропустите один цикл выполнения.

15
hashier

Согласно моему предположению, я чувствую, что вы пытаетесь представить myView из self.viewController до того, как self.viewController будет прикреплен или помещен в иерархию окон. Так что просто убедитесь, что myView присутствует после того, как self.viewController появится/прикрепится к окну.

Почему модальный контроллер представления не может представить другой в viewDidLoad?

12
βhargavḯ

У меня была похожая проблема, я вызывал presentViewController из моего AppDelegate.m, когда приложение вышло на передний план:

- (void)applicationWillEnterForeground:(UIApplication *)application
{
    NSDate * lastActive = [[NSUserDefaults standardUserDefaults] objectForKey:@"lastActive"];

    double interval = [[NSDate date] timeIntervalSinceDate:lastActive];

    NSLog(@"Time Interval: %f", interval);

    if (interval > 900) { // interval is in seconds, so 900 seconds = 15 mins
        Login *pres = [self.window.rootViewController.storyboard instantiateViewControllerWithIdentifier:@"login"];

        UINavigationController *navi = ((UINavigationController*)self.window.rootViewController);
        if (navi.presentedViewController) {
            [navi dismissViewControllerAnimated:YES completion:^{
                [navi presentViewController:pres animated:NO completion:nil];
            }];
        } else {
            [navi presentViewController:pres animated:NO completion:nil];
        }
    }
}

Это не сработало, так как он сначала отклоняет контроллер представления (независимо от того, какие представления были помещены на него), если он присутствует до представления контроллера представления входа в систему. Если нет, то я могу сразу представить контроллер вида Login.

2
Rob

это может быть связано с тем, что представление viewcontroller в данный момент не загружается в иерархию окон при представлении VC ...

-(void) application:(UIApplication *)application didReceiveLocalNotification:(UILocalNotification *)notification
{
    UINavigationController *navigationController = (UINavigationController*) self.window.rootViewController;
    rootViewController = [[navigationController viewControllers] objectAtIndex:0];
    blankPageViewController *myView = [[blankPageViewController alloc] initWithNibName:@"blankPageViewController" bundle: nil];
    [rootViewController presentModalViewController:myView animated:YES];
}
2
BhushanVU

Край случае:

Некоторые люди могут найти это через Google, и стоит указать, что иногда эта ошибка возникает, если вы загружаете представление как контроллер корневого представления, которое не помечено как начальное представление в раскадровке (и другое представление), а затем вы загрузить другой вид сверху. Например, в представлениях входа в систему, которые загружаются программно из метода applicationdidfinish... делегата приложения. Просто измените начальный вид (перетащите стрелку в раскадровке) на соответствующий для вашей иерархии. Эзотерический, расплывчатый, но заслуживающий внимания. 

1
LpLrich
I have used Navigation Controller and on which i have used a
ModalViewController to present a Popup(Present over current context). 
From this Popup i am opening a ViewController Modally which 
caused the Warning. So to resolve i did below change:

[self.presentedViewController performSegueWithIdentifier:@"PresentScreenSegueId" sender:sender];
0
Suraj Mirajkar

Если ваш тип приложения идентификатора UINavigationController, то вы можете использовать.

-(void) application:(UIApplication *)application didReceiveLocalNotification:(UILocalNotification *)notification {

blankPageViewController *myView = [[blankPageViewController alloc]
                                   initWithNibName:@"blankPageViewController" bundle: nil];
myView.modalTransitionStyle = UIModalTransitionStyleFlipHorizontal;
[self.navigationController presentViewController:myView animated:NO completion:nil]; }

Надеюсь, это поможет вам .... Всего наилучшего !!!

0
Yashesh

ДляSwift 2.0Я использовал переопределение для viewDidAppear с:

пусть vc = self.storyboard? .instantiateViewControllerWithIdentifier ("Second") как! SecondViewController

self.presentViewController(vc, animated: true, completion: nil)

Где «Second» - это идентификатор раскадровки SecondViewController в инспекторе идентификации.

0
Sarah Prata