Hor*_*ren 16 javascript youtube youtube-api
我有一个隐藏控件的嵌入式YouTube视频:
<iframe id="ytplayer" type="text/html" width="400" height="225"
src="http://www.youtube.com/embed/dMH0bHeiRNg?rel=0&controls=0&showinfo=0
&loop=1&hd=1&modestbranding=1&enablejsapi=1&playerapiid=ytplayer"
frameborder="0" allowfullscreen></iframe>
Run Code Online (Sandbox Code Playgroud)
我可以使用youtube Javascript API来控制它.
var tag = document.createElement('script');
tag.src = "//www.youtube.com/iframe_api";
var firstScriptTag = document.getElementsByTagName('script')[0];
firstScriptTag.parentNode.insertBefore(tag, firstScriptTag);
var player;
function onYouTubeIframeAPIReady() {
player = new YT.Player('ytplayer', {
events: {
'onReady': onPlayerReady,
'onStateChange': onPlayerStateChange
}
});
}
Run Code Online (Sandbox Code Playgroud)
像player.playVideo()等等的东西完美地工作.现在我正在寻找一种方法,通过Javascript调用使视频在全屏模式下播放,但我在API中找不到任何方法.
它甚至可能(没有控制),如果是这样 - 如何?
我在Auto-Full Screen for a Youtube embed 的回答中添加了代码来执行全屏(真正的全屏,而不是全窗口)。
YouTube 不会在他们的 API 中公开全屏,但是您可以从 YouTube API 的 playerStateChange() 事件中调用本机浏览器 requestFullScreen() 函数,或者像我一样制作自己的自定义播放按钮。
您可以使用 html5 全屏 api:
node.requestFullScreen();
document.cancelFullScreen();
document.fullScreen; // bool
Run Code Online (Sandbox Code Playgroud)
但请注意:
mozRequestFullScreen()或webkitRequestFullScreenrequestFullScreen 必须在用户事件上调用(如 onclick)在我看来,这很完美。您可以在此链接上找到更多详细信息:CodePen上的演示
var player, iframe;
var $ = document.querySelector.bind(document);
// init player
function onYouTubeIframeAPIReady() {
player = new YT.Player('player', {
height: '200',
width: '300',
videoId: 'dQw4w9WgXcQ',
events: {
'onReady': onPlayerReady
}
});
}
// when ready, wait for clicks
function onPlayerReady(event) {
var player = event.target;
iframe = $('#player');
setupListener();
}
function setupListener (){
$('button').addEventListener('click', playFullscreen);
}
function playFullscreen (){
player.playVideo();//won't work on mobile
var requestFullScreen = iframe.requestFullScreen || iframe.mozRequestFullScreen || iframe.webkitRequestFullScreen;
if (requestFullScreen) {
requestFullScreen.bind(iframe)();
}
}
Run Code Online (Sandbox Code Playgroud)
小智 0
也许看看这个类似的问题。看起来这可能适合你(使用 javascript 全屏 api 而不是 Youtube API):
使用 Javascript 的 Chromeless 播放器中的全屏选项?
| 归档时间: |
|
| 查看次数: |
52306 次 |
| 最近记录: |