Optimizing ZIM

image

Here is a post about optimizing ZIM. We can add to it as it goes. Here are some basics. Often, we do not need to do these things. But if you notice performance issues, then let us know. Usually, drastic performance issues are inefficient code like adding event functions in a Ticker - do not do this.

  1. ROLLOVERS
    Generally... getting pixel color at the mouse is one of the slower things. ZIM Frame defaults to having rollovers (unless mobile) which uses pixel color. So... if you do not need to interact with an object you can add noMouse() to it. noMouse() can also be added to a Container with lots of things in it. If you need the mouse later then add mouse().

  2. STAGE UPDATE
    Stage update takes processing and reduces batteries. We use a Ticker that queues any changes like dragging, animating, etc. and calls a single stage update afterwards. Avoid unnecessary stage update like if something is already animating, don't add your own S.update(). Do not update in a loop but rather after the loop, etc.

  3. FRAMES
    The amount of vectors that needs to be drawn on update will also affect performance. For instance, if you have a lot of text or other vector heavy code like 100s of shapes that do no change... then consider adding them to one Frame and then add your interface that needs to be interactive to another Frame. This way, when you roll over interface, it does not have to update all the vectors.

  4. CACHE
    To get smoother animation, cache vectors like text and shapes. Then uncache them when the animation is done. Do not cache images - there is no need.

  5. HITTESTS
    Use equation-based hitTests when possible - these are: hitTestBounds (for two rectangular things), hitTestCircleRect(), hitTestCircles(), and hitTestGrid().

  6. GPU
    For some types of game and art, the GPU might help. There are gpu and gpuObj (for setting anti-aliasing) parameters in Frame that uses StageGL. Everything will need to be a bitmap though to see it on StageGL. So text and shapes must be cached. Consider using a Frame for the GPU and then a standard Frame for interface.

  7. SPRITE
    Use a Sprite for emitting lots of particles. Even if the particles are shapes, if they are put in a Sprite it is one call to the GPU and that's it.

  8. REUSE
    If you have hundreds of monsters being made over the course of a game, reuse ones rather than remaking. This is called pooling - we do it for the Emitter.

  9. DISPOSE
    If you no longer need something use dispose() rather than removeFrom(). If you are going to use it again then use removeFrom() rather than dispose(). To properly dispose, you need to use circle.dispose() and then circle = null. We cannot remove the references in your code.

  10. EVENTS
    Make sure your event functions are running as expected and not thousands of times - just do a zogy() inside one and see in the console it is behaving. If you have your own custom objects (not ZIM objects) with events, make sure that you remove the events before you dispose your objects otherwise they stay around and do not get garbage collected. We went through ZIM in version TEN and checked all our disposes to make sure there were no references left.

  11. EFFECTS
    Watch effects like Blur, Shadow, etc. they can be processor intensive. And too many drop shadows as well - like on buttons, etc. Probably fine unless you have a whole page of buttons.

  12. DESIGN
    Plan your projects. If there is too much on the screen at once, then reduce it. Have multiple pages. Again, do not worry unless you start to notice a slowdown. This will probably be noticed on older mobile devices first. You can test to see if M is true and if so, they you are on mobile so make sure to adjust things like Emitters and Physics so performance is acceptable also check multiple animations. Remember to cache what you are animating - this is a must on older mobile.

3 Likes

I think compressing all code into one file for final product too is an important step to get faster load times. And probably adds up to performance too.

Good point. ZIM Distill minifies code on the ZIM side. I have not used it in a while but might help some. ZIM - DISTILL - ZIM Minify Tool - ZIMjs - under CODE > Tools.

2 Likes

Great checklist. Thank you Dan.

1 Like

Good to hear from you Iestyn! Hope all is well!

1 Like

Thank you Dan,

I've been busy firefighting but all is good. I hope all is well with you too. Now things are calmer I'm trying to get back into coding and content creation (I've discovered it's true that if you don't use it you lose it).

Oh BTW, is the discord site being phased out? Just wondering where the best place to post is.

Great to see some of the exciting developments with ZIM. You're doing a great job.

1 Like

Discord is still going although not too many people say things there. We phased out Slack. So here is the best place to catch us - or on Discord is fine too.

1 Like

Slack was good but forum mich better now :slight_smile: .. who reached the most topics? :slight_smile:

Was just doing some testing and we are losing 5 fps for showing a drop shadow on a button. So... would suggest using this on Buttons:

new Button({shadowColor:M?-1:null})

or

STYLE = {shadowColor:M?-1:null} // for all shadows off on Mobile
1 Like

make shadow not standard for buttons.. I set it always out with style..