Android動畫之補間動畫(Tween Animation)基礎(chǔ)學(xué)習(xí)
前言
之前說過了在Android中,動畫Animation的實現(xiàn)有兩種方式:Tween Animation(漸變動畫)和Frame Animation(幀動畫)。漸變動畫是通過對場景里的對象不斷做圖像變換(平移、縮放、旋轉(zhuǎn)等)產(chǎn)生動畫效果。幀動畫則是通過順序播放事先準備好的圖像來產(chǎn)生動畫效果,和電影類似。
小編也和大家分享了逐幀動畫的基礎(chǔ)知識,下面我們就來學(xué)習(xí)下Android中逐幀動畫的基礎(chǔ)知識。
原理 : 給出開始和結(jié)束兩個關(guān)鍵幀,兩個關(guān)鍵幀之間的插補幀是由計算機自動運算而得到的。
分類 : AlphaAnimation
(透明度) ScaleAnimation
(縮放) TranslateAnimation
(位移) RotateAnimation
(旋轉(zhuǎn)) AnimationSet
(組合)
方式 :
1.在代碼中new
2.在anim文件夾下定義動畫xml資源
效果
代碼
第一步 :準備動畫資源
目錄
<?xml version="1.0" encoding="utf-8"?> <alpha xmlns:android="http://schemas.android.com/apk/res/android" android:duration="2000" android:fromAlpha="1.0" android:interpolator="@android:anim/linear_interpolator" android:toAlpha="0.3"> </alpha>
<?xml version="1.0" encoding="utf-8"?> <rotate xmlns:android="http://schemas.android.com/apk/res/android" android:interpolator="@android:interpolator/linear" android:repeatCount="infinite" android:repeatMode="reverse" android:duration="2000" android:fromDegrees="0" android:toDegrees="1080"> android:pivotX="50%" android:pivotY="50%" </rotate>
<?xml version="1.0" encoding="utf-8"?> <scale xmlns:android="http://schemas.android.com/apk/res/android" android:interpolator="@android:anim/linear_interpolator" android:duration="2000" android:fillAfter="true" android:fromXScale="1.0" android:fromYScale="1.0" android:pivotX="50%" android:pivotY="50%" android:toXScale="0.3" android:toYScale="0.3"> </scale>
<?xml version="1.0" encoding="utf-8"?> <translate xmlns:android="http://schemas.android.com/apk/res/android" android:interpolator="@android:anim/linear_interpolator" android:duration="2000" android:fromXDelta="10" android:fromYDelta="10" android:toXDelta="300" android:toYDelta="300"> </translate>
<?xml version="1.0" encoding="utf-8"?> <set xmlns:android="http://schemas.android.com/apk/res/android" android:interpolator="@android:anim/linear_interpolator" android:duration="2000"> <alpha android:fromAlpha="0.3" android:toAlpha="1.0"/> <rotate android:fromDegrees="0" android:toDegrees="360" android:pivotX="0" android:pivotY="0" android:repeatMode="restart" android:repeatCount="infinite"/> </set>
第二步 :activity_main.xml ( 略 )
第三步 :MainActivity.java
package com.lyp.anim; import android.support.v7.app.AppCompatActivity; import android.os.Bundle; import android.view.View; import android.view.animation.Animation; import android.view.animation.AnimationUtils; import android.widget.Button; import android.widget.ImageView; public class MainActivity extends AppCompatActivity implements View.OnClickListener{ private Button btnScale; private Button btnRotate; private Button btnTranslate; private Button btnAlpha; private Button btnAll; private ImageView mImage; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); initView(); } private void initView() { btnScale= (Button) findViewById(R.id.btn_scale); btnRotate= (Button) findViewById(R.id.btn_rotate); btnTranslate= (Button) findViewById(R.id.btn_translate); btnAlpha= (Button) findViewById(R.id.btn_alpha); btnAll= (Button) findViewById(R.id.btn_all); mImage= (ImageView) findViewById(R.id.image); btnScale.setOnClickListener(this); btnRotate.setOnClickListener(this); btnTranslate.setOnClickListener(this); btnAlpha.setOnClickListener(this); btnAll.setOnClickListener(this); } @Override public void onClick(View v) { switch (v.getId()){ case R.id.btn_scale: //加載縮放動畫 Animation scale = AnimationUtils.loadAnimation(this, R.anim.scale); scale.setFillAfter(true); //保留動畫結(jié)束狀態(tài),在xml文件中設(shè)置無效!! mImage.startAnimation(scale); break; case R.id.btn_rotate: //加載旋轉(zhuǎn)動畫 Animation rotate = AnimationUtils.loadAnimation(this, R.anim.rotate); mImage.startAnimation(rotate); break; case R.id.btn_translate: //加載位移動畫 Animation translate = AnimationUtils.loadAnimation(this, R.anim.translate); mImage.startAnimation(translate); break; case R.id.btn_alpha: //加載透明度漸變動畫 Animation alpha = AnimationUtils.loadAnimation(this, R.anim.alpha); mImage.startAnimation(alpha); break; case R.id.btn_all: //加載組合動畫 Animation all = AnimationUtils.loadAnimation(this, R.anim.all); mImage.startAnimation(all); break; } } }
總結(jié)
以上Android中補間動畫(Tween Animation)基礎(chǔ)的全部內(nèi)容了,動畫Animation實現(xiàn)的兩種方式小編現(xiàn)在已經(jīng)都給大家分享了,希望能對各位Android開發(fā)者們有所幫助,如果有疑問大家可以留言交流。
相關(guān)文章
FrameLayout和Fragment處理Android應(yīng)用UI布局實例
這篇文章主要介紹了FrameLayout和Fragment處理Android應(yīng)用UI布局實例,安卓3.0以后Fragment的出現(xiàn)為多尺寸屏幕的適配帶來了方便,需要的朋友可以參考下2016-02-02android MediaRecorder實現(xiàn)錄屏?xí)r帶錄音功能
這篇文章主要介紹了android MediaRecorder錄屏?xí)r帶錄音功能實現(xiàn)代碼,本文通過實例代碼給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-04-04Android 自定義日期段選擇控件功能(開始時間-結(jié)束時間)
這篇文章主要介紹了Android 自定義日期段選擇控件功能,開始時間-結(jié)束時間。本文通過實例代碼給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-04-04Android判斷網(wǎng)絡(luò)狀態(tài)的代碼
這篇文章主要為大家詳細介紹了Android判斷網(wǎng)絡(luò)狀態(tài)的方法,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-10-10Android中Fragment的分屏顯示處理橫豎屏顯示的實現(xiàn)方法
今天小編就為大家分享一篇關(guān)于Android中Fragment的分屏顯示處理橫豎屏顯示的實現(xiàn)方法,小編覺得內(nèi)容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧2019-03-03