【问题标题】:Is it possible to rotate UIAlertController (and Alert) in landscape orientation?是否可以横向旋转 UIAlertController(和警报)?
【发布时间】:2015-10-03 21:25:48
【问题描述】:

我正在编辑一个应用,我在其中添加了一个新的 UIViewController 以在一个布局中配置多人游戏。

我为每个玩家添加了两个按钮(顶部按钮、机器人按钮)。每个按钮都会在屏幕上生成一个警报(记住它是横向的),但问题是,玩家 2 没有看到旋转的警报,我的意思是,警报应该以他的方向显示在我面前。

有没有办法做到这一点?我想为玩家旋转一个Alert 2 不会看到Alert 翻转的信息。

这是我的警报代码:

@IBAction func ShowAlert(){
let message = "Test"
let alert = UIAlertController(title: title, message: message, preferredStyle: .Alert)

let action = UIAlertAction(title: "OK", style: .Default, handler: nil)

    alert.addAction(action)

    presentViewController(alert, animated: true, completion: nil)
}

【问题讨论】:

    标签: ios swift rotation uialertcontroller


    【解决方案1】:

    这是一种旋转警报控制器视图的方法,尽管它并不完美。控制器尝试根据方向呈现,我发现尝试在呈现之前对其进行转换是不成功的。

    为了最初看不到“不正确”的方向,您必须将警报设置为hidden,然后在“呈现”后使其可见。

    let alert // setup
    
    alert.view.hidden = true;
    [self presentViewController:c animated:YES completion:^{
        alert.view.transform = CGAffineTransformMakeRotation(M_PI);
        alert.view.hidden = false;
    }];
    

    我遇到的唯一突出问题是,在用户与警报交互后,它会闪回到初始转换(取决于方向)。我目前还没有找到解决方案,但如果有的话会更新。


    或者,使用自定义“警报”可以解决这个问题,因为您可以更好地控制它的视图。这可能是更可靠的方法。

    【讨论】:

    • 您是否找到了解雇时轮换的解决方案(闪烁)?
    【解决方案2】:

    这是我的解决方案。 presentViewController 没有动画以避免在出现警报控制器时闪烁。

    [self presentViewController:alert animated:NO completion:^{
        [alertController.view setTransform: CGAffineTransformMakeRotation(M_PI_2)];
     }];
    

    然后创建一个 UIAlertController 类别,命名为 e.g. UIAlertController+Orientation, 隐藏viewWillDisappear 中的视图以避免在关闭警报控制器时闪回。

    #import "UIAlertController+Orientation.h"
    
    @implementation UIAlertController (Orientation)
    
    - (void)viewWillDisappear:(BOOL)animated {
        [super viewWillDisappear:animated];
        [self.view setHidden:YES];
    }
    
    - (BOOL) shouldAutorotate {
        return NO;
    }
    
    @end
    

    【讨论】:

    • viewWillDisappear 没有被调用。有什么想法吗?
    猜你喜欢
    • 2021-06-07
    • 1970-01-01
    • 2016-04-19
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2016-01-19
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多