Object Partners

This post will discuss how to solve the problem of playing a Youtube video from a press from an initial starting image, and then replacing the image when the video has ended playing.

Over the last two years on a few different web projects, I have had occasion to need to trigger a Youtube video to play from a Jquery click event on a PNG image button or HTML5 element. When implementing frontend development For example, a JPG rollover has CSS3 styles simulating button presses, which loads the Youtube Player Javascript API and fires the OnPlayerReady callback.

Recently, it was needed to replace the Jpeg clicked button or Div element when the video finished playing. In this case, it is necessary to detect the Youtube player state and call the player.destroy() method, along with reseting any other DOM elements that may have been effected during the instantiation of the player object. This all needs to be reliable for browser versions at least as old as IE8, as well as, mobile devices, iPhones, iPads, and Android tablets and phones.

Skip to full code Working JSfiddle

How it works

Basically, this works by downloading the Youtube player API asynchronously, then instantiating a new player object and assigning the appropriate event listeners

var tag = document.createElement('script');  
    tag.src = "https://www.youtube.com/iframe_api";  
    var firstScriptTag = document.getElementsByTagName('script')[0];  
    firstScriptTag.parentNode.insertBefore(tag, firstScriptTag);

In this example, I have added a few other pieces that were useful in my particular case, namely a rollover image for a button which is attached as the background-image of a div that holds the player div.

$("#container").mouseenter(function(){  
        $(this).addClass('hover-state');  
    }).mouseleave(function(){  
        $(this).removeClass('hover-state');  
    });

For the purposes of simplicity I am simply using some image urls that have been converted to data uris

.inactive-state {  
        background-repeat: no-repeat;  
        background-size: 100%;  
        background-image: url('');  
    }  
    .hover-state {  
        background-image: url('');  
    }

I have also added an example of some additional embellishment that can be added to the event handler functions, clicking the element and then the onStateChange.

$("#container.click-to-play-video").click(function(){  
        $('#head').css({"background-color":"black"});

and

$("#container.click-to-play-video").click(function(){  
        $('#head').css({"background-color":"black"});function onPlayerStateChange(event) {  
        if(event.data == YT.PlayerState.ENDED) {  
            player.destroy();  
            $('#head').css({"background-color":"#aaa"});  
        }  
    }

I found that this code will work in a wide range of browsers, tested backward to IE8, as well as mobile devices and phones. As always, testing the code in every platform that your project supports is paramount to success.

The Full Code

<!DOCTYPE html>  
<html>  
<head>  
    <meta charset="utf-8">  
    <title>Triggering a Youtube Video from Clicking a Button Image and Replacing when Ended</title>  
</head>  
<body>  
<style type="text/css">  
    #head {  
        background-color: #aaa;  
        width:100%;  
    }  
    #container {  
        cursor:pointer;  
        width:320px;  
        height:180px;  

        margin:auto;  
        position:relative;  
    }  

    .inactive-state {  
        background-repeat: no-repeat;  
        background-size: 100%;  
        background-image: url('');  
    }  
    .hover-state {  
        background-image: url('');  
    }  
</style>  
<section id="head">  
    <div id="container" class="click-to-play-video inactive-state">  
        <div id="player" class="home-player"></div>  
    </div>  
</div>  

<script src="//ajax.googleapis.com/ajax/libs/jquery/1.10.1/jquery.min.js"></script>  
<script type="text/javascript">  
    $("#container").mouseenter(function(){  
        $(this).addClass('hover-state');  
    }).mouseleave(function(){  
        $(this).removeClass('hover-state');  
    });  

    $("#container.click-to-play-video").click(function(){  
        $('#head').css({"background-color":"black"});  

        player = new YT.Player('player', {  
            width : '320',  
            height : '180',  
            videoId : 'qlEUrEVqDbo',  
            playerVars: { 'autoplay': 1 },  
            events : {  
                'onReady' : onPlayerReady,  
                'onStateChange' : onPlayerStateChange  
            }  
        });  
    });  

    var tag = document.createElement('script');  
    tag.src = "https://www.youtube.com/iframe_api";  
    var firstScriptTag = document.getElementsByTagName('script')[0];  
    firstScriptTag.parentNode.insertBefore(tag, firstScriptTag);  

    var player;  
    function onPlayerReady(event) {  
        //event.target.playVideo();  
    }  
    function onPlayerStateChange(event) {  
        if(event.data == YT.PlayerState.ENDED) {  
            player.destroy();  
            $('#head').css({"background-color":"#aaa"});  
        }  
    }  
</script>  
</body>  
</html>

Was this content useful? Follow Nate Flink on Twitter!

Share this Post

Related Blog Posts

Unknown

How to implement Advanced Process Control (APC) in a manufacturing facility to improve process ca...

June 14th, 2013

How to implement Advanced Process Control (APC) in a manufacturing facility to improve process capability and product quality

Kevin Beatty
Unknown

Technical tips and pitfalls in Jive SBS

March 20th, 2013

Object Partners
Unknown

Connecting to the built-in Mac VNC server from a Windows machine

February 26th, 2013

Connecting to the built-in Mac VNC may cause the host machine to freeze up when connecting from Windows. Included are some potential fixes.

Igor Shults

About the author