iOS 全局禁止横屏,但UIWebView 全屏播放视频,横屏,解决办法
来源:互联网 发布:淘宝开店没有电脑认证 编辑:程序博客网 时间:2024/05/12 21:40
iOS 全局禁止横屏,但UIWebView 全屏播放视频,横屏,解决办法
UIWebview在播放网页视频的时候我们需要进行是否全屏状态的监听。
一般的需求是在播放视频时候需要横屏,退出全屏的时候不能横屏,但是UIWebview没有给出响应的方法,
本问题解决的Demo工程https://github.com/darren90/iOS_Demo/tree/master/02-UIWebview
1:其他界面不支持横屏:
这个比较容易我的思路是在APPDelegate.h文件中增加属性:是否支持横屏
/*** 是否允许横屏的标记 */@property (nonatomic,assign)BOOL allowRotation;
在APPDelegate.m文件中增加方法,控制全部不支持横屏
-(NSUInteger)application:(UIApplication *)application supportedInterfaceOrientationsForWindow:(UIWindow *)window { if (self.allowRotation) { return UIInterfaceOrientationMaskAll; } return UIInterfaceOrientationMaskPortrait;}
这样在其他界面想要横屏的时候,我们只要控制allowRotation这个属性就可以控制其他界面进行横屏了。
//需在上面#import "AppDelegate.h"AppDelegate *appDelegate = (AppDelegate *)[[UIApplication sharedApplication] delegate];appDelegate.allowRotation = YES;//不让横屏的时候 appDelegate.allowRotation = NO;即可
2:播放界面横屏:
2.1:播放界面横屏:网上的解决方案
网上有人给出两种方法:
第一:但是iOS8下失效,没有用[[NSNotificationCenterdefaultCenter]addObserver:selfselector:@selector(videoStarted:)name:@"UIMoviePlayerControllerDidEnterFullscreenNotification"object:nil];//
第二:通过js,但是没有找到详细的,可解决的方案。
所以也就是没有找到成熟的方案,所以就自己分析了。
2.2:播放界面横屏:问题分析
方法总会有的,我们要向监听UIWebView视频播放时候是否全屏,也就是我们要能拿到播放视频的view或者是viewcontroller,但是由于UIWebView没有比较直观的方法,所以只能从其他地方下手了
通过Reveal我们可以查看到view的一些层级关系,可以看出弹出播放的是AVPlayerView,在UIWindow上,
好了,问题到这已经很明晰了,我们要么能拿到AVPlayerView,要呢拿到UIWindow才能控制播放界面,分析后发现AVPlayerView不好拿,但是UIWindow及很easy了。
2.3:播放界面横屏:问题解决
所以这里可以使用UIWindow的通知,就可以解决
[[NSNotificationCenter defaultCenter] addObserver:self selector:@selector(begainFullScreen) name:UIWindowDidBecomeVisibleNotification object:nil];//进入全屏[[NSNotificationCenter defaultCenter] addObserver:self selector:@selector(endFullScreen) name:UIWindowDidBecomeHiddenNotification object:nil];//退出全屏
在退出全屏时,增加逻辑让其强制编程竖屏,这样当全屏播放的时候,点击down("完成")时,就会自动变成竖屏了。
// 进入全屏-(void)begainFullScreen{ AppDelegate *appDelegate = (AppDelegate *)[[UIApplication sharedApplication] delegate]; appDelegate.allowRotation = YES;}// 退出全屏-(void)endFullScreen{ AppDelegate *appDelegate = (AppDelegate *)[[UIApplication sharedApplication] delegate]; appDelegate.allowRotation = NO; //强制归正: if ([[UIDevice currentDevice] respondsToSelector:@selector(setOrientation:)]) { SEL selector = NSSelectorFromString(@"setOrientation:"); NSInvocation *invocation = [NSInvocation invocationWithMethodSignature:[UIDevice instanceMethodSignatureForSelector:selector]]; [invocation setSelector:selector]; [invocation setTarget:[UIDevice currentDevice]]; int val =UIInterfaceOrientationPortrait; [invocation setArgument:&val atIndex:2]; [invocation invoke]; }}
实例Demo工程 https://github.com/darren90/iOS_Demo/tree/master/02-UIWebview
欢迎您的访问...
微博:@IT_攻城师
github: @Darren90
作者: http://www.cnblogs.com/fengtengfei/
本文版权归本人和博客园所有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接。
- iOS 全局禁止横屏,但UIWebView 全屏播放视频,横屏,解决办法
- iOS 全局禁止横屏,但UIWebView 全屏横屏播放视频的解决办法
- 实现iOS全局禁止横屏,但kxmovie全屏横屏播放视频
- iOS 全局禁止横屏,但视频播放界面选择性横屏的解决办法
- 全局禁止横屏,但视频播放界面选择性横屏,以及引发问题的解决办法
- iOS UIWebView 全屏播放视频, 需横屏,单app不支持横屏, 解决办法
- iOS UIWebView 全屏播放视频, 需横屏,单app不支持横屏, 解决办法
- iOS UIWebView 全屏播放视频, 需横屏,单app不支持横屏, 解决办法
- iOS UIWebView 全屏播放视频, 需横屏,单app不支持横屏, 解决办法
- iOS UIWebView 全屏播放视频横屏 app其他页面不支持横屏
- 移动端在iOS上视频禁止全屏播放
- ios上微信视频不能自动播放和禁止默认全屏
- iOS 单页UIWebView播放视频,需要横屏
- UIWebView直接全屏播放视频链接
- iOS 土豆视频播放,UIwebview播放视频
- ios 全局禁止横屏 单个视屏全局播放 横屏显示
- 使用UIWebView播放视频时捕捉全屏播放事件
- UIWebView视频播放横竖屏
- 毕业5年决定你的命运 --------值得所有不甘平庸的人看看
- Spring -- 2.Bean
- nexus安装和部署
- PS切图
- dos linux 生成带有时间戳的文件
- iOS 全局禁止横屏,但UIWebView 全屏播放视频,横屏,解决办法
- Ionic2跨平台项目(四)热修复(本地测试)
- Thrift的TJsonProtocol协议分析
- 并发编程中的三个概念
- velocity 引擎初始化报错,velocity.log禁止访问
- Linux下Nagios的安装与配置
- redis的集群搭建与添加节点
- 操作系统--内存管理之连续分配管理方式
- 深入理解作用域链