API YouTube не работает с iPad / iPhone / не Flash-устройством

Этот фрагмент кода прекрасно работает в браузерах DESKTOP (код любезно предоставлен @Rob-W), щелкните миниатюру, и начнется воспроизведение соседнего видео с помощью API YouTube.

HTML

<div id="tabs2">
    <div>
    <img class='thumb' src='http://i2.cdnds.net/11/34/odd_alan_partridge_bio_cover.jpg'>
    <iframe id="frame1" width="640" height="390" frameborder="0" title="YouTube video player"type="text/html"src="http://www.youtube.com/embed/u1zgFlCw8Aw?enablejsapi=1"></iframe>
    </div>

    <div>
        <img class='thumb' src='http://i2.cdnds.net/11/34/odd_alan_partridge_bio_cover.jpg'>
   <iframe id="frame2" width="640" height="390" frameborder="0" title="YouTube video player"type="text/html"src="http://www.youtube.com/embed/u1zgFlCw8Aw?enablejsapi=1"></iframe>
    </div>
</div>

CSS

#tabs2 div {
    position: relative;
}
/* For security reasons, an element cannor be placed over a frame */
/*.thumb {
    position: absolute;
}*/    
.play {
    border: 3px solid red;
}

JS

function getFrameID(id) {
    var elem = document.getElementById(id);
    if (elem) {
        if (/^iframe$/i.test(elem.tagName)) return id; //Frame, OK
        // else: Look for frame
        var elems = elem.getElementsByTagName("iframe");
        if (!elems.length) return null; //No iframe found, FAILURE
        for (var i = 0; i < elems.length; i++) {
            if (/^https?:\/\/(?:www\.)?youtube(?:-nocookie)?\.com(\/|$)/i.test(elems[i].src)) break;
        }
        elem = elems[i]; //The only, or the best iFrame
        if (elem.id) return elem.id; //Existing ID, return it
        // else: Create a new ID
        do { //Keep postfixing `-frame` until the ID is unique
            id += "-frame";
        } while (document.getElementById(id));
        elem.id = id;
        return id;
    }
    // If no element, return null.
    return null;
}

// Define YT_ready function.
var YT_ready = (function() {
    var onReady_funcs = [],
        api_isReady = false;
/* @param func function     Function to execute on ready
         * @param func Boolean      If true, all qeued functions are executed
         * @param b_before Boolean  If true, the func will added to the first
                                     position in the queue*/
    return function(func, b_before) {
        if (func === true) {
            api_isReady = true;
            for (var i = 0; i < onReady_funcs.length; i++) {
                // Removes the first func from the array, and execute func
                onReady_funcs.shift()();
            }
        }
        else if (typeof func == "function") {
            if (api_isReady) func();
            else onReady_funcs[b_before ? "unshift" : "push"](func);
        }
    }
})();
// This function will be called when the API is fully loaded

function onYouTubePlayerAPIReady() {
    YT_ready(true)
}

var players = {};
//Define a player storage object, to enable later function calls,
//  without having to create a new class instance again.
YT_ready(function() {
    $(".thumb + iframe[id]").each(function() {
        var identifier = this.id;
        var frameID = getFrameID(identifier);
        if (frameID) { //If the frame exists
            players[frameID] = new YT.Player(frameID, {
                events: {
                    "onReady": createYTEvent(frameID, identifier)
                }
            });
        }
    });
});

// Returns a function to enable multiple events
function createYTEvent(frameID, identifier) {
    return function (event) {
        var player = players[frameID]; // player object
        var the_div = $('#'+identifier).parent();
        the_div.children('.thumb').click(function() {
            var $this = $(this);
            $this.fadeOut().next().addClass('play');
            if ($this.next().hasClass('play')) {
                player.playVideo();
            }
        });
    }
}
// Load YouTube Frame API
(function(){ //Closure, to not leak to the scope
  var s = document.createElement("script");
  s.src = "http://www.youtube.com/player_api"; /* Load Player API*/
  var before = document.getElementsByTagName("script")[0];
  before.parentNode.insertBefore(s, before);
})();

JSFiddle

Проблема в том, что он не воспроизводится на устройствах iOS (из-за отсутствия Flash-плеера, я думаю, он просто зависает).

Я могу заставить его играть, нажав на видео еще раз, что побуждает его играть с использованием QuickTime.

Но как мне заставить его играть с QuickTime автоматически?

3 ответа

Извините, но в iOS это невозможно. Согласно документации Apple,

"... встроенные медиафайлы не могут воспроизводиться автоматически в Safari на iOS - пользователь всегда запускает воспроизведение".

Ограничение является постоянным независимо от сетевого подключения, так как оно является как решением о пропускной способности, так и решением пользователя.

Обновление, октябрь 2016 года. Стоит отметить, что теперь, когда iOS 10 вышла и завоевывает значительную долю рынка, люди могут использовать изменения в способе воспроизведения видео на iOS 10, чтобы получить поведение автозапуска. Если в видео нет звуковых дорожек или тэг отключен, возможно автоматическое воспроизведение. Более подробная информация доступна в этом блоге. API YouTube может справиться с этим довольно скоро.

Начиная с iOS 4, UIWebView имеет mediaPlaybackRequiresUserAction имущество. Я не могу сказать, реализуете ли вы это в Интернете или в собственном приложении, но установив это NO в нативном приложении должно быть разрешено автоматическое воспроизведение.

Вы можете использовать API YouTube iFrame на iOS.

Другие вопросы по тегам