Skip to content

webscreens/requestshowmedia

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

26 Commits
 
 
 
 
 
 
 
 
 
 

Repository files navigation

requestShowMedia.js

A Presentation API prollyfill for the HTMLMediaElement.

Demo

A second screen <video> sharing demo displays a <video> contained on a web page on a second screen and allows its playback to be controlled using the standard HTMLMediaElement methods play(), pause(), and fastSeek(time). If an experimental Chromium build is used, the video is displayed on a second screen attached to your system using HDMI, VGA, Miracast, or WiDi. Or, if a Chromecast device is available, the video is sent there (requires Chrome with the Google Cast Extension installed). The demo also works in modern browsers (tested with latest Chrome, Firefox, and Safari) without any extensions by emulating a second screen using a new window.

How It Works

  1. Include the requestshowmedia.js script to your page, copy requestshowmedia.js and player.html to the same directory (or see demo/index.html for advanced configuration).
  2. Include the cast_sender.js script that implements the Chrome Sender API for Chromecast support.
  3. Invoke requestShow() on the video element to show the video on the second screen.
  4. Use the standard HTMLMediaElement methods to control the playback on the second screen.
  5. Enjoy.
<script src="requestshowmedia.js" data-player="player.html"></script>
<script src="https://www.gstatic.com/cv/js/sender/v1/cast_sender.js"></script>
<video src="myvideo.mp4"></video>
<script>
var v = document.querySelector('video');
v.requestShow();

// Standard HTMLMediaElement methods
v.play();
v.pause();
v.fastSeek(time);

// Experimental extensions to the HTMLMediaElement
v.ontimeupdateonsecondscreen = function (event) {
  console.log(event.detail.currentTimeOnSecondScreen);
};

v.onclosesecondscreen = function () {
  console.log('Second screen closed.');
};

v.exitShow();
</script>

Next Steps

  • Track and help evolve the Presentation API
  • Implement the missing HTMLMediaElement methods
  • Make requestShow() return a promise when the browser support improves (or use a polyfill)
  • Use native fastSeek(time) when browsers implement it

Credits

Video trailer from http://www.bigbuckbunny.org/, an open source http://www.blender.org/ project. Transcoded versions from https://github.com/georgepaterson/jquery-videobackground.

About

A Presentation API prollyfill for the HTMLMediaElement

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • JavaScript 86.2%
  • CSS 13.8%