--- title: Animação SVG com SMIL slug: Web/SVG/SVG_animacao_com_SMIL tags: - Animação - Animação de SVG - Firefox 4 - Gecko 2.0 - SVG translation_of: Web/SVG/SVG_animation_with_SMIL ---
Embora o Chrome 45 tenha revogado SMIL em favor das animações CSS e da Web, os programadores do Chrome suspenderam essa revogação.
Firefox 4 introduziu suporte para a animação de SVG utilizando Synchronized Multimedia Integration Language (SMIL). SMIL permite-lhe:
This is done adding an SVG element like
inside the SVG element to animate. Below are examples for the four different ways.The following example animates the cx attribute of a circle. To do so, we add an
If you want to animate more attributes inside the same element, just add more {{ SVGElement("animate") }} elements.
<svg width="300" height="100"> <title>Attribute Animation with SMIL</title> <rect x="0" y="0" width="300" height="100" stroke="black" stroke-width="1" /> <circle cx="0" cy="50" r="15" fill="blue" stroke="black" stroke-width="1"> <animate attributeName="cx" from="0" to="500" dur="5s" repeatCount="indefinite" /> </circle> </svg>
{{ EmbedLiveSample('Animating_attributes_of_an_element', '100%', 120) }}
<svg width="300" height="100"> <title>SVG SMIL Animate with transform</title> <rect x="0" y="0" width="300" height="100" stroke="black" stroke-width="1" /> <rect x="0" y="50" width="15" height="34" fill="blue" stroke="black" stroke-width="1"> <animateTransform attributeName="transform" begin="0s" dur="20s" type="rotate" from="0 60 60" to="360 100 60" repeatCount="indefinite" /> </rect> </svg>
{{ EmbedLiveSample('Animating_the_transform_attributes', '100%', 120) }}
The path is defined the same way as in
In this example, a blue circle bounces between the left and right edges of a black box, over and over again, indefinitely. The animation here is handled by the {{ SVGElement("animateMotion") }} element. In this case, we're establishing a path consisting of a MoveTo command to establish the starting point for the animation, then the Horizontal-line command to move the circle 300 pixels to the right, followed by the Z command, which closes the path, establishing a loop back to the beginning. By setting the value of the repeatCount attribute to indefinite
, we indicate that the animation should loop forever, as long as the SVG image exists.
<svg xmlns="http://www.w3.org/2000/svg" width="300" height="100"> <title>SVG SMIL Animate with Path</title> <rect x="0" y="0" width="300" height="100" stroke="black" stroke-width="1" /> <circle cx="0" cy="50" r="15" fill="blue" stroke="black" stroke-width="1"> <animateMotion path="M 0 0 H 300 Z" dur="3s" repeatCount="indefinite" /> </circle> </svg>
{{ EmbedLiveSample('Example_1_Linear_motion', '100%', 120) }}
Same example as before with a curved path and following the direction of the path.
<svg width="300" height="100"> <title>SVG SMIL Animate with Path</title> <rect x="0" y="0" width="300" height="100" stroke="black" stroke-width="1" /> <rect x="0" y="0" width="20" height="20" fill="blue" stroke="black" stroke-width="1"> <animateMotion path="M 250,80 H 50 Q 30,80 30,50 Q 30,20 50,20 H 250 Q 280,20,280,50 Q 280,80,250,80Z" dur="3s" repeatCount="indefinite" rotate="auto" /> </rect> </svg>
{{ EmbedLiveSample('Example_2_Curved_motion', '100%', 120) }}