Animation classification
data:image/s3,"s3://crabby-images/5bda5/5bda54e4812a30dfddd52cf108955fc4f4923c0a" alt=""
Mending animation
There are four operations: Pan, zoom, rotate and Alpha animation
Patching animation is achieved by changing the display position of View. The actual position of View has not changed. For example, if a button [0,0100,50] is translated to button [500500600550], the actual position of the response selection status is [0,0100,50].
Animation classification rules
name |
XML tags |
Subclass |
effect |
translating animation |
<translate> |
TranslateAnimation |
Mobile View |
Scale animation |
<scale> |
ScaleAnimation |
Zoom in or out of View |
Rotate animation |
<rotate> |
RotateAnimation |
Rotate View |
Transparent animation |
<alpha> |
AlphaAnimation |
Change the transparency of the View |
data:image/s3,"s3://crabby-images/822c5/822c5eb5508167e2495884dd1c48a50bfce50b5d" alt=""
Four Animation classes are all subclasses of Animation, in which AnimationSet is an Animation set, which can combine a single Animation, and the corresponding label is < set >
translate animation
field |
significance |
android:fromXDelta |
Represents the starting value of x |
android:fromYDelta |
Represents the starting value of y |
android:toXDelta |
Represents the end value of x |
android:toYDelta |
Represents the end value of y |
<?xml version="1.0" encoding="utf-8"?>
<translate xmlns:android="http://schemas.android.com/apk/res/android"
android:fromXDelta="0"
android:fromYDelta="0"
android:toXDelta="0"
android:toYDelta="-200">
</translate>
//Origin translation up
<?xml version="1.0" encoding="utf-8"?>
<translate xmlns:android="http://schemas.android.com/apk/res/android"
android:fromXDelta="0"
android:fromYDelta="0"
android:toXDelta="200"
android:toYDelta="200">
</translate>
//Origin translation down right
<?xml version="1.0" encoding="utf-8"?>
<translate xmlns:android="http://schemas.android.com/apk/res/android"
android:fromXDelta="0"
android:fromYDelta="-200"
android:toXDelta="0"
android:toYDelta="0">
</translate>
//Pan down to origin
data:image/s3,"s3://crabby-images/d98d8/d98d8f53f802a48c713635dfab9a119f974ddaaf" alt=""
scale animation
field |
significance |
android:fromXScale |
Start value of horizontal scaling |
android:fromYScale |
Start value of vertical scaling |
android:pivotX |
Scaled X coordinate |
android:pivotY |
Scaled Y coordinate |
android:toXScale |
End value of horizontal scaling |
android:toYScale |
End of vertical scaling |
<?xml version="1.0" encoding="utf-8"?>
<scale xmlns:android="http://schemas.android.com/apk/res/android"
android:fromXScale="1.0"
android:fromYScale="1.0"
android:pivotX="0"
android:pivotY="0"
android:toXScale="2.0"
android:toYScale="1.0">
</scale>
//Origin lateral magnification
<?xml version="1.0" encoding="utf-8"?>
<scale xmlns:android="http://schemas.android.com/apk/res/android"
android:fromXScale="1.0"
android:fromYScale="1.0"
android:pivotX="0"
android:pivotY="0"
android:toXScale="2.0"
android:toYScale="2.0">
</scale>
//Origin magnification
<?xml version="1.0" encoding="utf-8"?>
<scale xmlns:android="http://schemas.android.com/apk/res/android"
android:fromXScale="1.0"
android:fromYScale="1.0"
android:pivotX="100"
android:pivotY="100"
android:toXScale="0.5"
android:toYScale="0.5">
</scale>
//Non origin reduction
data:image/s3,"s3://crabby-images/58c36/58c36cb1e4c4c17787edbec2e40dee08840cf504" alt=""
rotate animation
field |
significance |
android:fromDegrees |
Angle at which rotation begins |
android:toDegrees |
Angle at the end of rotation |
android:pivotX |
X coordinate of rotation |
android:pivotY |
Y coordinate of rotation |
<?xml version="1.0" encoding="utf-8"?>
<rotate xmlns:android="http://schemas.android.com/apk/res/android"
android:fromDegrees="0"
android:pivotX="0"
android:pivotY="0"
android:toDegrees="360">
</rotate>
//Clockwise rotation360
<?xml version="1.0" encoding="utf-8"?>
<rotate xmlns:android="http://schemas.android.com/apk/res/android"
android:fromDegrees="0"
android:pivotX="0"
android:pivotY="0"
android:toDegrees="-720">
</rotate>,
//Counter clockwise rotation720
data:image/s3,"s3://crabby-images/b8e8c/b8e8c3ac00bb46ab498a52a2a6023dafe6d962ec" alt=""
Transparency animation alpha
field |
significance |
android:fromAlpha |
Indicates the starting value of transparency |
android:toAlpha |
End value for transparency |
<?xml version="1.0" encoding="utf-8"?>
<alpha xmlns:android="http://schemas.android.com/apk/res/android"
android:fromAlpha="0"
android:toAlpha="1">
</alpha>
//display
<?xml version="1.0" encoding="utf-8"?>
<alpha xmlns:android="http://schemas.android.com/apk/res/android"
android:fromAlpha="1"
android:toAlpha="0">
</alpha>
//hide
data:image/s3,"s3://crabby-images/0fa09/0fa0962a233b4fcdb9053520f61492faf76af080" alt=""
Animation combination set
<?xml version="1.0" encoding="utf-8"?>
<set xmlns:android="http://schemas.android.com/apk/res/android"
android:duration="3000"
android:fillAfter="true"
android:shareInterpolator="@android:anim/accelerate_decelerate_interpolator">
<!--Transparency from scratch-->
<alpha
android:fromAlpha="0"
android:toAlpha="1" />
<!--Two and a half turns-->
<rotate
android:fromDegrees="0"
android:pivotX="50%"
android:pivotY="50%"
android:toDegrees="900" />
<!--Zoom in threefold-->
<scale
android:fromXScale="0"
android:fromYScale="0"
android:pivotX="0%"
android:pivotY="100%"
android:toXScale="3"
android:toYScale="3" />
<!--Pan to middle-->
<translate
android:fromXDelta="0"
android:fromYDelta="0"
android:toXDelta="-50%p"
android:toYDelta="50%p" />
</set>
data:image/s3,"s3://crabby-images/36056/36056ab13fea6aa028eb08ffa276224d2bfa0d1e" alt=""
Code address
Github