Android 三種動畫詳解及簡單實(shí)例
Android 三種動畫詳解
幀動畫
一張張圖片不斷的切換,形成動畫效果
在drawable目錄下定義xml文件,子節(jié)點(diǎn)為animation-list,在這里定義要顯示的圖片和每張圖片的顯示時(shí)長
<animation-list
xmlns:android="http://schemas.android.com/apk/res/android"
android:oneshot="false">
<item android:drawable="@drawable/g1"
android:duration="200" />
<item android:drawable="@drawable/g2"
android:duration="200" />
<item android:drawable="@drawable/g3" 、
android:duration="200" />
</animation-list>
在屏幕上播放幀動畫
ImageView iv = (ImageView) findViewById(R.id.iv);
//把動畫文件設(shè)置為imageView的背景
iv.setBackgroundResource(R.drawable.animations);
AnimationDrawable ad = (AnimationDrawable)
iv.getBackground();
//播放動畫
ad.start();
補(bǔ)間動畫
- 原形態(tài)變成新形態(tài)時(shí)為了過渡變形過程,生成的動畫就叫補(bǔ)間動畫,補(bǔ)間動畫,只是一個動畫效果,組件其實(shí)還在原來的位置上,xy沒有改變
- 位移、旋轉(zhuǎn)、縮放、透明
位移:
- 參數(shù)10指的是X的起點(diǎn)坐標(biāo),但不是指屏幕x坐標(biāo)為10的位置,而是imageview的 真實(shí)X + 10
- 參數(shù)150指的是X的終點(diǎn)坐標(biāo),它的值是imageview的 真實(shí)X + 150
//創(chuàng)建為位移動畫對象,設(shè)置動畫的初始位置和結(jié)束位置 TranslateAnimation ta = new TranslateAnimation(10, 150, 20, 140);
- x坐標(biāo)的起點(diǎn)位置,如果相對于自己,傳0.5f,那么起點(diǎn)坐標(biāo)就是 真實(shí)X + 0.5 * iv寬度
- x坐標(biāo)的終點(diǎn)位置,如果傳入2,那么終點(diǎn)坐標(biāo)就是 真實(shí)X + 2 * iv的寬度
- y坐標(biāo)的起點(diǎn)位置,如果傳入0.5f,那么起點(diǎn)坐標(biāo)就是 真實(shí)Y + 0.5 * iv高度
- y坐標(biāo)的終點(diǎn)位置,如果傳入2,那么終點(diǎn)坐標(biāo)就是 真實(shí)Y + 2 * iv高度
TranslateAnimation ta = new TranslateAnimation(Animation.RELATIVE_TO_SELF, 0.5f, Animation.RELATIVE_TO_SELF, 2, Animation.RELATIVE_TO_SELF, 0.5f, Animation.RELATIVE_TO_SELF, 2);
動畫播放相關(guān)的設(shè)置
//設(shè)置動畫持續(xù)時(shí)間
ta.setDuration(2000);
//動畫重復(fù)播放的次數(shù)
ta.setRepeatCount(1);
//動畫重復(fù)播放的模式
ta.setRepeatMode(Animation.REVERSE);
//動畫播放完畢后,組件停留在動畫結(jié)束的位置上
ta.setFillAfter(true);
//播放動畫
iv.startAnimation(ta);
縮放:
- 參數(shù)0.1f表示動畫的起始寬度是真實(shí)寬度的0.1倍
- 參數(shù)4表示動畫的結(jié)束寬度是真實(shí)寬度的4倍
- 縮放的中心點(diǎn)在iv左上角
ScaleAnimation sa = new ScaleAnimation(0.1f, 4, 0.1f, 4);
- 參數(shù)0.1f和4意義與上面相同
- 改變縮放的中心點(diǎn):傳入的兩個0.5f,類型都是相對于自己,這兩個參數(shù)改變了縮放的中心點(diǎn)
- 中心點(diǎn)x坐標(biāo) = 真實(shí)X + 0.5 * iv寬度
- 中心點(diǎn)Y坐標(biāo) = 真實(shí)Y + 0.5 * iv高度
ScaleAnimation sa = new ScaleAnimation(0.1f, 4, 0.1f, 4, Animation.RELATIVE_TO_SELF, 0.5f, Animation.RELATIVE_TO_SELF, 0.5f);
透明:
0為完全透明,1為完全不透明
AlphaAnimation aa = new AlphaAnimation(0, 0.5f);
旋轉(zhuǎn):
- 20表示動畫開始時(shí)的iv的角度
- 360表示動畫結(jié)束時(shí)iv的角度
- 默認(rèn)旋轉(zhuǎn)的圓心在iv左上角
RotateAnimation ra = new RotateAnimation(20, 360);
- 20,360的意義和上面一樣
- 指定圓心坐標(biāo),相對于自己,值傳入0.5,那么圓心的x坐標(biāo):真實(shí)X + iv寬度 * 0.5
- 圓心的Y坐標(biāo):真實(shí)Y + iv高度 * 0.5
RotateAnimation ra = new RotateAnimation(20, 360, Animation.RELATIVE_TO_SELF, 0.5f, Animation.RELATIVE_TO_SELF, 0.5f);
所有動畫一起飛
//創(chuàng)建動畫集合
AnimationSet set = new AnimationSet(false);
//往集合中添加動畫
set.addAnimation(aa);
set.addAnimation(sa);
set.addAnimation(ra);
iv.startAnimation(set);
屬性動畫
位移:
- 第一個參數(shù)target指定要顯示動畫的組件
- 第二個參數(shù)propertyName指定要改變組件的哪個屬性
- 第三個參數(shù)values是可變參數(shù),就是賦予屬性的新的值
- 傳入0,代表x起始坐標(biāo):當(dāng)前x + 0
- 傳入100,代表x終點(diǎn)坐標(biāo):當(dāng)前x + 100
//具有g(shù)et、set方法的成員變量就稱為屬性 ObjectAnimator oa = ObjectAnimator.ofFloat(bt, "translationX", 0, 100) ;
縮放:
- 第三個參數(shù)指定縮放的比例
- 0.1是從原本高度的十分之一開始
- 2是到原本高度的2倍結(jié)束
ObjectAnimator oa = ObjectAnimator.ofFloat(bt, "scaleY", 0.1f, 2);
透明:
透明度,0是完全透明,1是完全不透明
ObjectAnimator oa = ObjectAnimator.ofFloat(bt, "alpha", 0.1f, 1);
旋轉(zhuǎn)
- rotation指定是順時(shí)針旋轉(zhuǎn)
- 20是起始角度
- 270是結(jié)束角度
ObjectAnimator oa = ObjectAnimator.ofFloat(bt, "rotation", 20, 270);
- 屬性指定為rotationX是豎直翻轉(zhuǎn)
- 屬性指定為rotationY是水平翻轉(zhuǎn)
ObjectAnimator oa = ObjectAnimator.ofFloat(bt, "rotationY", 20, 180);
可變參數(shù)
第三個參數(shù)可變參數(shù)可以傳入多個參數(shù),可以實(shí)現(xiàn)往回位移(旋轉(zhuǎn)、縮放、透明)
ObjectAnimator oa = ObjectAnimator.ofFloat(bt, "translationX", 0, 70, 30, 100) ;
所有動畫一起飛
//創(chuàng)建動畫師集合
AnimatorSet set = new AnimatorSet();
//設(shè)置要播放動畫的組件
set.setTarget(bt);
//所有動畫有先后順序的播放
//set.playSequentially(oa, oa2, oa3, oa4);
//所有動畫一起播放
set.playTogether(oa, oa2, oa3, oa4);
set.start();
感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!
- 三款A(yù)ndroid炫酷Loading動畫組件推薦
- Android實(shí)現(xiàn)Activity界面切換添加動畫特效的方法
- Android 使用XML做動畫UI的深入解析
- Android Tween動畫之RotateAnimation實(shí)現(xiàn)圖片不停旋轉(zhuǎn)效果實(shí)例介紹
- Android動畫之逐幀動畫(Frame Animation)實(shí)例詳解
- Android系統(tǒng)聯(lián)系人全特效實(shí)現(xiàn)(上)分組導(dǎo)航和擠壓動畫(附源碼)
- Android啟動畫面的實(shí)現(xiàn)方法
- Android開發(fā)之圖形圖像與動畫(一)Paint和Canvas類學(xué)習(xí)
- Android開發(fā)之圖形圖像與動畫(二)Animation實(shí)現(xiàn)圖像的漸變/縮放/位移/旋轉(zhuǎn)
相關(guān)文章
Android?ASM插樁探索實(shí)戰(zhàn)詳情
這篇文章主要介紹了Android?ASM插樁探索實(shí)戰(zhàn)詳情,文章圍繞主題展開詳細(xì)的內(nèi)容戒殺,具有一定的參考價(jià)值,需要的小伙伴可以參考一下2022-09-09
Android TextWatcher三個回調(diào)以及監(jiān)聽EditText的輸入案例詳解
這篇文章主要介紹了Android TextWatcher三個回調(diào)以及監(jiān)聽EditText的輸入案例詳解,本篇文章通過簡要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下2021-08-08
Android?14新功能HighLights快速實(shí)現(xiàn)文本高亮
這篇文章主要為大家介紹了Android?14新功能HighLights快速實(shí)現(xiàn)文本高亮示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-03-03
Android ContentProvider的實(shí)現(xiàn)及簡單實(shí)例代碼
這篇文章主要介紹了Android ContentProvider的實(shí)現(xiàn)及簡單實(shí)例代碼的相關(guān)資料,需要的朋友可以參考下2017-02-02
okhttp3.4.1+retrofit2.1.0實(shí)現(xiàn)離線緩存的示例
本篇文章主要介紹了okhttp3.4.1+retrofit2.1.0實(shí)現(xiàn)離線緩存的示例,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-12-12
ListView實(shí)現(xiàn)下拉刷新加載更多的實(shí)例代碼(直接拿來用)
這篇文章主要介紹了ListView實(shí)現(xiàn)下拉刷新加載更多的實(shí)例代碼(直接拿來用)的相關(guān)資料,需要的朋友可以參考下2016-07-07
Android中SeekBar和RatingBar用法實(shí)例分析
這篇文章主要介紹了Android中SeekBar和RatingBar用法,結(jié)合實(shí)例形式分析了SeekBar和RatingBar的功能、定義與簡單使用方法,需要的朋友可以參考下2016-06-06

