Hacks動畫篇-Hack3 為ViewGroup的子視圖添加悅目的動畫效果

為ViewGroup的子視圖添加悅目的動畫效果

作者:李旺成

時間:2016年5月11日


這個 Hack 將介紹如何為 ViewGroup 的子視圖添加動畫效果娶视。

默認(rèn)情況下羞延,添加到 ViewGroup 中的子視圖是直接顯示出來的策吠。有一個簡單的方法可以為這個過程增加動畫效果竹习。

LayoutAnimationController 類簡介

LayoutAnimationController 可以為 ViewGroup 的子視圖添加動畫效果茄猫。需要注意的是狈蚤,并不能為每個子視圖分別指定不同的動畫效果(也就是說每個子視圖都會有相同的動畫效果),但是 LayoutAnimationController 可以決定各個子視圖顯示動畫效果的時間划纽。

先看下官方的介紹:

LayoutAnimationController類

文檔上介紹了 ”XML Attributes“脆侮,那說明可以在 xml 中使用,也就是說有兩種使用方式:直接在 Java 代碼中用和在 xml 中定義阿浓。在稍微看一下提供了哪些方法:

LayoutAnimationController方法

有幾個方法簡單解釋下:

  • setInterpolator(Interpolator interpolator):設(shè)置兩個子視圖之間延遲時間的插值器他嚷,注意添加的動畫也是可以設(shè)置單獨設(shè)置插值器的
  • setOrder(int order):設(shè)置控件顯示的順序
  • willOverlap():返回兩個子視圖的動畫是否會出現(xiàn)重疊

LayoutAnimationController 簡單使用

上面介紹 LayoutAnimationController 的時候提過,該類應(yīng)該有兩種使用方式,下面將分別介紹這兩種方式筋蓖。

先看下效果:


LayoutAnimationController使用演示

直接在 Java 代碼中使用

1卸耘、創(chuàng)建動畫

AnimationSet set = new AnimationSet(false); // 傳入 false 表示組成動畫集中的動畫使用不同的 Interpolator
Animation alphaAnimation = new AlphaAnimation(0.0f, 1.0f);
alphaAnimation.setDuration(700);
alphaAnimation.setInterpolator(new FastOutSlowInInterpolator());
set.addAnimation(alphaAnimation);

Animation translateAnimation = new TranslateAnimation(
        Animation.RELATIVE_TO_SELF,
        0.0f,
        Animation.RELATIVE_TO_SELF,
        0.0f,
        Animation.RELATIVE_TO_SELF,
        -1.0f,
        Animation.RELATIVE_TO_SELF,
        0.0f);
translateAnimation.setDuration(1000);
translateAnimation.setInterpolator(new LinearOutSlowInInterpolator());
set.addAnimation(translateAnimation);

這里使用透明度動畫和位移動畫組合創(chuàng)建一個動畫集,并且分別為這兩個動畫設(shè)置了不同的 Interpolator 以及 持續(xù)時間粘咖。

注意:直接使用某一種動畫是完全一樣的蚣抗,這里使用動畫集僅僅是為了演示。

2瓮下、代碼創(chuàng)建 LayoutAnimationController

LayoutAnimationController lac = new LayoutAnimationController(
                set,
                1f);

3翰铡、設(shè)置子視圖顯示的順序

lac.setOrder(LayoutAnimationController.ORDER_NORMAL);

order 可有如下取值:

  • ORDER_NORMAL:順序
  • ORDER_REVERSE:相反
  • ORDER_RANDOM:隨機(jī)

4、為 ViewGroup 設(shè)置 LayoutAnimationController

mContentLV.setLayoutAnimation(lac);

5讽坏、為 ViewGroup 添加子視圖
這里的 ViewGroup 是 ListView锭魔,所以要為其設(shè)置 Adapter:

mContentLV.setAdapter(new ArrayAdapter<String>(
                this,
                android.R.layout.simple_list_item_1,
                Countries.COUNTRIES));

使用很簡單,就這么幾步即可路呜。

在 xml 中定義 LayoutAnimationController

其實與在 Java 代碼中使用是一樣的迷捧,只是定義方式的區(qū)別。

1胀葱、創(chuàng)建 layoutAnimation 的 xml 文件
在 res/anim 文件夾下面創(chuàng)建名為 list_item_anim_layout.xml 的文件漠秋,內(nèi)容如下:

<?xml version="1.0" encoding="utf-8"?>
<layoutAnimation xmlns:android="http://schemas.android.com/apk/res/android"
    android:delay="1"
    android:animationOrder="reverse"
    android:animation="@anim/list_animation"/>

在這里可以直接設(shè)置子視圖的順序,延遲時間(注意:單位是”秒“)抵屿,以及要顯示的動畫庆锦。

