西瓜播放器全屏功能源码分析

H5业务中使用了西瓜播放器,嵌入各个APP,全屏时候会有相应的差异。

带着好奇心,阅读一下xgpplayer全屏功能部分源代码。

源码地址

一、工具方法

其他方法看名称就知道是dom操作相关,无需多说,上面这两个工具方法主要用来检测视频的播放形式,分别代表画中画,在页面中播放以及全屏播放。

二、绑定全屏事件

这里根据用户是否配置roateFullScreen来决定进入和退出全屏执行的方法,执行的方法略有差异,下面详细说明。

看看这个配置的作用是啥:

三、进入全屏和退出全屏

此处接受到播放器的包裹元素,尝试调用requestFullScreen方法,该方法作用和用法如下:

剩下的else if语句主要针对,firefox, webkit类型webview,ie浏览器进行兼容,如果都不支持requestFullScreen方法,就通过给播放器的包裹元素添加样式的方式实现全屏效果。样式代码如下,比较简洁。

退出全屏相对应的,请求exitFullscreen()方法就可以了。

四、进入样式横屏全屏和退出样式横屏全屏

箭头部分配置作用如下:

设置流式布局,相对应的样式全屏样式需要特殊处理,这里专门做了区分。

样式横屏全屏添加了红框样式,

对包裹元素进行了旋转处理。

五、监听全屏事件变动

此处针对不同浏览器对fullscreenchange进行监听,toggle css 和 进入退出全屏事件。注意如果配置了弹幕,切换全屏会对弹幕进行resize。

六、监听展现mode

自定义事件 webkitpresentationmodechanged 相对的处理,这个事件会在画中画相对应操作触发,退出全屏删除全屏样式,触发exitFullScreen()方法。

七、销毁

自定义destroy事件,播放器实例销毁,移除绑定事件。

-- END --

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值