example.html 4.14 KB
<!DOCTYPE html>
<html>
<head>
  <meta charset="utf-8">
  <title>video.js HLS Plugin Example</title>

  <link href="http://vjs.zencdn.net/4.0/video-js.css" rel="stylesheet">
  
  <!-- video.js -->
  <script src="libs/video-js/src/js/core.js"></script>
  <script src="libs/video-js/src/js/core-object.js"></script>
  <script src="libs/video-js/src/js/events.js"></script>
  <script src="libs/video-js/src/js/lib.js"></script>
  <script src="libs/video-js/src/js/component.js"></script>
  <script src="libs/video-js/src/js/button.js"></script>
  <script src="libs/video-js/src/js/slider.js"></script>
  <script src="libs/video-js/src/js/menu.js"></script>
  <script src="libs/video-js/src/js/player.js"></script>
  <script src="libs/video-js/src/js/control-bar/control-bar.js"></script>
  <script src="libs/video-js/src/js/control-bar/play-toggle.js"></script>
  <script src="libs/video-js/src/js/control-bar/time-display.js"></script>
  <script src="libs/video-js/src/js/control-bar/fullscreen-toggle.js"></script>
  <script src="libs/video-js/src/js/control-bar/progress-control.js"></script>
  <script src="libs/video-js/src/js/control-bar/volume-control.js"></script>
  <script src="libs/video-js/src/js/control-bar/mute-toggle.js"></script>
  <script src="libs/video-js/src/js/control-bar/volume-menu-button.js"></script>
  <script src="libs/video-js/src/js/poster.js"></script>
  <script src="libs/video-js/src/js/loading-spinner.js"></script>
  <script src="libs/video-js/src/js/big-play-button.js"></script>
  <script src="libs/video-js/src/js/media/media.js"></script>
  <script src="libs/video-js/src/js/media/html5.js"></script>
  <script src="libs/video-js/src/js/media/flash.js"></script>
  <script src="libs/video-js/src/js/media/loader.js"></script>
  <script src="libs/video-js/src/js/tracks.js"></script>
  <script src="libs/video-js/src/js/json.js"></script>
  <script src="libs/video-js/src/js/setup.js"></script>
  <script src="libs/video-js/src/js/plugins.js"></script>

  <!-- Media Sources plugin -->
  <script src="libs/videojs-media-sources.js"></script>
  <!-- HLS plugin -->
  <script src="src/video-js-hls.js"></script>
  <script src="src/flv-tag.js"></script>
  <script src="src/exp-golomb.js"></script>
  <script src="src/h264-stream.js"></script>
  <script src="src/aac-stream.js"></script>
  <script src="src/segment-parser.js"></script>
  
  <!-- example MPEG2-TS segments -->
  <!-- bipbop -->
  <!-- <script src="test/tsSegment.js"></script> -->
  <!-- bunnies -->
  <script src="test/tsSegment-bc.js"></script>

</head>
<body>
  <video id='video'
         class="video-js vjs-default-skin"
         height="300"
         width="600"
         controls>
  </video>
  <script>
    var video, mediaSource;

    // initialize the player
    videojs.options.flash.swf = "libs/video-js.swf";
    video = videojs('video');

    // create a media source
    mediaSource = new videojs.MediaSource();

    mediaSource.addEventListener('sourceopen', function(event){
      var tag, bytes, parser, i, everything, old;

      // feed parsed bytes into the player
      var sourceBuffer = mediaSource.addSourceBuffer('video/flv; codecs="vp6,aac"');
      parser = new videojs.hls.SegmentParser();
      // var header = parser.getFlvHeader();
      everything = parser.getFlvHeader();
      // sourceBuffer.appendBuffer(header, video);

      parser.parseSegmentBinaryData(window.bcSegment);

      while (parser.tagsAvailable()) {
        tag = parser.getNextTag();
        old = everything;
        everything = new Uint8Array(old.byteLength + tag.bytes.byteLength);
        everything.set(old);
        everything.set(tag.bytes, old.byteLength);
      }
      console.log('sending ' + everything.byteLength + 'B');
      // var iframe = document.createElement('iframe');
      // iframe.src = 'data:video/x-flv;base64,' + window.btoa((Array.prototype.map.call(everything, function(byte) {
        // return String.fromCharCode(byte);
      // })).join(''));
      //document.body.appendChild(iframe);
      sourceBuffer.appendBuffer(everything, video);
    }, false);

    url = videojs.URL.createObjectURL(mediaSource);
  
    video.src({ 
      src: url, 
      type: "video/flv"
    });
  </script>
</body>
</html>