theme-windowAnimationStyle 动画设置

对于windowAnimationStyle 的引用,目前自己发现的有两处

1.就是直接在Theme 中引用的,如下

<style name="Theme.Funui" parent="Theme.Holo.Light">
  <!--activity 动画引用-->
  <item name="android:windowAnimationStyle">@android:style/Animation.Holo.Activity</item>
</style> <style name="Animation.Holo.Activity" parent="Animation.Activity">
</style>
<style name="Animation.Activity">
       <!--A打开B,B的出现动画-->
<item name="activityOpenEnterAnimation">@anim/activity_open_enter</item>
        <!--A打开B,A的消失动画-->
<item name="activityOpenExitAnimation">@anim/activity_open_exit</item>
         <!--A关闭B,B的出现动画-->
<item name="activityCloseEnterAnimation">@anim/activity_close_enter</item>

         <!--A关闭B,A的消失动画-->
         <item name="activityCloseExitAnimation">@anim/activity_close_exit</item> 
         <item name="taskOpenEnterAnimation">@anim/task_open_enter</item>
         <item name="taskOpenExitAnimation">@anim/task_open_exit</item>
         <item name="taskCloseEnterAnimation">@anim/task_close_enter</item>
         <item name="taskCloseExitAnimation">@anim/task_close_exit</item>
         <item name="taskToFrontEnterAnimation">@anim/task_open_enter</item>
         <item name="taskToFrontExitAnimation">@anim/task_open_exit</item>
         <item name="taskToBackEnterAnimation">@anim/task_close_enter</item>
         <item name="taskToBackExitAnimation">@anim/task_close_exit</item>
         <item name="wallpaperOpenEnterAnimation">@anim/wallpaper_open_enter</item>
         <item name="wallpaperOpenExitAnimation">@anim/wallpaper_open_exit</item>
         <item name="wallpaperCloseEnterAnimation">@anim/wallpaper_close_enter</item>
         <item name="wallpaperCloseExitAnimation">@anim/wallpaper_close_exit</item>
         <item name="wallpaperIntraOpenEnterAnimation">@anim/wallpaper_intra_open_enter</item>
         <item name="wallpaperIntraOpenExitAnimation">@anim/wallpaper_intra_open_exit</item>
         <item name="wallpaperIntraCloseEnterAnimation">@anim/wallpaper_intra_close_enter</item>
         <item name="wallpaperIntraCloseExitAnimation">@anim/wallpaper_intra_close_exit</item>
         <item name="fragmentOpenEnterAnimation">@animator/fragment_open_enter</item>
         <item name="fragmentOpenExitAnimation">@animator/fragment_open_exit</item>
         <item name="fragmentCloseEnterAnimation">@animator/fragment_close_enter</item>
         <item name="fragmentCloseExitAnimation">@animator/fragment_close_exit</item>
         <item name="fragmentFadeEnterAnimation">@animator/fragment_fade_enter</item>
         <item name="fragmentFadeExitAnimation">@animator/fragment_fade_exit</item>
 </style>

还有一种引用,是在Theme.Dialog中

如下

<style name="Theme.Funui" parent="Theme.Holo.Light">

<item name="dialogTheme">@android:style/Theme.Funui.Dialog</item>

</style>

 <style name="Theme.Funui.Dialog" >
        <item name="android:windowFrame">@null</item>
        <item name="android:windowTitleStyle">@android:style/DialogWindowTitle.Funui</item>
        <item name="android:windowBackground">@android:drawable/dialog_full_funui</item>
        <item name="android:windowIsFloating">true</item>
        <item name="android:windowContentOverlay">@null</item>
        <item name="android:windowAnimationStyle">@android:style/Animation.Funui.Dialog</item>
        <item name="android:windowSoftInputMode">stateUnspecified|adjustPan</item>
        <item name="android:windowActionBar">false</item>
        <item name="android:windowActionModeOverlay">true</item>
        <item name="android:windowCloseOnTouchOutside">@bool/config_closeDialogWhenTouchOutside</item>

        <item name="android:colorBackgroundCacheHint">@null</item>

        <item name="android:buttonBarStyle">@android:style/Funui.ButtonBar.AlertDialog</item>
        <item name="borderlessButtonStyle">@android:style/Widget.Funui.Button.Borderless.Small</item>

        <item name="textAppearance">@android:style/TextAppearance.Funui</item>
        <item name="textAppearanceInverse">@android:style/TextAppearance.Funui.Inverse</item>

        <item name="listPreferredItemPaddingLeft">16dip</item>
        <item name="listPreferredItemPaddingRight">16dip</item>
        <item name="listPreferredItemPaddingStart">16dip</item>
        <item name="listPreferredItemPaddingEnd">16dip</item>

        <item name="preferencePanelStyle">@style/PreferencePanel.Dialog</item>
    </style>      
    <style name="Animation.Funui.Dialog" parent="Animation.Dialog">
<item name="windowEnterAnimation">@anim/funui_dialog_enter</item> <item name="windowExitAnimation">@anim/funui_dialog_exit</item> </style>

funui_dialog_enter 跟funui_dialog_exit 两个文件内容如下

<!--enter-->
<?xml version="1.0" encoding="utf-8"?>
<set xmlns:android="http://schemas.android.com/apk/res/android"
    android:duration="400"
    android:fillAfter="true"
    android:fillBefore="true"
    android:fillEnabled="true"
    android:interpolator="@anim/decelerate_interpolator" >

    <translate
        android:fromXDelta="0.0%"
        android:fromYDelta="100.0%"
        android:toXDelta="0.0%"
        android:toYDelta="0.0%" />

</set>

<!--exit-->
<?xml version="1.0" encoding="utf-8"?>
<set xmlns:android="http://schemas.android.com/apk/res/android"
    android:duration="400"
    android:fillAfter="true"
    android:fillBefore="true"
    android:fillEnabled="true"
    android:interpolator="@anim/decelerate_interpolator" >

    <translate
        android:fromXDelta="0.0%"
        android:fromYDelta="0.0%"
        android:toXDelta="0.0%"
        android:toYDelta="100.0%" />

</set>

 

 

 

从上面两个代码我们就很容易理解了,虽然在不同的theme下,windowAnimationStyle 的引用一样,但是他们的属性是有区别的。一个是作用于activity,一个是作用在dialog中。

转载于:https://www.cnblogs.com/zhangshuli-1989/p/zhangshuli_anim_150317131.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值