1 page.title=Animation Resources 2 parent.title=Resource Types 3 parent.link=available-resources.html 4 @jd:body 5 6 <div id="qv-wrapper"> 7 <div id="qv"> 8 <h2>In this document</h2> 9 <ol> 10 <li><a href="#Property">Property Animation</a></li> 11 <li><a href="#View">View Animation</a> 12 <ol> 13 <li><a href="#Tween">Tween animation</a></li> 14 <li><a href="#Frame">Frame animation</a></li> 15 </ol> 16 </li> 17 </ol> 18 <h2>See also</h2> 19 <ol> 20 <li><a href="{@docRoot}guide/topics/graphics/view-animation.html">View Animation</a></li> 21 <li><a href="{@docRoot}guide/topics/graphics/prop-animation.html">Property Animation</a></li> 22 </ol> 23 </div> 24 </div> 25 26 27 <p>An animation resource can define one of two types of animations:</p> 28 29 <dl> 30 <dt><a href="#Property">Property Animation</a></dt> 31 <dd>Creates an animation by modifying an object's property values over a set period 32 of time with an {@link android.animation.Animator}.</dd> 33 <dt><a href="#View">View Animation</a></dt> 34 <dd> 35 <p>There are two types of animations that you can do with the view animation framework:</p> 36 <ul> 37 <li><a href="#Tween">Tween animation</a>: Creates an animation by performing a series of transformations on a single image 38 with an {@link android.view.animation.Animation}</li> 39 <li><a href="#Frame">Frame animation</a>: or creates an animation by showing a sequence of images in order 40 with an {@link android.graphics.drawable.AnimationDrawable}.</li> 41 </ul> 42 </dd> 43 </dl> 44 45 46 <h2 id="Property">Property Animation</h2> 47 <p>An animation defined in XML that modifies properties of the target object, such as 48 background color or alpha value, over a set amount of time.</p> 49 50 <dl class="xml"> 51 52 <dt>file location:</dt> 53 <dd><code>res/animator/<em>filename</em>.xml</code><br/> 54 The filename will be used as the resource ID.</dd> 55 56 <dt>compiled resource datatype:</dt> 57 <dd>Resource pointer to a {@link android.animation.ValueAnimator}, {@link android.animation.ObjectAnimator}, 58 or {@link android.animation.AnimatorSet}.</dd> 59 60 <dt>resource reference:</dt> 61 <dd> 62 In Java: <code>R.animator.<em>filename</em></code><br/> 63 In XML: <code>@[<em>package</em>:]animator/<em>filename</em></code> 64 </dd> 65 66 <dt>syntax:</dt> 67 <dd> 68 <pre class="stx"> 69 <<a href="#animator-set-element">set</a> 70 android:ordering=["together" | "sequentially"]> 71 72 <<a href="#obj-animator-element">objectAnimator</a> 73 android:propertyName="<em>string</em>" 74 android:duration="<em>int</em>" 75 android:valueFrom="<em>float</em> | <em>int</em> | <em>color</em>" 76 android:valueTo="<em>float</em> | <em>int</em> | <em>color</em>" 77 android:startOffset="<em>int</em>" 78 android:repeatCount="<em>int</em>" 79 android:repeatMode=["repeat" | "reverse"] 80 android:valueType=["intType" | "floatType"]/> 81 82 <<a href="#val-animator-element">animator</a> 83 android:duration="<em>int</em>" 84 android:valueFrom="<em>float</em> | <em>int</em> | <em>color</em>" 85 android:valueTo="<em>float</em> | <em>int</em> | <em>color</em>" 86 android:startOffset="<em>int</em>" 87 android:repeatCount="<em>int</em>" 88 android:repeatMode=["repeat" | "reverse"] 89 android:valueType=["intType" | "floatType"]/> 90 91 <<a href="#animator-set-element">set</a>> 92 ... 93 </set> 94 </set> 95 </pre> 96 97 <p>The file must have a single root element: either 98 <code><set></code>, <code><objectAnimator></code>, or <code><valueAnimator></code>. You can 99 group animation elements together inside the <code><set></code> element, including other 100 <code><set></code> elements. 101 </p> 102 </dd> 103 104 <dt>elements:</dt> 105 <dd> 106 <dl class="tag-list"> 107 <dt id="animator-set-element"><code><set></code></dt> 108 <dd>A container that holds other animation elements (<code><objectAnimator></code>, 109 <code><valueAnimator></code>, or other <code><set></code> elements). Represents 110 an {@link android.animation.AnimatorSet}. 111 <p>You can specify nested <code><set></code> tags to further 112 group animations together. Each <code><set></code> can define its own 113 <code>ordering</code> attribute.</p> 114 115 <p class="caps">attributes:</p> 116 <dl class="atn-list"> 117 <dt> 118 <code>android:ordering</code> 119 </dt> 120 <dd> 121 <em>Keyword</em>. Specifies the play ordering of animations in this set. 122 <table> 123 <tr><th>Value</th><th>Description</th></tr> 124 <tr><td><code>sequentially</code></td><td>Play animations in this set sequentially</td></tr> 125 <tr><td><code>together</code> (default)</td><td>Play animations in this set at the same time.</td></tr> 126 </table> 127 </dd> 128 </dl> 129 </dd> 130 131 <dt id="obj-animator-element"><code><objectAnimator></code></dt> 132 <dd>Animates a specific property of an object over a specific amount of time. Represents 133 an {@link android.animation.ObjectAnimator}.</p> 134 135 <p class="caps">attributes:</p> 136 <dl class="atn-list"> 137 <dt> 138 <code>android:propertyName</code> 139 </dt> 140 <dd> 141 <em>String</em>. <strong>Required</strong>. The object's property to animate, referenced by its name. For example you can specify 142 <code>"alpha"</code> or <code>"backgroundColor"</code> for a View object. 143 The <code>objectAnimator</code> element does not expose a <code>target</code> 144 attribute, however, so you cannot set the object to animate in the XML declaration. You have to 145 inflate your animation XML resource by calling {@link android.animation.AnimatorInflater#loadAnimator 146 loadAnimator()} and call {@link android.animation.ObjectAnimator#setTarget setTarget()} to set 147 the target object that contains this property. 148 </dd> 149 150 <dt> 151 <code>android:valueTo</code> 152 </dt> 153 <dd> 154 <em>float, int, or color</em>. <strong>Required</strong>. The value where the animated property ends. Colors are represented 155 as six digit hexadecimal numbers (for example, #333333). 156 </dd> 157 158 <dt> 159 <code>android:valueFrom</code> 160 </dt> 161 <dd> 162 <em>float, int, or color</em>. The value where the animated property starts. If not 163 specified, the animation starts at the value obtained by the property's get method. Colors are represented 164 as six digit hexadecimal numbers (for example, #333333). 165 </dd> 166 167 <dt> 168 <code>android:duration</code> 169 </dt> 170 <dd> 171 <em>int</em>. The time in milliseconds of the animation. 300 milliseconds is the default. 172 </dd> 173 174 <dt> 175 <code>android:startOffset</code> 176 </dt> 177 <dd> 178 <em>int</em>. The amount of milliseconds the animation delays after 179 {@link android.animation.ObjectAnimator#start start()} is called. 180 </dd> 181 182 <dt> 183 <code>android:repeatCount</code> 184 </dt> 185 <dd> 186 <em>int</em>. How many times to repeat an animation. Set to <code>"-1"</code> to infinitely 187 repeat or to a positive integer. For example, a value of <code>"1"</code> means that the animation 188 is repeated once after the initial run of the animation, so the animation plays a total 189 of two times. The default value is <code>"0"</code>, which means no repetition. 190 191 </dd> 192 193 <dt> 194 <code>android:repeatMode</code> 195 </dt> 196 <dd> 197 <em>int</em>. How an animation behaves when it reaches the end of the animation. <code>android:repeatCount</code> 198 must be set to a positive integer or <code>"-1"</code> for this attribute to have an effect. Set to <code>"reverse"</code> 199 to have the animation reverse direction with each iteration or <code>"repeat"</code> to have the animation 200 loop from the beginning each time. 201 </dd> 202 203 <dt> 204 <code>android:valueType</code> 205 </dt> 206 <dd> 207 <em>Keyword</em>. Do not specify this attribute if the value is a color. The animation framework automatically handles color 208 values 209 <table> 210 <tr><th>Value</th><th>Description</th></tr> 211 <tr><td><code>intType</code></td><td>Specifies that the animated values are integers</td></tr> 212 <tr><td><code>floatType</code> (default)</td><td>Specifies that the animated values are floats</td></tr> 213 </table> 214 </dd> 215 216 </dl> 217 </dd> 218 219 <dt id="val-animator-element"><code><animator></code></dt> 220 <dd>Performs an animation over a specified amount of time. 221 Represents a {@link android.animation.ValueAnimator}. 222 223 <p class="caps">attributes:</p> 224 <dl class="atn-list"> 225 <dt> 226 <code>android:valueTo</code> 227 </dt> 228 <dd> 229 <em>float, int, or color</em>. <strong>Required</strong>. The value where the animation ends. Colors are represented 230 as six digit hexadecimal numbers (for example, #333333). 231 </dd> 232 233 <dt> 234 <code>android:valueFrom</code> 235 </dt> 236 <dd> 237 <em>float, int, or color</em>. <strong>Required</strong>. The value where the animation starts. Colors are represented 238 as six digit hexadecimal numbers (for example, #333333). 239 </dd> 240 241 <dt> 242 <code>android:duration</code> 243 </dt> 244 <dd> 245 <em>int</em>. The time in milliseconds of the animation. 300ms is the default. 246 </dd> 247 248 <dt> 249 <code>android:startOffset</code> 250 </dt> 251 <dd> 252 <em>int</em>. The amount of milliseconds the animation delays after 253 {@link android.animation.ValueAnimator#start start()} is called. 254 </dd> 255 256 <dt> 257 <code>android:repeatCount</code> 258 </dt> 259 <dd> 260 <em>int</em>. How many times to repeat an animation. Set to <code>"-1"</code> to infinitely 261 repeat or to a positive integer. For example, a value of <code>"1"</code> means that the animation 262 is repeated once after the initial run of the animation, so the animation plays a total 263 of two times. The default value is <code>"0"</code>, which means no repetition. 264 </dd> 265 266 <dt> 267 <code>android:repeatMode</code> 268 </dt> 269 <dd> 270 <em>int</em>. How an animation behaves when it reaches the end of the animation. <code>android:repeatCount</code> 271 must be set to a positive integer or <code>"-1"</code> for this attribute to have an effect. Set to <code>"reverse"</code> 272 to have the animation reverse direction with each iteration or <code>"repeat"</code> to have the animation 273 loop from the beginning each time. 274 </dd> 275 276 <dt> 277 <code>android:valueType</code> 278 </dt> 279 <dd> 280 <em>Keyword</em>. Do not specify this attribute if the value is a color. The animation framework automatically handles color 281 values. 282 <table> 283 <tr><th>Value</th><th>Description</th></tr> 284 <tr><td><code>intType</code></td><td>Specifies that the animated values are integers</td></tr> 285 <tr><td><code>floatType</code> (default)</td><td>Specifies that the animated values are floats</td></tr> 286 </table> 287 </dd> 288 289 </dl> 290 </dd> 291 </dl> 292 293 </dd> <!-- end elements and attributes --> 294 295 <dt>example:</dt> 296 <dd> 297 <pp>XML file saved at <code>res/animator/property_animator.xml</code>:</p> 298 <pre> 299 <set android:ordering="sequentially"> 300 <set> 301 <objectAnimator 302 android:propertyName="x" 303 android:duration="500" 304 android:valueTo="400" 305 android:valueType="intType"/> 306 <objectAnimator 307 android:propertyName="y" 308 android:duration="500" 309 android:valueTo="300" 310 android:valueType="intType"/> 311 </set> 312 <objectAnimator 313 android:propertyName="alpha" 314 android:duration="500" 315 android:valueTo="1f"/> 316 </set> 317 </pre> 318 <p>In order to run this animation, you must inflate the XML resources in your code to an {@link 319 android.animation.AnimatorSet} object, and then set the target objects for all of the animations 320 before starting the animation set. Calling {@link android.animation.AnimatorSet#setTarget 321 setTarget()} sets a single target object for all children of the {@link 322 android.animation.AnimatorSet} as a convenience. The following code shows how to do this:</p> 323 324 <pre> 325 AnimatorSet set = (AnimatorSet) AnimatorInflater.loadAnimator(myContext, 326 R.anim.property_animator); 327 set.setTarget(myObject); 328 set.start(); 329 </pre> 330 331 332 </dd> <!-- end example --> 333 334 <dt>see also:</dt> 335 <dd> 336 <ul> 337 <li><a href="{@docRoot}guide/topics/graphics/prop-animation.html">Property Animation</a></li> 338 <li><a href="{@docRoot}resources/samples/ApiDemos/src/com/example/android/apis/animation/index.html">API Demos</a> for examples 339 on how to use the property animation system.</li> 340 </ul> 341 </dd> 342 343 </dl> 344 345 <h2 id="View">View Animation</h2> 346 The view animation framework supports both tween and frame by frame animations, which can both be declared 347 in XML. The following sections describe how to use both methods. 348 349 <h3 id="Tween">Tween animation</h3> 350 351 <p>An animation defined in XML that performs transitions such as rotating, 352 fading, moving, and stretching on a graphic. 353 </p> 354 355 <dl class="xml"> 356 357 <dt>file location:</dt> 358 <dd><code>res/anim/<em>filename</em>.xml</code><br/> 359 The filename will be used as the resource ID.</dd> 360 361 <dt>compiled resource datatype:</dt> 362 <dd>Resource pointer to an {@link android.view.animation.Animation}.</dd> 363 364 <dt>resource reference:</dt> 365 <dd> 366 In Java: <code>R.anim.<em>filename</em></code><br/> 367 In XML: <code>@[<em>package</em>:]anim/<em>filename</em></code> 368 </dd> 369 370 <dt>syntax:</dt> 371 <dd> 372 <pre class="stx"> 373 <?xml version="1.0" encoding="utf-8"?> 374 <<a href="#set-element">set</a> xmlns:android="http://schemas.android.com/apk/res/android" 375 android:interpolator="@[package:]anim/<em>interpolator_resource</em>" 376 android:shareInterpolator=["true" | "false"] > 377 <<a href="#alpha-element">alpha</a> 378 android:fromAlpha="<em>float</em>" 379 android:toAlpha="<em>float</em>" /> 380 <<a href="#scale-element">scale</a> 381 android:fromXScale="<em>float</em>" 382 android:toXScale="<em>float</em>" 383 android:fromYScale="<em>float</em>" 384 android:toYScale="<em>float</em>" 385 android:pivotX="<em>float</em>" 386 android:pivotY="<em>float</em>" /> 387 <<a href="#translate-element">translate</a> 388 android:fromXDelta="<em>float</em>" 389 android:toXDelta="<em>float</em>" 390 android:fromYDelta="<em>float</em>" 391 android:toYDelta="<em>float</em>" /> 392 <<a href="#rotate-element">rotate</a> 393 android:fromDegrees="<em>float</em>" 394 android:toDegrees="<em>float</em>" 395 android:pivotX="<em>float</em>" 396 android:pivotY="<em>float</em>" /> 397 <<a href="#set-element">set</a>> 398 ... 399 </set> 400 </set> 401 </pre> 402 403 <p>The file must have a single root element: either an 404 <code><alpha></code>, <code><scale></code>, <code><translate></code>, 405 <code><rotate></code>, or <code><set></code> element that holds 406 a group (or groups) of other animation elements (even nested <code><set></code> elements). 407 </p> 408 </dd> 409 410 <dt>elements:</dt> 411 <dd> 412 <dl class="tag-list"> 413 <dt id="set-element"><code><set></code></dt> 414 <dd>A container that holds other animation elements 415 (<code><alpha></code>, <code><scale></code>, <code><translate></code>, 416 <code><rotate></code>) or other <code><set></code> elements. Represents an {@link 417 android.view.animation.AnimationSet}. 418 <p class="caps">attributes:</p> 419 <dl class="atn-list"> 420 <dt><code>android:interpolator</code></dt> 421 <dd><em>Interpolator resource</em>. 422 An {@link android.view.animation.Interpolator} to apply on the animation. 423 The value must be a reference to a resource that specifies an interpolator 424 (not an interpolator class name). There are default interpolator 425 resources available from the platform or you can create your own interpolator resource. 426 See the discussion below for more about <a href="#Interpolators">Interpolators</a>.</dd> 427 <dt><code>android:shareInterpolator</code></dt> 428 <dd><em>Boolean</em>. "true" if you want to share the same interpolator among all child 429 elements.</dd> 430 </dl> 431 </dd> 432 <dt id="alpha-element"><code><alpha></code></dt> 433 <dd>A fade-in or fade-out animation. Represents an {@link 434 android.view.animation.AlphaAnimation}. 435 <p class="caps">attributes:</p> 436 <dl class="atn-list"> 437 <dt><code>android:fromAlpha</code></dt> 438 <dd><em>Float</em>. Starting opacity offset, where 0.0 is transparent and 1.0 439 is opaque.</dd> 440 <dt><code>android:toAlpha</code></dt> 441 <dd><em>Float</em>. Ending opacity offset, where 0.0 is transparent and 1.0 442 is opaque.</dd> 443 </dl> 444 <p>For more attributes supported by <code><alpha></code>, see the 445 {@link android.view.animation.Animation} class reference (of which, all XML attributes are 446 inherrited by this element).</p> 447 </dd> 448 <dt id="scale-element"><code><scale></code></dt> 449 <dd>A resizing animation. You can specify the center point of the image from which it grows 450 outward (or inward) by specifying {@code pivotX} and {@code pivotY}. For example, if these values 451 are 0, 0 (top-left corner), all growth will be down and to the right. Represents a {@link 452 android.view.animation.ScaleAnimation}. 453 <p class="caps">attributes:</p> 454 <dl class="atn-list"> 455 <dt><code>android:fromXScale</code></dt> 456 <dd><em>Float</em>. Starting X size offset, where 1.0 is no change.</dd> 457 <dt><code>android:toXScale</code></dt> 458 <dd><em>Float</em>. Ending X size offset, where 1.0 is no change.</dd> 459 <dt><code>android:fromYScale</code></dt> 460 <dd><em>Float</em>. Starting Y size offset, where 1.0 is no change.</dd> 461 <dt><code>android:toYScale</code></dt> 462 <dd><em>Float</em>. Ending Y size offset, where 1.0 is no change.</dd> 463 <dt><code>android:pivotX</code></dt> 464 <dd><em>Float</em>. The X coordinate to remain fixed when the object is scaled.</dd> 465 <dt><code>android:pivotY</code></dt> 466 <dd><em>Float</em>. The Y coordinate to remain fixed when the object is scaled.</dd> 467 </dl> 468 <p>For more attributes supported by <code><scale></code>, see the 469 {@link android.view.animation.Animation} class reference (of which, all XML attributes are 470 inherrited by this element).</p> 471 </dd> 472 <dt id="translate-element"><code><translate></code></dt> 473 <dd>A vertical and/or horizontal motion. Supports the following attributes in any of 474 the following three formats: values from -100 to 100 ending with "%", indicating a percentage 475 relative to itself; values from -100 to 100 ending in "%p", indicating a percentage relative to its 476 parent; a float value with no suffix, indicating an absolute value. Represents a {@link 477 android.view.animation.TranslateAnimation}. 478 <p class="caps">attributes:</p> 479 <dl class="atn-list"> 480 <dt><code>android:fromXDelta</code></dt> 481 <dd><em>Float or percentage</em>. Starting X offset. Expressed either: in pixels relative 482 to the normal position (such as {@code "5"}), in percentage relative to the element width (such as 483 {@code "5%"}), or in percentage relative to the parent width (such as {@code "5%p"}).</dd> 484 <dt><code>android:toXDelta</code></dt> 485 <dd><em>Float or percentage</em>. Ending X offset. Expressed either: in pixels relative 486 to the normal position (such as {@code "5"}), in percentage relative to the element width (such as 487 {@code "5%"}), or in percentage relative to the parent width (such as {@code "5%p"}).</dd> 488 <dt><code>android:fromYDelta</code></dt> 489 <dd><em>Float or percentage</em>. Starting Y offset. Expressed either: in pixels relative 490 to the normal position (such as {@code "5"}), in percentage relative to the element height (such as 491 {@code "5%"}), or in percentage relative to the parent height (such as {@code "5%p"}).</dd> 492 <dt><code>android:toYDelta</code></dt> 493 <dd><em>Float or percentage</em>. Ending Y offset. Expressed either: in pixels relative 494 to the normal position (such as {@code "5"}), in percentage relative to the element height (such as 495 {@code "5%"}), or in percentage relative to the parent height (such as {@code "5%p"}).</dd> 496 </dl> 497 <p>For more attributes supported by <code><translate></code>, see the 498 {@link android.view.animation.Animation} class reference (of which, all XML attributes are 499 inherrited by this element).</p> 500 </dd> 501 <dt id="rotate-element"><code><rotate></code></dt> 502 <dd>A rotation animation. Represents a {@link android.view.animation.RotateAnimation}. 503 <p class="caps">attributes:</p> 504 <dl class="atn-list"> 505 <dt><code>android:fromDegrees</code></dt> 506 <dd><em>Float</em>. Starting angular position, in degrees.</dd> 507 <dt><code>android:toDegrees</code></dt> 508 <dd><em>Float</em>. Ending angular position, in degrees.</dd> 509 <dt><code>android:pivotX</code></dt> 510 <dd><em>Float or percentage</em>. The X coordinate of the center of rotation. Expressed 511 either: in pixels relative to the object's left edge (such as {@code "5"}), in percentage relative 512 to the object's left edge (such as {@code "5%"}), or in percentage relative to the parent 513 container's left edge (such as {@code "5%p"}).</dd> 514 <dt><code>android:pivotY</code></dt> 515 <dd><em>Float or percentage</em>. The Y coordinate of the center of rotation. Expressed 516 either: in pixels relative to the object's top edge (such as {@code "5"}), in percentage relative 517 to the object's top edge (such as {@code "5%"}), or in percentage relative to the parent 518 container's top edge (such as {@code "5%p"}).</dd> 519 </dl> 520 <p>For more attributes supported by <code><rotate></code>, see the 521 {@link android.view.animation.Animation} class reference (of which, all XML attributes are 522 inherrited by this element).</p> 523 </dd> 524 </dl> 525 </dd> <!-- end elements and attributes --> 526 527 <dt>example:</dt> 528 <dd> 529 <pp>XML file saved at <code>res/anim/hyperspace_jump.xml</code>:</p> 530 <pre> 531 <set xmlns:android="http://schemas.android.com/apk/res/android" 532 android:shareInterpolator="false"> 533 <scale 534 android:interpolator="@android:anim/accelerate_decelerate_interpolator" 535 android:fromXScale="1.0" 536 android:toXScale="1.4" 537 android:fromYScale="1.0" 538 android:toYScale="0.6" 539 android:pivotX="50%" 540 android:pivotY="50%" 541 android:fillAfter="false" 542 android:duration="700" /> 543 <set 544 android:interpolator="@android:anim/accelerate_interpolator" 545 android:startOffset="700"> 546 <scale 547 android:fromXScale="1.4" 548 android:toXScale="0.0" 549 android:fromYScale="0.6" 550 android:toYScale="0.0" 551 android:pivotX="50%" 552 android:pivotY="50%" 553 android:duration="400" /> 554 <rotate 555 android:fromDegrees="0" 556 android:toDegrees="-45" 557 android:toYScale="0.0" 558 android:pivotX="50%" 559 android:pivotY="50%" 560 android:duration="400" /> 561 </set> 562 </set> 563 </pre> 564 <p>This application code will apply the animation to an {@link android.widget.ImageView} and 565 start the animation:</p> 566 <pre> 567 ImageView image = (ImageView) findViewById(R.id.image); 568 Animation hyperspaceJump = AnimationUtils.{@link android.view.animation.AnimationUtils#loadAnimation(Context,int) loadAnimation}(this, R.anim.hyperspace_jump); 569 image.{@link android.view.View#startAnimation(Animation) startAnimation}(hyperspaceJump); 570 </pre> 571 </dd> <!-- end example --> 572 573 574 <dt>see also:</dt> 575 <dd> 576 <ul> 577 <li><a href="{@docRoot}guide/topics/graphics/view-animation.html#tween-animation">2D 578 Graphics: Tween Animation</a></li> 579 </ul> 580 </dd> 581 582 </dl> 583 584 <h4 id="Interpolators">Interpolators</h4> 585 586 <p>An interpolator is an animation modifier defined in XML that affects the rate of change in an 587 animation. This allows your existing animation effects to be accelerated, decelerated, repeated, 588 bounced, etc.</p> 589 590 <p>An interpolator is applied to an animation element with the {@code android:interpolator} 591 attribute, the value of which is a reference to an interpolator resource.</p> 592 593 <p>All interpolators available in Android are subclasses of the {@link 594 android.view.animation.Interpolator} class. For each interpolator class, Android 595 includes a public resource you can reference in order to apply the interpolator to an animation 596 using the {@code android:interpolator} attribute. 597 The following table specifies the resource to use for each interpolator:</p> 598 599 <table> 600 <tr><th>Interpolator class</th><th>Resource ID</th></tr> 601 <tr> 602 <td>{@link android.view.animation.AccelerateDecelerateInterpolator}</td> 603 <td>{@code @android:anim/accelerate_decelerate_interpolator}</td> 604 </tr> 605 <tr> 606 <td>{@link android.view.animation.AccelerateInterpolator}</td> 607 <td>{@code @android:anim/accelerate_interpolator}</td> 608 </tr> 609 <tr> 610 <td>{@link android.view.animation.AnticipateInterpolator}</td> 611 <td>{@code @android:anim/anticipate_interpolator}</td> 612 </tr> 613 <tr> 614 <td>{@link android.view.animation.AnticipateOvershootInterpolator}</td> 615 <td>{@code @android:anim/anticipate_overshoot_interpolator}</td> 616 </tr> 617 <tr> 618 <td>{@link android.view.animation.BounceInterpolator}</td> 619 <td>{@code @android:anim/bounce_interpolator}</td> 620 </tr> 621 <tr> 622 <td>{@link android.view.animation.CycleInterpolator}</td> 623 <td>{@code @android:anim/cycle_interpolator}</td> 624 </tr> 625 <tr> 626 <td>{@link android.view.animation.DecelerateInterpolator}</td> 627 <td>{@code @android:anim/decelerate_interpolator}</td> 628 </tr> 629 <tr> 630 <td>{@link android.view.animation.LinearInterpolator}</td> 631 <td>{@code @android:anim/linear_interpolator}</td> 632 </tr> 633 <tr> 634 <td>{@link android.view.animation.OvershootInterpolator}</td> 635 <td>{@code @android:anim/overshoot_interpolator}</td> 636 </tr> 637 </table> 638 639 <p>Here's how you can apply one of these with the {@code android:interpolator} attribute:</p> 640 <pre> 641 <set android:interpolator="@android:anim/accelerate_interpolator"> 642 ... 643 </set> 644 </pre> 645 646 647 <h4>Custom interpolators</h4> 648 649 <p>If you're not satisfied with the interpolators provided by the platform (listed in the 650 table above), you can create a custom interpolator resource with modified attributes. 651 For example, you can adjust the rate of 652 acceleration for the {@link android.view.animation.AnticipateInterpolator}, or adjust the number of 653 cycles for the {@link android.view.animation.CycleInterpolator}. In order to do so, you need to 654 create your own interpolator resource in an XML file. 655 </p> 656 657 <dl class="xml"> 658 659 <dt>file location:</dt> 660 <dd><code>res/anim/<em>filename</em>.xml</code><br/> 661 The filename will be used as the resource ID.</dd> 662 663 <dt>compiled resource datatype:</dt> 664 <dd>Resource pointer to the corresponding interpolator object.</dd> 665 666 <dt>resource reference:</dt> 667 <dd> 668 In XML: <code>@[<em>package</em>:]anim/<em>filename</em></code> 669 </dd> 670 671 <dt>syntax:</dt> 672 <dd> 673 <pre class="stx"> 674 <?xml version="1.0" encoding="utf-8"?> 675 <<em>InterpolatorName</em> xmlns:android="http://schemas.android.com/apk/res/android" 676 android:<em>attribute_name</em>="<em>value</em>" 677 /> 678 </pre> 679 <p>If you don't apply any attributes, then your interpolator will function exactly the same as 680 those provided by the platform (listed in the table above).</p> 681 </dd> 682 683 <dt>elements:</dt> 684 <dd>Notice that each {@link android.view.animation.Interpolator} implementation, when 685 defined in XML, begins its name in lowercase.</p> 686 687 <dl class="tag-list"> 688 <dt><code><accelerateDecelerateInterpolator></code></dt> 689 <dd>The rate of change starts and ends slowly but accelerates through the 690 middle. <p>No attributes.</p></dd> 691 <dt><code><accelerateInterpolator></code></dt> 692 <dd>The rate of change starts out slowly, then accelerates. 693 <p class="caps">attributes:</p> 694 <dl class="atn-list"> 695 <dt><code>android:factor</code></dt> 696 <dd><em>Float</em>. The acceleration rate (default is 1).</dd> 697 </dl> 698 </dd> 699 <dt><code><anticipateInterpolator></code></dt> 700 <dd>The change starts backward then flings forward. 701 <p class="caps">attributes:</p> 702 <dl class="atn-list"> 703 <dt><code>android:tension</code></dt> 704 <dd><em>Float</em>. The amount of tension to apply (default is 2).</dd> 705 </dl> 706 </dd> 707 <dt><code><anticipateOvershootInterpolator></code></dt> 708 <dd>The change starts backward, flings forward and overshoots the target value, then 709 settles at the final value. 710 <p class="caps">attributes:</p> 711 <dl class="atn-list"> 712 <dt><code>android:tension</code></dt> 713 <dd><em>Float</em>. The amount of tension to apply (default is 2).</dd> 714 <dt><code>android:extraTension</code></dt> 715 <dd><em>Float</em>. The amount by which to multiply the tension (default is 716 1.5).</dd> 717 </dl> 718 </dd> 719 <dt><code><bounceInterpolator></code></dt> 720 <dd>The change bounces at the end. <p>No attributes</p></dd> 721 <dt><code><cycleInterpolator></code></dt> 722 <dd>Repeats the animation for a specified number of cycles. The rate of change follows a 723 sinusoidal pattern. 724 <p class="caps">attributes:</p> 725 <dl class="atn-list"> 726 <dt><code>android:cycles</code></dt> 727 <dd><em>Integer</em>. The number of cycles (default is 1).</dd> 728 </dl> 729 </dd> 730 <dt><code><decelerateInterpolator></code></dt> 731 <dd>The rate of change starts out quickly, then decelerates. 732 <p class="caps">attributes:</p> 733 <dl class="atn-list"> 734 <dt><code>android:factor</code></dt> 735 <dd><em>Float</em>. The deceleration rate (default is 1).</dd> 736 </dl> 737 </dd> 738 <dt><code><linearInterpolator></code></dt> 739 <dd>The rate of change is constant. <p>No attributes.</p></dd> 740 <dt><code><overshootInterpolator></code></dt> 741 <dd>The change flings forward and overshoots the last value, then comes back. 742 <p class="caps">attributes:</p> 743 <dl class="atn-list"> 744 <dt><code>android:tension</code></dt> 745 <dd><em>Float</em>. The amount of tension to apply (default is 2).</dd> 746 </dl> 747 </dd> 748 </dl> 749 750 <dt>example:</dt> 751 <dd> 752 <p>XML file saved at <code>res/anim/my_overshoot_interpolator.xml</code>:</p> 753 <pre> 754 <?xml version="1.0" encoding="utf-8"?> 755 <overshootInterpolator xmlns:android="http://schemas.android.com/apk/res/android" 756 android:tension="7.0" 757 /> 758 </pre> 759 <p>This animation XML will apply the interpolator:</p> 760 <pre> 761 <scale xmlns:android="http://schemas.android.com/apk/res/android" 762 android:interpolator="@anim/my_overshoot_interpolator" 763 android:fromXScale="1.0" 764 android:toXScale="3.0" 765 android:fromYScale="1.0" 766 android:toYScale="3.0" 767 android:pivotX="50%" 768 android:pivotY="50%" 769 android:duration="700" /> 770 </pre> 771 </dd> 772 </dl> 773 774 775 <h3 id="Frame">Frame animation</h3> 776 777 <p>An animation defined in XML that shows a sequence of images in order (like a film). 778 </p> 779 780 781 <dl class="xml"> 782 783 <dt>file location:</dt> 784 <dd><code>res/drawable/<em>filename</em>.xml</code><br/> 785 The filename will be used as the resource ID.</dd> 786 787 <dt>compiled resource datatype:</dt> 788 <dd>Resource pointer to an {@link android.graphics.drawable.AnimationDrawable}.</dd> 789 790 <dt>resource reference:</dt> 791 <dd> 792 In Java: <code>R.drawable.<em>filename</em></code><br/> 793 In XML: <code>@[<em>package</em>:]drawable.<em>filename</em></code> 794 </dd> 795 796 <dt>syntax:</dt> 797 <dd> 798 <pre class="stx"> 799 <?xml version="1.0" encoding="utf-8"?> 800 <<a href="#animation-list-element">animation-list</a> xmlns:android="http://schemas.android.com/apk/res/android" 801 android:oneshot=["true" | "false"] > 802 <<a href="#item-element">item</a> 803 android:drawable="@[package:]drawable/<em>drawable_resource_name</em>" 804 android:duration="<em>integer</em>" /> 805 </animation-list> 806 </pre> 807 </dd> 808 809 <dt>elements:</dt> 810 <dd> 811 <dl class="tag-list"> 812 <dt id="animation-list-element"><code><animation-list></code></dt> 813 <dd><strong>Required</strong>. This must be the root element. Contains one or more 814 <code><item></code> elements. 815 <p class="caps">attributes:</p> 816 <dl class="atn-list"> 817 <dt><code>android:oneshot</code></dt> 818 <dd><em>Boolean</em>. "true" if you want to perform the animation once; "false" to loop the 819 animation.</dd> 820 </dl> 821 </dd> 822 <dt id="item-element"><code><item></code></dt> 823 <dd>A single frame of animation. Must be a child of a <code><animation-list></code> element. 824 <p class="caps">attributes:</p> 825 <dl class="atn-list"> 826 <dt><code>android:drawable</code></dt> 827 <dd><em>Drawable resource</em>. The drawable to use for this frame.</dd> 828 <dt><code>android:duration</code></dt> 829 <dd><em>Integer</em>. The duration to show this frame, in milliseconds.</dd> 830 </dl> 831 </dd> 832 </dl> 833 </dd> <!-- end elements and attributes --> 834 835 <dt>example:</dt> 836 <dd> 837 <dl> 838 <dt>XML file saved at <code>res/anim/rocket.xml</code>:</dt> 839 <dd> 840 <pre> 841 <?xml version="1.0" encoding="utf-8"?> 842 <animation-list xmlns:android="http://schemas.android.com/apk/res/android" 843 android:oneshot="false"> 844 <item android:drawable="@drawable/rocket_thrust1" android:duration="200" /> 845 <item android:drawable="@drawable/rocket_thrust2" android:duration="200" /> 846 <item android:drawable="@drawable/rocket_thrust3" android:duration="200" /> 847 </animation-list> 848 </pre> 849 </dd> 850 851 <dt>This application code will set the animation as the background for a View, 852 then play the animation:</dt> 853 <dd> 854 <pre> 855 ImageView rocketImage = (ImageView) findViewById(R.id.rocket_image); 856 rocketImage.{@link android.view.View#setBackgroundResource(int) setBackgroundResource}(R.drawable.rocket_thrust); 857 858 rocketAnimation = (AnimationDrawable) rocketImage.{@link android.view.View#getBackground()}; 859 rocketAnimation.{@link android.graphics.drawable.AnimationDrawable#start()}; 860 </pre> 861 </dd> 862 863 </dl> 864 </dd> <!-- end example --> 865 866 <dt>see also:</dt> 867 <dd> 868 <ul> 869 <li><a href="{@docRoot}guide/topics/graphics/view-animation.html#frame-animation">2D 870 Graphics: Frame Animation</a></li> 871 </ul> 872 </dd> 873 </dl> 874