引言
在做监控视频时,一个很重要需求就是视频全屏以及退出。下面就讲讲用JavaScript来检测全屏以及退出。
全屏实现
全屏有一套Web API已经为我们准备好,见这里,不过有时我们在使用第三方Web SDK时,可能已经提供,比如海康威视、大华、宇视等。但是第三方其实也是基于Web API的二次封装而已,所以本质还是要了解的。
export const clickFullScreen = () => {
const objElement = document.querySelector('.parent-wnd').childNodes[0];
objElement.requesetFullscreen().then(()=>{
},(err)=>{
console.log(err.message)
});
}
这里需要注意Chrome浏览器需要特殊处理,对于待全屏的元素,需要指定{ width:100%; height:100%}
全屏检测
一般的,我们通过监听document.fullscreenElement 是否存在即可,如果处于全屏状态,这个值不为空,否则为空(null )
if(!document.fullscreenElement){
}else{
}
但是这里有个坑,就是Chrome浏览器(webkit内核)在全屏下是无法监听键盘事件的,如果想在退出全屏下做一些事情,在Chrome浏览器下需要依赖resize 事件。
this.__resizeHanlder = this.lodash.debounce(() => {
if (!document.fullscreenElement) {
this.isFullScreen = false
}
if (this.hasInit && !this.isFullScreen) {
this.initWebCtrl()
}
}, 150)
window.addEventListener('resize', this.__resizeHanlder)
|