1

我的应用程序有一个根视图控制器,它在应用程序开始时显示

  • login viewController用户未登录时的视图
  • 如果用户已登录,则主 viewController 视图

AppDelegate 代码:

- (BOOL)              application: (UIApplication*) application
    didFinishLaunchingWithOptions: (NSDictionary*) launchOptions
{
    self.window = [[UIWindow alloc] initWithFrame: [[UIScreen mainScreen] bounds]];

    self.window.rootViewController = [[RootViewController alloc] init];

    [self.window makeKeyAndVisible];

    return YES;
}

这是 RootViewController 中使用的代码:

@implementation RootViewController

- (void) loadView
{
   [super loadView];

   // here mainViewController and loginNavigationController are initialized
}

...

- (UIView*) view
{   
   [super view]; // this invokes loadView

    return self.isLoggedIn ? self.mainViewController.view : 
                             self.loginNavigationController.view;
}

....

- (void) userDidLogin
{
     [self.loginNavigationController presentViewController: self.mainViewController 
                                                  animated: YES 
                                                completion: nil];
}
@end

如果用户未登录并按下登录按钮,则会显示主视图控制器。

问题是在主 viewController 出现后,我无法与任何 UI 元素进行交互。例如,我有一个 tableView 作为主 viewController 的子视图,当我尝试滚动它时,我在调试面板中收到以下警告:

 <UITableView: 0x202a4000; frame = (0 0; 310 548); clipsToBounds = YES;
 gestureRecognizers = <NSArray: 0x1fd9f570>; layer = <CALayer: 0x1fdccff0>;
 contentOffset: {0, 0}>'s window 
 is not equal to <RootViewController: 0x1fd9f7d0>'s view's window!
4

1 回答 1

1

好的,所以在查看更新后的代码后,我发现您有一个 rootViewController 并且正在动态地提供您认为应该呈现的视图。问题是,rootViewController 负责根视图,而其他两个视图控制器则管理自己的视图。您不应该传递不同的视图控制器的视图。

所以最后看起来你想有条件地设置你的rootviewcontroller。因此,让我们看看应用程序委托。我认为你应该让你的应用程序委托做这样的事情。让它在运行时确定要呈现哪个视图控制器。然后将其设为应用程序的 rootviewcontroller。

- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions
{
    UIViewController * resolvedRootViewController = [self someMethodThatCorrectlyGivesRootViewController];

    self.window = [[UIWindow alloc] initWithFrame:[[UIScreen mainScreen] bounds]];
    self.window.rootViewController = resolvedRootViewController;
    [self.window makeKeyAndVisible];

    return YES;
}
于 2013-07-16T15:23:18.027 回答