25

I know this question has been asked a number of times, and I've looked through every single one of them here on StackOverflow.

I'm simply trying to loop a 5 second MP4 video in an HTML5 player and have it be seamless. I've tried both jwplayer and video.js, both locally and on webspace, and neither do the trick. I've tried using the "ended" events; I've tried preloading/prebuffering; I've tried listening for the final second of a video and then seeking to the beginning to bypass the stop/play events entirely. I still always see jitter, and I still always see the loading icon (latest Chrome & Firefox).

For reference, here's some of my latest code for video.js:

<video id="loop_me" class="video-js vjs-default-skin vjs-big-play-centered"
  width="640" height="480"
  data-setup='{"controls": false, "autoplay": true, "loop": true, "preload": "auto"}'>
  <source src="video/loop_me.mp4" type="video/mp4" />
</video>

<script type="text/javascript">
  var myPlayer = videojs("loop_me");
  videojs("loop_me").ready(function(){
    this.on("timeupdate", function(){
      var whereYouAt = myPlayer.currentTime();
      if (whereYouAt > 4) {
        myPlayer.currentTime(1);
      }
    });
  });
</script>

Has anyone managed to do this successfully? And, if so, could you please post a complete solution? I don't normally ask for or want those, but I think it might be necessary this time.

emaxsaun
  • 4,191
  • 2
  • 13
  • 13
daveycroqet
  • 2,667
  • 7
  • 35
  • 61
  • 1
    you are probably going to have to use the `MediaSource` capabilities of HTML5 to feed your video to the video element as a continual stream if you want to avoid the pause while resetting the playhead to the beginning - see http://updates.html5rocks.com/2011/11/Stream-video-using-the-MediaSource-API for example – Offbeatmammal Dec 24 '13 at 15:23
  • 1
    d'oh .... sometimes the obvious worked wonders.... the `loop` property: ` – Offbeatmammal Dec 25 '13 at 20:41
  • 2
    The accepted answer is not seamless http://jsfiddle.net/blowsie/QQTqn/ – Blowsie Apr 04 '14 at 09:02
  • 1
    If you happen to be using a `poster` attribute in your real code, try removing that after the video starts playing. For me this fixed a flicker between loops in Chrome where the poster image would display for a fraction of a second. – Josh Harrison Jun 26 '14 at 16:45

4 Answers4

3

Try this:
1) edit your video this way:
[1s][2s][3s][4s][5s]
cut 1st second block of the video and append it 2x to the end like this:
[2s][3s][4s][5s][1s][1s]

2) Use code:

<video id="vid"  width="100" height="50" loop autoplay preload="true">
    <source src="something.mp4" type="video/mp4">
</video>

<!-- Goes to end of body of course -->
<script>
    var vid = document.getElementById("vid");
    vid.addEventListener("timeupdate", function () {
        if(this.currentTime >= 5.0) {
            this.currentTime = 0.0;
        }
    });
</script>

The idea behind this is to make the video seamless (the end of the video is the beginning of the video). Also, you have to make sure the video never ends. The loop attribute works with smaller video files but you see a black image at the end of the video if too large (before the next looping iteration). Essentially before the video ends, you are seeking back to 0.0s.

I hope that helps.

Quin
  • 31
  • 3
  • 2
    Shouldn't this be: [1s][2s][3s][4s][5s][1s] As with your solution, there is flash of the video starting frame just before this loops. – Rauli Rajande Dec 20 '16 at 07:03
1

Heureka!

We've found the actual, real, work-around-free solution to this problem over at where I work. It explains the inconsistent behavior through multiple developers as well.

The tl;dr version is: Bitrates. Who would've guessed? What I suppose is that many people use standard values for this that usually are around 10 Mbit/s for HD videos if you use the Adobe Media Encoder. This is not sufficient. The correct value would be 18 Mbit/s or maybe even higher. 16 is still a bit janky. I cannot express how well this works. I've, by now, tried the messiest workarounds for about five hours until I found this together with our video editor.

I hope this helps everyone and saves you tons of time!

