Android 編程下設置 Activity 切換動畫

爲 Activity 設置切換動畫

我們知道,我們可以在 AndroidManifest.xml 文件中,通過 android:theme 屬性設置 Activity 的主題。主題中定義了關於 Activity 外觀的很多特性。同時,主題中還可以定義 Activity 的切換動畫。這是應用 Activity 切換動畫的一種方法。下面講解一下如何通過主題來設置 Activity 間的切換動畫。

定義包含動畫的 Activity 主題

res/values/styles.xml,很簡單,就是使用 windowAnimationStyle 這個屬性,指定切換動畫的style即可。

<style name="AnimActivityTheme">
    <item name="android:windowAnimationStyle">@style/FeelyouWindowAnimTheme</item>
</style>

定義切換動畫 style

res/values/styles.xml

<style name="FeelyouWindowAnimTheme" parent="@android:style/Animation.Activity">
    <item name="android:activityOpenEnterAnimation">@anim/in_from_left</item>
    <item name="android:activityOpenExitAnimation">@anim/out_from_right</item>
    <item name="android:activityCloseEnterAnimation">@anim/in_from_right</item>
    <item name="android:activityCloseExitAnimation">@anim/out_from_left</item>
</style>

注意需要繼承自 @android:style/Animation.Activity。具體這4個屬性什麼意思呢?假設我們有 2 個 Activity,分別是 A1 和 A2:

  • 當我們從 A1 啓動 A2 時,A1 從屏幕上消失,這個動畫叫做 android:activityOpenExitAnimation
  • 當我們從 A1 啓動 A2 時,A2 出現在屏幕上,這個動畫叫做 android:activityOpenEnterAnimation
  • 當我們從 A2 退出回到 A1 時,A2 從屏幕上消失,這個叫做 android:activityCloseExitAnimation
  • 當我們從 A2 退出回到 A1 時,A1 出現在屏幕上,這個叫做 android:activityCloseEnterAnimation

結合上面我講的情況,在腦海中想象一下,再結合屬性的名字,就很容易理解了!

定義具體動畫文件

這裏的動畫可以是透明度、位移、縮放之類的任何動畫,我這裏以位移來舉例。當我們 A1 啓動 A2 時,我希望 A1 從右邊平移退出屏幕(out_from_right),A2 從左邊平移進入屏幕(in_from_left)。當我們從 A2 退出回到 A1 時,我希望 A2 從左邊平移退出屏幕(out_from_left),A1 從右邊平移進入屏幕(in_from_right)

下面我貼一下4個具體的動畫的 xml 文件:

anim/out_from_right.xml

按 Ctrl+C 複製代碼
按 Ctrl+C 複製代碼

anim/in_from_left.xml

按 Ctrl+C 複製代碼
按 Ctrl+C 複製代碼

anim/out_from_left.xml

按 Ctrl+C 複製代碼
按 Ctrl+C 複製代碼

anim/in_from_right.xml

按 Ctrl+C 複製代碼
按 Ctrl+C 複製代碼

應用到對應 Activity

AndroidMenifest.xml

複製代碼
<activity
    android:name="info.feelyou.demo.A1"
    android:theme="@style/AnimActivityTheme" >
</activity>
<activity
    android:name="info.feelyou.demo.A2"
    android:theme="@style/AnimActivityTheme" >
</activity>
複製代碼
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章