iOS单页面支持横屏的几种方法总结

size class布局

 在storyboard中可以利用size class对横竖屏进行页面布局,达到显示不同界面的效果。应用,例如视频播放,在横屏下显示全屏播放。注意点:控制view不同屏幕是否显示,需在storyboard右边栏的“show the Attribuse ”最下面设置Inatalled设置。

单页面实现支持横屏,接受通知,改变view的布局

步骤一:在UIApplication实现该方法

- (UIInterfaceOrientationMask)application:(UIApplication *)application supportedInterfaceOrientationsForWindow:(UIWindow *)window {
    if(self.isFull){
        return UIInterfaceOrientationMaskAll;
    }
    return UIInterfaceOrientationMaskPortrait;

}

步骤二: 在需要支持横屏的页面重写次方法

   // 支持设备自动旋转
- (BOOL)shouldAutorotate {
    return YES;
}
// 支持横竖屏显示
-(UIInterfaceOrientationMask)supportedInterfaceOrientations{
    return UIInterfaceOrientationMaskAll;
}

判断手机是否横屏,可使用重力感应判断旋转角度。

导入' CoreMotion/CoreMotion.h ,CMMotionManager '类对重力检测。次方法虽可行,但十分复杂。

整个项目依然不支持横屏,对视图进行强制transform 旋转

  不支持自动旋转监听屏幕是否旋转,需要使用UIDeviceOrientationDidChangeNotification的通知,判断方向在transform 相应的角度即可。

你可能感兴趣的:(iOS_应用)