使用youtube iframe api
禁用全屏按钮:FS:0
禁用键盘控制: disablekb:1
当播放器加载,删除全屏选项:
// Get DOM video player not YT videoplayer
videoPlayer = document.getElementById('player');
// don't allow full screen
videoPlayer.allowFullscreen = false;
对DOM的球员(在我们的例子中的iframe)与Fullscreen_API
触发全屏
videoPlayer.requestFullScreen()
全屏休假会发生,如果ESC键被按下或视频端(自定义事件处理)
JsFiddle工作实施例:
<!DOCTYPE html>
<html>
<body>
<!-- The <iframe> (and video player) will replace this <div> tag. -->
<div id="player"></div>
<br />
<button id="fullScreenPlayer">Full Screen Player</button>
<script>
// DOM player
var videoPlayer;
// This code loads the IFrame Player API code asynchronously.
var tag = document.createElement('script');
tag.src = "https://www.youtube.com/iframe_api";
var firstScriptTag = document.getElementsByTagName('script')[0];
firstScriptTag.parentNode.insertBefore(tag, firstScriptTag);
// This function creates an <iframe> (and YouTube player)
// after the API code downloads.
var player;
function onYouTubeIframeAPIReady() {
player = new YT.Player('player',
{
height: '390',
width: '640',
videoId: 'nAgKA7R4Fz4',
// params: https://developers.google.com/youtube/player_parameters?playerVersion=HTML5
playerVars: { 'fs': 0, 'disablekb': 1, 'rel': 0 },
events: {
'onReady': onPlayerReady,
'onStateChange': onPlayerStateChange
}
});
}
// The API will call this function when the video player is ready.
function onPlayerReady(event) {
event.target.playVideo();
// Get DOM video player not YT videoplayer
videoPlayer = document.getElementById('player');
// don't allow full screen
videoPlayer.allowFullscreen = false;
// Listen for fulscreen changes, if you need custom logic here, but I won't recommned that, it's to complex and you don't have control inside YT iframe
videoPlayer.addEventListener("fullscreenchange", fullScreeCallback, false);
videoPlayer.addEventListener("webkitfullscreenchange", fullScreeCallback, false);
videoPlayer.addEventListener("msfullscreenchange", fullScreeCallback, false);
videoPlayer.addEventListener("mozfullscreenchange", fullScreeCallback, false);
}
// If the video reach the end then player will leave full screen
function onPlayerStateChange(event) {
if (event.data == YT.PlayerState.ENDED) {
leaveFullscreen();
}
}
function stopVideo() {
player.stopVideo();
}
// fullscreen event handller
function fullScreeCallback(e) {
// do what you like when you catch the event
console.log(e);
return false;
}
var goFullscreen = function() {
if (videoPlayer === undefined) throw "player is undefined";
if (videoPlayer.requestFullScreen) {
videoPlayer.requestFullScreen();
} else if (videoPlayer.mozRequestFullScreen) {
videoPlayer.mozRequestFullScreen();
} else if (videoPlayer.webkitRequestFullScreen) {
videoPlayer.webkitRequestFullScreen();
}
}
var leaveFullscreen = function() {
if (document.cancelFullScreen) {
document.cancelFullScreen();
} else if (document.mozCancelFullScreen) {
document.mozCancelFullScreen();
} else if (document.webkitCancelFullScreen) {
document.webkitCancelFullScreen();
}
}
document.getElementById('fullScreenPlayer').addEventListener("click", function(e) {
goFullscreen();
}, false);
</script>
</body>
</html>
感谢您的真棒回答!这真的很好,是我在问题中提到的解决方法。有什么方法可以在使用YouTube的全屏按钮时使其工作?当YouTube的按钮被点击时,fullscreenchange事件被触发。我想阻止YouTube播放器进入全屏模式,而是在使用YouTube的全屏按钮时从我的某个DOM元素请求全屏。 – Alexander
可以显示全屏按钮,从玩家变量中删除'fs':0,但它不会全屏显示,因为强制不这样做,点击事件或其他事件不能被监听在iframe中,我的回答是解决方法是,你可以通过这种方式来阻止全屏,我会试着找到一个解决方案,但我确定没有一个解决方案。 – SilentTremor
如果yt.player“fs”按钮是不可变的,那么控制全屏时,我再次阅读你的问题,它说它不需要全屏双击发生,在播放器fs控制点击或键盘快捷按下(我添加这)在播放器上它会过度播放一些HTML,添加那里全屏幕触发这是你唯一的选择与youtube iframe API,如果你想控制全屏幕使用另一个球员,你可以找到很多,但移动是一个很大的关注与那些,祝你今天愉快。 – SilentTremor