Android編程中Tween動畫和Frame動畫實例分析
本文實例講述了Android編程中Tween動畫和Frame動畫實現(xiàn)方法。分享給大家供大家參考,具體如下:
Animation主要有兩種動畫模式:Tween動畫和Frame動畫
Tween動畫由四種類型組成
res目錄下新建anim創(chuàng)建Tween.xml
<?xml version="1.0" encoding="utf-8"?> <set xmlns:android="http://schemas.android.com/apk/res/android"> <!-- 透明 --> <alpha android:fromAlpha="1" android:toAlpha="0" android:duration="3000" /> <!-- 旋轉 --> <rotate android:fromDegrees="0" android:toDegrees="360" android:pivotX="50%" android:pivotY="50%" android:duration="3000" /> <!-- 縮放 --> <scale android:fromXScale="1" android:fromYScale="1" android:toXScale="3" android:toYScale="3" android:pivotX="0" android:pivotY="0" android:duration="3000" /> <!-- 移動 --> <translate android:fromXDelta="0" android:fromYDelta="0" android:toXDelta="50%p" android:toYDelta="50%p" android:duration="3000" /> </set>
以上每個動畫效果可放在不同的xml文件中已方便查看效果
下邊是Activity中調用動畫
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.main);
imageView = (ImageView) findViewById(R.id.img);
}
public void onClick(View view) {
Animation animation = null;
switch (view.getId()) {
case R.id.alpha:
animation = AnimationUtils.loadAnimation(this, R.anim.alpha);
break;
case R.id.scale:
animation = AnimationUtils.loadAnimation(this, R.anim.scale);
break;
case R.id.translate:
animation = AnimationUtils.loadAnimation(this, R.anim.translate);
break;
case R.id.rotate:
//animation = AnimationUtils.loadAnimation(this, R.anim.rotate);
//令一種方式JavaCode中 創(chuàng)建RotateAnimation
animation = new RotateAnimation(0, 180, RotateAnimation.RELATIVE_TO_SELF, 0.5f, RotateAnimation.RELATIVE_TO_SELF, 0.5f);
animation.setDuration(3000);
break;
case R.id.all:
animation = AnimationUtils.loadAnimation(this, R.anim.Tween);
break;
}
//啟動動畫
imageView.startAnimation(animation);
}
Tween動畫由四種類型組成
幀動畫是有多張圖片組成,多張圖片循環(huán)。
示例:
Frame.xml
<?xml version="1.0" encoding="utf-8"?> <animation-list xmlns:android="http://schemas.android.com/apk/res/android" android:oneshot="false"> <item android:drawable="@drawable/p1" android:duration="200" /> <item android:drawable="@drawable/p2" android:duration="200" /> <item android:drawable="@drawable/p3" android:duration="200" /> <item android:drawable="@drawable/p4" android:duration="200" /> <item android:drawable="@drawable/p5" android:duration="200" /> <item android:drawable="@drawable/p6" android:duration="200" /> <item android:drawable="@drawable/p7" android:duration="800" /> <item android:drawable="@drawable/p8" android:duration="200" /> <item android:drawable="@drawable/p9" android:duration="200" /> <item android:drawable="@drawable/p10" android:duration="200" /> <item android:drawable="@drawable/p11" android:duration="200" /> </animation-list>
main.xml
<?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:orientation="vertical" android:layout_width="fill_parent" android:layout_height="fill_parent" > <ImageView android:layout_width="wrap_content" android:layout_height="wrap_content" android:src="@anim/frame" android:onClick="go" /> </LinearLayout>
Activity:
public void go(View view) {
// 獲取ImageView
ImageView imageView = (ImageView) view;
// 獲取ImageView上面的動畫圖片
AnimationDrawable drawable = (AnimationDrawable) imageView.getDrawable();
// 動畫開始
drawable.start();
}
希望本文所述對大家Android程序設計有所幫助。
- Android動畫之補間動畫(Tween Animation)實例詳解
- Android幀動畫、補間動畫、屬性動畫用法詳解
- Android動畫之補間動畫(Tween Animation)基礎學習
- android 幀動畫,補間動畫,屬性動畫的簡單總結
- Android基礎知識之tween動畫效果
- Android Tween動畫之RotateAnimation實現(xiàn)圖片不停旋轉效果實例介紹
- Android動畫之漸變動畫(Tween Animation)詳解 (漸變、縮放、位移、旋轉)
- Android 動畫之TranslateAnimation應用詳解
- Android 動畫之ScaleAnimation應用詳解
- Android控件Tween動畫(補間動畫)實現(xiàn)方法示例
相關文章
Android中ScrollView監(jiān)聽滑動距離案例講解
這篇文章主要介紹了Android中ScrollView監(jiān)聽滑動距離案例講解,本篇文章通過簡要的案例,講解了該項技術的了解與使用,以下就是詳細內(nèi)容,需要的朋友可以參考下2021-08-08
android仿知乎ScrollView滾動改變標題欄透明度
這篇文章主要為大家詳細介紹了android仿知乎ScrollView滾動改變標題欄透明度,具有一定的參考價值,感興趣的小伙伴們可以參考一下2018-06-06
詳解Android 利用Iptables實現(xiàn)網(wǎng)絡黑白名單(防火墻)
這篇文章主要介紹了詳解Android 利用Iptables實現(xiàn)網(wǎng)絡黑白名單(防火墻),小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-08-08
加載頁面遮擋耗時操作任務頁面--第三方開源之AndroidProgressLayout
AndroidProgressLayout實現(xiàn)為界面添加圓形進度條。調用setprogress()方法顯示和隱藏進度條,這篇文章主要介紹了加載頁面遮擋耗時操作任務頁面--第三方開源之AndroidProgressLayout的相關資料,需要的朋友可以參考下2015-11-11
詳解Android?Flutter中SliverAppBar的使用教程
對于一個APP來說,肯定會有一個AppBar,這個AppBar一般包含了APP的導航信息等。在lutter已經(jīng)為我們提供了一個非常強大的AppBar組件,這個組件叫做SliverAppBar。本文就來聊聊它的具體使用吧2023-01-01

