presentModalViewController: не возвращает

У меня происходит очень странная вещь. В моем делегате приложения я вызываю presentModalViewController: в UITabBarController для отображения пользовательского класса (LoadingViewController), который реализует loadView для отображения изображения. Когда я тестирую это в симуляторе на устройстве iOS 4.x (iPhone или iPad), оно отлично работает во всех ориентациях. Однако, когда я тестировал iPad 3.2, он отлично работал только в портретной ориентации. Если это пейзаж, метод presentModalViewController: не возвращается. Методы loadView и viewDidLoad вызываются, но методы viewWillAppear: и viewDidAppear: не вызываются.

Любые идеи?

Вот код для loadView в LoadingViewController:

- (void) loadView
{
    CGRect mainScreenBounds = [UIScreen mainScreen].bounds;

    UIImageView * loadingImageView = [[UIImageView alloc] initWithFrame: mainScreenBounds];

    loadingImageView.autoresizesSubviews = YES;
    loadingImageView.autoresizingMask = UIViewAutoresizingFlexibleWidth | UIViewAutoresizingFlexibleHeight;

    NSString * splashImageName = [self getSplashImageName: [UIDevice currentDevice].orientation];
    loadingImageView.image = [UIImage imageNamed: splashImageName];

    UIActivityIndicatorView * spinner = [[UIActivityIndicatorView alloc] initWithActivityIndicatorStyle: UIActivityIndicatorViewStyleWhiteLarge];
    CGRect spinnerFrame = spinner.frame;

    spinnerFrame.origin.x = (mainScreenBounds.size.width - spinnerFrame.size.width) / 2;
    spinnerFrame.origin.y = mainScreenBounds.size.height * 0.7f;

    spinner.autoresizingMask = UIViewAutoresizingFlexibleLeftMargin
                             | UIViewAutoresizingFlexibleRightMargin
                             | UIViewAutoresizingFlexibleTopMargin
                             | UIViewAutoresizingFlexibleBottomMargin;
    spinner.frame = spinnerFrame;
    spinner.hidesWhenStopped = YES;

    [spinner startAnimating];

    [loadingImageView addSubview: spinner];

    // Add a label indicating we are working so the user knows what we are doing.
    UIColor * textColor = [UIColor blueColor];

    CGRect labelFrame = loadingImageView.frame;
    labelFrame.size.height = 40;
    labelFrame.origin.y = spinnerFrame.origin.y - 100;
    UILabel * workingLabel = [[UILabel alloc] initWithFrame: labelFrame];
    workingLabel.font             = [UIFont systemFontOfSize: 18.0];
    workingLabel.textColor        = textColor;
    workingLabel.backgroundColor  = [UIColor clearColor];
    workingLabel.textAlignment    = UITextAlignmentCenter;
    workingLabel.text             = NSLocalizedString(@"Searching for location...", @"Searching for location...");
    workingLabel.autoresizingMask = UIViewAutoresizingFlexibleLeftMargin
                                  | UIViewAutoresizingFlexibleRightMargin
                                  | UIViewAutoresizingFlexibleTopMargin
                                  | UIViewAutoresizingFlexibleBottomMargin
                                  | UIViewAutoresizingFlexibleWidth
                                  | UIViewAutoresizingFlexibleHeight;

    [loadingImageView addSubview: workingLabel];
    [workingLabel release];

    [spinner release];

    self.view = loadingImageView;
    [loadingImageView release];
}

person David Potter    schedule 15.04.2011    source источник


Ответы (2)


UITabBarController должен быть RootViewController при использовании presentModalViewController.. Также существует проблема с IOS 3.2, заключающаяся в том, что при использовании presentModalViewController в ландшафте с UITabBarController, если все его контроллеры представления не переопределяют shouldAutorotateToInterfaceOrientation и возвращают yes для ландшафта, это приведет к зависанию presentModalViewController.

person Alan    schedule 28.04.2011

Решение, к которому мы пришли, состоит в том, чтобы вообще не использовать presentModalViewController, а установить LoadingViewController в качестве корневого контроллера представления. Очевидно, что это не полное решение, но, к счастью, оно было достаточно хорошим для нас. Что расстраивает, так это то, что мы не знаем, почему presentModalViewController не работает сейчас, хотя в предыдущей версии нашего приложения он работал нормально. Что-то, что мы сделали, сломало его.

person David Potter    schedule 02.05.2011