Merritt6616
  • 187
  • 1
  • 4
  • 1
    Ooh, this is something that I haven't looked into! I have a large number of short videos that are supposed to loop and it always feels weird as we never got it to loop perfectly. I'm going to take a look into what our video bitrates are and see what I find. – Austin Burk Dec 22 '18 at 15:43
  • 1
    I just tested this at 2, 8, 10, 16, 20, 24 mbit bitrates and sadly, while the higher rates do help, it's still present :( Given the filesize increase of higher bitrate for a simple video (just for some rotating models), I'll probably have to just loop the sequence a few times and export at a lower bitrate :S remarkably frustrating issue – waffl Aug 16 '20 at 16:33
  • Sorry for another reply, actually the only thing that actually does work for me is lowering the resolution and bitrate which seems to allow the browser to keep it buffered better - who knows why looping an 800kb constant bit rate video is still an issue in 2020 – waffl Aug 16 '20 at 16:48
  • Yeah, nowadays what I can recommend is using lottie, period (https://airbnb.design/lottie/). Strange that the higher bitrates didn't work for you, sorry about that :/ – Merritt6616 Jan 26 '21 at 13:41
  • Necro++ I know this is 7years old., @Merritt6616 how is lottie used for animating/ transitioning html5 video? Would you mind giving a link to a description or tutorial. The Lottie link isn't that informative about the video transition topic. Thanks! – Stephan Luis Apr 30 '21 at 15:47
-1
  1. Doozerman and Offbeatmammal are correct: no Javascript is required to loop video in HTML5.

  2. About that pause before each iteration: in some browsers we, too, can observe a pause at the end of the loop in our tests. E.g., in the inline, 22-second demo video at... http://www.externaldesign.com/Marlin-Ouverson.html

...under OS X, we see a ~0.5 sec. pause before the loop repeats -- only in Firefox and Safari; Chrome and Opera both play the loop without noticeable pause. But note: for desktop/laptop browsers, the above page provides an added full-screen background video that appears to loop without pause in all four of the above browsers.

  • 1
    Yes but why does that video not pause? Is it a screen size issue? – Hari Honor Oct 07 '15 at 15:43
  • If the code is correct and set to loop, there _should_ not be a pause -- but HTML5 video is still relatively new, so it appears not every web browser is interpreting the HTML5 standard in the same way. For commercial web sites and high-visibility content, we typically code to the standard, test thoroughly on many browsers on both OS X and Windows, perhaps on Linux, and then come up with custom code and/or design workarounds (possibly involving Javascript, CSS, et al.) for the browsers that don't exhibit standard behavior. – Marlin Ouverson Oct 12 '15 at 04:18
-8

You don't need any extra scripts for that kind of stuff.

The "video" tag has built in loop attribute, use this and your video will loop.

<video id="loop_me" class="video-js vjs-default-skin vjs-big-play-centered" width="640" height="480" controls autoplay loop>
  <source src="video/loop_me.mp4" type="video/mp4" />
</video>

You can also add preload attribute if you wanted to. If you want, you can find more information about the video tag here: HTML video Tag

Edit: Oops. Didn't notice Offbeatmammals comment under your question. :)

Doozerman
  • 235
  • 2
  • 8
  • 6
    The loop from the html5 video is not seamless tho :( http://jsfiddle.net/blowsie/QQTqn/ – Blowsie Apr 03 '14 at 14:12
  • 1
    @Blowsie Your fiddle actually plays seamlessly for me in Firefox, but in Chrome it shows a loading icon each time it loops. – daveycroqet Apr 05 '14 at 21:48
  • @daveycroqet lets hope chrome can fix this bug soon – Blowsie May 13 '14 at 15:44
  • 1
    You can do this with canvas. Here is my answer about this: http://stackoverflow.com/questions/34097834/html5-video-how-to-do-a-seamless-play-and-or-loop-of-several-videos/34137680#34137680 – Tanuki Dec 08 '15 at 13:27
  • 2
    As of 2018 this plays seamlessly in Chrome and Firefox. – antonyh Oct 25 '18 at 15:47
  • as of 2020, this works on Firefox with a non standard setting (allow autoplay). and just doesn't seem to work on chrome anymore. but that doesn't make the answer so negatively wrong... – cregox May 19 '20 at 23:12
  • fixed it, thanks to https://robsimpson.digital/articles/autoplay-html5-video + simply add `muted playsinline`. also recommend to replace with and height with style `video { width: 100%; max-height: 100%; }` – cregox May 19 '20 at 23:26