Ответ 1
Лучшим решением, которое я нашел, является создание прозрачного представления контейнера, добавление этого контейнера в окно и размещение вашего предупреждения внутри контейнера. Затем вы можете зарегистрироваться для UIApplicationWillChangeStatusBarOrientationNotification
для получения событий поворота и преобразования контейнера; это позволяет вам самостоятельно управлять рамкой оповещения:
- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions
{
...
self.container = [[UIView alloc] initWithFrame:self.window.bounds];
[self.container addSubview:self.alertView];
[self.window addSubview:self.container];
[[NSNotificationCenter defaultCenter] addObserver:self
selector:@selector(statusBarWillRotate:)
name:UIApplicationWillChangeStatusBarOrientationNotification
object:nil];
...
}
...
- (void)statusBarWillRotate:(NSNotification *)theNotification
{
CGFloat rotation = 0;
switch ([notification[UIApplicationStatusBarOrientationUserInfoKey] intValue])
{
case UIInterfaceOrientationLandscapeLeft:
rotation = -M_PI_2;
break;
case UIInterfaceOrientationLandscapeRight:
rotation = M_PI_2;
break;
case UIInterfaceOrientationPortraitUpsideDown:
rotation = M_PI;
break;
case UIInterfaceOrientationPortrait:
default:
rotation = 0;
break;
}
CGAffineTransform rotationTransform = CGAffineTransformMakeRotation(rotation);
CGSize rotatedSize = CGRectApplyAffineTransform(self.window.bounds, rotationTransform).size;
[UIView animationWithDuration:[UIApplication sharedApplication].statusBarOrientationAnimationDuration
animations:^{
self.container.transform = rotationTransform;
// Transform invalidates the frame, so use bounds/center
self.container.bounds = CGRectMake(0, 0, rotatedSize.width, rotatedSize.height);
self.container.center = CGPointMake(self.window.bounds.size.width / 2, self.window.bounds.size.height / 2);
}];
}
Если вы действительно хотите, вы можете создать совершенно новое окно со свойством windowLevel
, установленным на UIWindowLevelAlert
, что гарантирует, что окно останется выше всех других видов, включая клавиатуру, но управление окнами становится немного сложно. Вышеупомянутое решение должно быть достаточным для большинства потребностей.
Проблема с простое добавлением вида контроллера просмотра в окно заключается в том, что он не гарантирует получение всех сообщений вращения и view[Will|Did][Disa|A]ppear:
, если он не добавлен в иерархию диспетчера представлений через addChildViewController:
на контроллере корневого представления.