7

我有一个位于 UINavigationController 内的主视图控制器。在那个主视图控制器中,我有一个按钮可以推动一个内部有 UIWebView 的详细视图控制器。我希望这个细节视图控制器在加载时处于横向模式。回到主视图控制器,它又强制回到纵向模式。我正在运行 iOS 6。

我已经看到了其他类似的问题,但它对我没有用。我创建了一个 LandscapeViewController,它是 UIViewController 的子类,我在其中编写了这些方法:

#pragma mark - Orientation Methods
- (NSUInteger)supportedInterfaceOrientations
{
    return UIInterfaceOrientationMaskLandscape;
}

- (BOOL)shouldAutorotate
{
    return YES;
}

这是我推送详细视图控制器时的代码:

DetailViewController *detailVC = [[DetailViewController alloc]
                                      initWithNibName:@"DetailViewController"
                                      bundle:nil];

    [self.navigationController pushViewController:detailVC
                                         animated:YES];

我正在考虑在上面的代码中将我的 LandscapeViewController 子类化以使其工作或如何正确子类化和推送我的详细视图控制器。如果导航控制器无法将我的详细视图控制器从纵向推到横向,我也可以模态显示我的详细视图控制器。我在哪里做错了?

4

2 回答 2

8

考虑:视图 A:仅纵向 - 视图 B:仅横向

我无法在导航控制器中做到这一点。相反,我所做的是打开一个从视图 A 到视图 B 的模态视图,并强制一个新的导航控制器进入这个视图。

这在 iOS5+ 中对我有用。

您需要为导航控制器创建一个类别,如下所示:

UINavigationController+Rotation_IOS6.h

#import <UIKit/UIKit.h> 

@interface UINavigationController (Rotation_IOS6)

- (BOOL)shouldAutorotate;
- (NSUInteger)supportedInterfaceOrientations;
- (UIInterfaceOrientation)preferredInterfaceOrientationForPresentation;

@end

UINavigationController+Rotation_IOS6.h

#import "UINavigationController+Rotation_IOS6.h"

@implementation UINavigationController (Rotation_IOS6)

- (BOOL)shouldAutorotate
{
    return [self.topViewController shouldAutorotate];
}

- (NSUInteger)supportedInterfaceOrientations
{
    return [self.topViewController supportedInterfaceOrientations];
}

- (UIInterfaceOrientation)preferredInterfaceOrientationForPresentation
{
    return [self.topViewController preferredInterfaceOrientationForPresentation];
}

@end

AppDelegate.m添加:

- (NSUInteger)application:(UIApplication *)application supportedInterfaceOrientationsForWindow:(UIWindow *)window{
    return UIInterfaceOrientationMaskAll;
}

然后在视图 A中:

- (BOOL)shouldAutorotate {
    return YES;
}

-(NSUInteger)supportedInterfaceOrientations
{
    return UIInterfaceOrientationMaskPortrait | UIInterfaceOrientationMaskPortraitUpsideDown;
}

- (UIInterfaceOrientation)preferredInterfaceOrientationForPresentation
{
    return UIInterfaceOrientationPortrait;
}

- (BOOL)shouldAutorotateToInterfaceOrientation:(UIInterfaceOrientation)interfaceOrientation
{
    return (interfaceOrientation == UIInterfaceOrientationPortrait || interfaceOrientation == UIInterfaceOrientationPortraitUpsideDown);
}

也在视图 A 中打开视图 B执行以下操作:

ViewB *vc = [[ViewB alloc] initWithNibName:@"ViewB" bundle:nil];

UINavigationController *navigationController = [[UINavigationController alloc] initWithRootViewController:vc];

[self presentViewController:navigationController animated:YES completion:nil];

最后,在视图 B

- (BOOL)shouldAutorotate {
    return YES;
}

-(NSUInteger)supportedInterfaceOrientations
{
    return UIInterfaceOrientationMaskLandscapeRight | UIInterfaceOrientationMaskLandscapeLeft;
}

- (UIInterfaceOrientation)preferredInterfaceOrientationForPresentation
{
    return UIInterfaceOrientationLandscapeRight;
}

- (BOOL)shouldAutorotateToInterfaceOrientation:(UIInterfaceOrientation)interfaceOrientation
{
    return (interfaceOrientation == UIInterfaceOrientationLandscapeRight || interfaceOrientation == UIInterfaceOrientationLandscapeLeft);
}
于 2012-12-18T13:56:02.527 回答
0

他们在这方面有点搞砸了 iOS 6 中的狗。这是我到目前为止所知道的:

首先,Apple 在 Xcode 4.5 中添加了“支持的界面方向”按钮。这对应于 _info.plist 中的“支持的界面方向”属性。必须先将这些按钮切换到正确的选项,然后才能使用其余按钮。(如果按钮似乎拒绝切换,可能是因为 info.plist 被 CVS 或其他进程锁定。)

接下来,必须设置属性 .window.rootViewController,并且必须指向堆栈中的“底部”视图控制器。通常,这将是导航控制器或选项卡控制器。

如果希望禁用所有旋转,这可以使用按钮来完成,或者可以在“底部”视图控制器中实现“shouldAutorotate”方法并让它返回 NO。(如果省略该方法,则默认为 YES。)

尽管使用 shouldAutorotate 禁用了自动旋转,但如果显示 MPMoviePlayerViewController,它将自动旋转。只有切换受支持的界面方向按钮才会出现这种情况。

如果想要有条件地自动旋转其他视图控制器,它会变得更加混乱。基本上,您的“底部”视图控制器必须实现supportedInterfaceOrientations 方法并根据当前的topViewController 返回适当的位掩码。这可以通过查询 topViewController 的旧“shouldAutorotateToInterfaceOrientation”方法的例程来完成,但它有点难看。即使此方案不需要修改旋转视图控制器的代码,您也需要在旋转视图控制器“下方”修改 VC 以实现“supportedInterfaceOrientation”,否则该视图将在返回时旋转。(至少这是一个简单的复制/粘贴。)不过,似乎没有人想出更好、更通用的方案。

于 2012-12-14T03:37:05.307 回答