是否可以横向旋转 UIAlertController(和 Alert)?

问题描述 投票:0回答:3

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

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

有什么办法可以做到这一点吗?我想旋转警报,玩家 2 将看不到旋转警报的信息。

这是我的警报代码:

@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
3个回答
9
投票

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

为了一开始就不会看到“不正确”的方向,您必须将警报设置为

hidden
,然后在“呈现”后使其可见。

let alert // setup

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

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


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


3
投票

这是我的解决方案。

presentViewController
无动画以避免出现警报控制器时闪烁。

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

然后创建一个 UIAlertController 类别,例如名为

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

0
投票

创建 UIAlertController 的子类并在警报的消失隐藏视图中,如下所示。

@MainActor open class CustomAlertView : UIAlertController {
    open override func viewWillDisappear(_ animated: Bool) {
        super.viewWillDisappear(animated)
        view.isHidden = true
    }
}

并像下面一样使用它,与 UIAlertController 相同。

    let alert = CustomAlertView(title: "Rotate 180", message: "Please confirm Alert view is rotated 180 degree(landscape)", preferredStyle: .alert)
    alert.view.isHidden = true;
    alert.addAction(UIAlertAction(title: "OK", style: .default, handler: { action in
    }))
    alert.addAction(UIAlertAction(title: "Cancel", style: .destructive, handler: { action in
    }))
    self.present(alert, animated: true) {
        alert.view.transform = CGAffineTransformMakeRotation(Double.pi / 2.0);
        alert.view.isHidden = false;
    }
© www.soinside.com 2019 - 2024. All rights reserved.