Sign Up

Sign Up to our social questions and Answers Engine to ask questions, answer people’s questions, and connect with other people.

Have an account? Sign In

Have an account? Sign In Now

Sign In

Login to our social questions & Answers Engine to ask questions answer people’s questions & connect with other people.

Sign Up Here

Forgot Password?

Don't have account, Sign Up Here

Forgot Password

Lost your password? Please enter your email address. You will receive a link and will create a new password via email.

Have an account? Sign In Now

You must login to ask a question.

Forgot Password?

Need An Account, Sign Up Here

Please briefly explain why you feel this question should be reported.

Please briefly explain why you feel this answer should be reported.

Please briefly explain why you feel this user should be reported.

Sign InSign Up

The Archive Base

The Archive Base Logo The Archive Base Logo

The Archive Base Navigation

  • SEARCH
  • Home
  • About Us
  • Blog
  • Contact Us
Search
Ask A Question

Mobile menu

Close
Ask a Question
  • Home
  • Add group
  • Groups page
  • Feed
  • User Profile
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Buy Points
  • Users
  • Help
  • Buy Theme
  • SEARCH
Home/ Questions/Q 9187345
In Process

The Archive Base Latest Questions

Editorial Team
  • 0
Editorial Team
Asked: June 17, 20262026-06-17T19:44:43+00:00 2026-06-17T19:44:43+00:00

I am testing HTML5’s video API. The plan is to have a video play

  • 0

I am testing HTML5’s video API. The plan is to have a video play with an effect, like making it black and white. I have and working together using a buffer. I take the current video frame and copy to the scratch buffer where I can process it. The problem is the rate at which it runs.

The Video API of HTML5 has the ‘timeupdate’ event. I tried using this to have the handler process frames, once for every frame, but it runs at a slower rate than the video.

Any ideas to speed up processing frames?

  • 1 1 Answer
  • 0 Views
  • 0 Followers
  • 0
Share
  • Facebook
  • Report

Leave an answer
Cancel reply

You must login to add an answer.

Forgot Password?

Need An Account, Sign Up Here

1 Answer

  • Voted
  • Oldest
  • Recent
  • Random
  1. Editorial Team
    Editorial Team
    2026-06-17T19:44:45+00:00Added an answer on June 17, 2026 at 7:44 pm

    You can get much more frequent redraws by using requestAnimationFrame to determine when to update your canvas, rather than relying on timeupdate, which only updates every 200-250ms. It’s definitely not enough for frame-accurate animation. requestAnimationFrame will update at most every 16ms (approx 60fps), but the browser will throttle it as necessary and sync with video buffer draw calls. It’s pretty much exactly what you want for this sort of thing.

    Even with higher frame rates, processing video frames with a 2D canvas is going to be pretty slow. For one thing, you’re processing every pixel sequentially in the CPU, running Javascript. The other problem is that you’re copying around a lot of memory. There’s no way to directly access pixels in a video element. Instead, you have to copy the whole frame into a canvas first. Then, you have to call getImageData, which not only copies the whole frame a second time, but it also has to allocate the whole block of memory again, since it creates a new ImageData every time. Would be nice if you could copy into an existing buffer, but you can’t.

    It turns out you can do extremely fast image processing with WebGL. I’ve written a library called Seriously.js for exactly this purpose. Check out the wiki for a FAQ and tutorial. There’s a Hue/Saturation plugin you can use – just drop the saturation to -1 to get your video to grayscale.

    The code will look something like this:

    var composition = new Seriously();
    var effect = composition.effect('hue-saturation');
    var target = composition.target('#mycanvas');
    effect.source = '#myvideo';
    effect.saturation = -1;
    target.source = effect;
    composition.go();
    

    The big down side of using WebGL is that not every browser or computer will support it – Internet Explorer is out, as is any machine with old or weird video drivers. Most mobile browsers don’t support it. You can get good stats on it here and here. But you can get very high frame rates on pretty large videos, even with much more complex effects.

    (There is also a small issue with a browser bug that, oddly enough, shows up in both Chrome and Firefox. Your canvas will often be one frame behind the video, which is only an issue if the video is paused, and is most egregious if you’re skipping around. The only workaround seems to be to keep forcing updates, even if your video is paused, which is less efficient. Please feel free to vote those tickets up so they get some attention.)

    • 0
    • Reply
    • Share
      Share
      • Share on Facebook
      • Share on Twitter
      • Share on LinkedIn
      • Share on WhatsApp
      • Report

Sidebar

Related Questions

I'm testing a new TeeChart HTML5/javascript and I have a problem with zoom. When
How can I listen to the events play/stop/pause of a HTML5 video? I tried
I am trying to simply play an HTML5 video which will be compatible with
I'm working on HTML5 Boilerplate template and Modernizr. While testing some features, I tried
[answered] I'm testing my browser's fps for an html5 game. I have this code:
I've been testing an HTML5 webapp on eReaders, and I got it mostly working,
On a dev site, i've been testing mp4 files for html5 play in safari.
I am currently working on a university project, using HTML5. I have been writing
We have a customized Flash/HTML5 video player we use for users on our site.
i'm testing a jQuery video background plugin and i don't have the same behavior

Explore

  • Home
  • Add group
  • Groups page
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Users
  • Help
  • SEARCH

Footer

© 2021 The Archive Base. All Rights Reserved
With Love by The Archive Base

Insert/edit link

Enter the destination URL

Or link to existing content

    No search term specified. Showing recent items. Search or use up and down arrow keys to select an item.