Search code examples
javascripthtmlcanvaskineticjsretina-display

Improving slow canvas animation on Retina iPad - KineticJS


I am using KineticJS to perform HTML Canvas animations. Animations work perfectly on all desktop browsers, and non retina iDevices (including iPad mini). However, from a retina device (browser or in-app webview using appcelerator) these animations are very sluggish. I have seen similar issues with canvas animations on retina display, but have not found any true solution.

My Stage constructor is 1024w x 768h. All images are preloaded. And animations are constructed using the preloader's callback function.

If I reduce my stage size by half (and scale inner contents accordingly), the animation will play almost normally (still a little choppier than other ipads). My only justification for trying this was my very poor understanding that a retina display is two 'points'/pixel.

Any insight or ideas are welcome. My next attempt is to start changing image resolutions, rather than scaling dynamically.


Solution

  • This is due to a feature added four months ago. KineticJS will recognize if the pixelratio of the device is over 1 and try to make it as sharp as with pixelratio 1. The problem is, like you have found out, that it kills the performance to the point that it's useless. We have found this to be the case for our use cases.

    Our solution: We commented out the pixel ratio part in KineticJS and hard coded it to always be one.

    Pros:

    The performance goes back up to normal

    Cons:

    Image is not as sharp

    This is the part where we have made the change:

    Kinetic.Canvas = function(width, height, pixelRatio) {
    // eduplus change to fix pixel ratio performance problems
    this.pixelRatio = 1; //pixelRatio || _pixelRatio;
    

    When discussing this with Eric, he made comments to investigate pixel ratio performance, but I don't think he has had the time to do that yet. Hope this helps!