2、在布局中為 ViewGroup 設(shè)置 layoutAnimation 屬性

<ListView
    android:id="@+id/lv_content"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:layoutAnimation="@anim/list_item_anim_layout"/>

3轧葛、為 ListView 設(shè)置 Adapter
為 ListView 設(shè)置好 Adapter 應(yīng)該就可以看到效果了搂抒。這里就不演示了,代碼在演示項目中都有朝群,感興趣的可以自己下去嘗試燕耿。

注意事項

只在第一次設(shè)置時有效?
示例中使用了 LinearLayout姜胖,通過點擊按鈕往 LinearLayout 中添加和刪除子視圖誉帅。你會發(fā)現(xiàn)在給 LinearLayout 設(shè)置好 LayoutAnimationController 后調(diào)用添加方法(也就是在 oncreate() 方法中執(zhí)行的那段代碼),會有動畫效果右莱。但是蚜锨,當(dāng)你再次點擊”添加“或”刪除“按鈕,并沒有出現(xiàn)動畫效果慢蜓。

這里沒有深入研究了亚再,只是在添加和刪除子視圖之前又調(diào)用了一下 ViewGroup 的 setLayoutAnimation() 方法,但是效果很詭異晨抡,所有的子視圖都會執(zhí)行動畫氛悬。

項目地址

AndroidHacks合集
動畫篇

項目示例代碼:
VGChildrenAnimActivity.java
Countries.java
activity_vgchildrenanim.xml
list_item_anim_layout.xml

參考

LayoutAnimationController

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末则剃,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子如捅,更是在濱河造成了極大的恐慌棍现,老刑警劉巖,帶你破解...
    沈念sama閱讀 206,378評論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件镜遣,死亡現(xiàn)場離奇詭異己肮,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)悲关,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,356評論 2 382
  • 文/潘曉璐 我一進(jìn)店門谎僻,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人寓辱,你說我怎么就攤上這事艘绍。” “怎么了讶舰?”我有些...
    開封第一講書人閱讀 152,702評論 0 342
  • 文/不壞的土叔 我叫張陵鞍盗,是天一觀的道長需了。 經(jīng)常有香客問我跳昼,道長,這世上最難降的妖魔是什么肋乍? 我笑而不...
    開封第一講書人閱讀 55,259評論 1 279
  • 正文 為了忘掉前任鹅颊,我火速辦了婚禮,結(jié)果婚禮上墓造,老公的妹妹穿的比我還像新娘堪伍。我一直安慰自己,他們只是感情好觅闽,可當(dāng)我...
    茶點故事閱讀 64,263評論 5 371
  • 文/花漫 我一把揭開白布帝雇。 她就那樣靜靜地躺著,像睡著了一般蛉拙。 火紅的嫁衣襯著肌膚如雪尸闸。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,036評論 1 285
  • 那天孕锄,我揣著相機(jī)與錄音吮廉,去河邊找鬼。 笑死畸肆,一個胖子當(dāng)著我的面吹牛宦芦,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播轴脐,決...
    沈念sama閱讀 38,349評論 3 400
  • 文/蒼蘭香墨 我猛地睜開眼调卑,長吁一口氣:“原來是場噩夢啊……” “哼抡砂!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起恬涧,我...
    開封第一講書人閱讀 36,979評論 0 259
  • 序言:老撾萬榮一對情侶失蹤舀患,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后气破,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體聊浅,經(jīng)...
    沈念sama閱讀 43,469評論 1 300
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 35,938評論 2 323
  • 正文 我和宋清朗相戀三年现使,在試婚紗的時候發(fā)現(xiàn)自己被綠了低匙。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 38,059評論 1 333
  • 序言:一個原本活蹦亂跳的男人離奇死亡碳锈,死狀恐怖顽冶,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情售碳,我是刑警寧澤强重,帶...
    沈念sama閱讀 33,703評論 4 323
  • 正文 年R本政府宣布,位于F島的核電站贸人,受9級特大地震影響间景,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜艺智,卻給世界環(huán)境...
    茶點故事閱讀 39,257評論 3 307
  • 文/蒙蒙 一倘要、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧十拣,春花似錦封拧、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,262評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至缰趋,卻和暖如春捧杉,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背埠胖。 一陣腳步聲響...
    開封第一講書人閱讀 31,485評論 1 262
  • 我被黑心中介騙來泰國打工糠溜, 沒想到剛下飛機(jī)就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人直撤。 一個月前我還...
    沈念sama閱讀 45,501評論 2 354
  • 正文 我出身青樓非竿,卻偏偏與公主長得像,于是被迫代替她去往敵國和親谋竖。 傳聞我的和親對象是個殘疾皇子红柱,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 42,792評論 2 345

推薦閱讀更多精彩內(nèi)容