Вопрос по javascript – Почему не анимированный GIF вместо анимированных CSS-спрайтов?

23

Error: User Rate Limit Exceeded

Error: User Rate Limit Exceeded

http://www.google.com/doodles/eadweard-j-muybridges-182nd-birthday (in fact, Google used this technique in other Doodles too) https://everyme.com/ ('me' logo) and many more...

Error: User Rate Limit ExceededThe reason I m asking is that I couldn't figure out as in both cases we need to generate the intermediate frames (mostly using tweening technique).

Error: User Rate Limit Exceededdocs.google.com/document/… Nick Josevski

Ваш Ответ

2   ответа
3

35

Control

You have no control over animated GIFs. You can't start them, you can't stop them. They just animate as soon as they load.

With sprites, you can control the animation. You can start, stop and react to browser events, pan through the animation. For example, Google Doodles usually activate when you click on them.

A nifty GIF control system can be found in the 9gag. You can start them by appending them to the DOM, and stop them by removing them and swapping them with a pre-generated "first-frame view". But that's as far as GIFs go.

Independent Instances

When you load multiple instances of the same GIF, all these instances use the same image across the page and move at the same time. If you have a row of dancing unicorns GIFs, they'd be dancing at the same time. Synchronized dancing!

But with sprites, even if you are using the same images, the animation relies on the underlying script. So if one sprite is animated by one script and another by another script, both animations can run independently, and differently from one another.

This saves you from creating another GIF and it's easy to modify since you are only changing the script.

Ensuring smooth animation

Animated GIFs just animate while loading, and when the internet is slow, the animations freeze up until more of the image gets loaded.

In contrast, the advantage of sprites is you can pre-load them, ensure all images load beforehand. This makes sure that the resources used for that animation are already loaded prior to animation to make sure it animates as smooth as possible.

However, GIFs are still images. You can dynamically load them off the DOM and listen for a load event before you append them to the DOM.

Partial rendering

With PNG sprites, you can do "partials" in the animation, breaking an animation scene to parts. For example, when a character stands still, but the arms are waving. You don't need to animate the entire character, or the entire scene. You can place an element depicting the sprite of the character's body in a "freeze" state while the arms are a different element that is animating. This conserves space and size of the sprite sheet. A good example for this was the 2012 Mother's Day Doodle by Google.

In contrast, most of the time, every frame in a GIF animation is whole image, and animates whether or not anything in it moves. The more frames, the bigger the size of the GIF.

GIFs just don't scale

GIFs were meant for icons. The ratio of file size to image size don't scale up that well in GIFs as compared with PNG and JPG.

Error: User Rate Limit Exceeded

Похожие вопросы