Android Fragment Transaction自定义动画

时间:2016-07-19 19:09:19

标签: android android-animation

我试图在这里找到动画。

Android 3d animation like Google Now Launcher Menu Animation

但是,我似乎无法使用objectAnimator,因为我使用了支持库片段。当我尝试使用上面链接中的代码时,我收到一条错误,指出未知动画:objectAnimator。

在使用片段支持库的同时添加/删除片段时,如何完成这样的动画?

更新

根据以下DeeV的回答,我已经为其余部分更新了XML动画。

gla_back_come.xml

<set xmlns:android="http://schemas.android.com/apk/res/android" android:duration="500">

    <alpha
        android:fromAlpha="1.0"
        android:toAlpha="0.0" />

    <scale
        android:fromXScale="1"
        android:toXScale="0"
        android:fromYScale="1"
        android:toYScale="0"
        android:pivotX="50%"
        android:pivotY="50%"
        android:interpolator="@android:anim/accelerate_decelerate_interpolator" />

</set>

gla_back_gone.xml

<set xmlns:android="http://schemas.android.com/apk/res/android" android:duration="500" >

    <alpha
        android:fromAlpha="0.0"
        android:toAlpha="1.0" />

    <scale
        android:fromXScale="12.0"
        android:toXScale="1.0"
        android:fromYScale="12.0"
        android:toYScale="1.0"
        android:pivotX="50%"
        android:pivotY="50%"
        android:interpolator="@android:anim/accelerate_decelerate_interpolator"/>

</set>

gla_there_come.xml

<set xmlns:android="http://schemas.android.com/apk/res/android" android:duration="500">

    <alpha
        android:fromAlpha="0.0"
        android:toAlpha="1.0" />

    <scale
        android:fromXScale="0.0"
        android:toXScale="1.0"
        android:fromYScale="0.0"
        android:toYScale="1.0"
        android:pivotX="50%"
        android:pivotY="50%"
        android:interpolator="@android:anim/accelerate_decelerate_interpolator"/>

</set>

gla_there_gone.xml

<set xmlns:android="http://schemas.android.com/apk/res/android" android:duration="500" >

    <alpha
        android:fromAlpha="1.0"
        android:toAlpha="0.0"/>

    <scale
        android:fromXScale="1.0"
        android:toXScale="12.0"
        android:fromYScale="1.0"
        android:toYScale="12.0"
        android:pivotX="50%"
        android:pivotY="50%"
        android:interpolator="@android:anim/accelerate_decelerate_interpolator"/>

</set>

1 个答案:

答案 0 :(得分:2)

您可以使用经典Animation替换ObjectAnimator。它们可以以大致相同的方式创建。您可以将它们放在animator资源目录中,而不是将xml文件放在anim资源目录中。 xml文件中的动画本身更具体地命名。您可以为要执行的动画命名,而不是命名属性:

<?xml version="1.0" encoding="utf-8"?>
<set xmlns:android="http://schemas.android.com/apk/res/android"
    android:interpolator="@[package:]anim/interpolator_resource"
    android:shareInterpolator=["true" | "false"] >
    <alpha
        android:fromAlpha="float"
        android:toAlpha="float" />
    <scale
        android:fromXScale="float"
        android:toXScale="float"
        android:fromYScale="float"
        android:toYScale="float"
        android:pivotX="float"
        android:pivotY="float" />
    <translate
        android:fromXDelta="float"
        android:toXDelta="float"
        android:fromYDelta="float"
        android:toYDelta="float" />
    <rotate
        android:fromDegrees="float"
        android:toDegrees="float"
        android:pivotX="float"
        android:pivotY="float" />
    <set>
        ...
    </set>
</set>

例如,在您发布的答案中,“gla_there_come.xml”将来自:

<set xmlns:android="http://schemas.android.com/apk/res/android" >

  <objectAnimator
    android:duration="500"
    android:propertyName="alpha"
    android:valueFrom="0.0"
    android:valueTo="1.0" />
  <objectAnimator
    android:duration="500"
    android:interpolator="@android:interpolator/accelerate_decelerate"
    android:propertyName="scaleY"
    android:valueFrom="0"
    android:valueTo="1" />
  <objectAnimator
    android:duration="500"
    android:interpolator="@android:interpolator/accelerate_decelerate"
    android:propertyName="scaleX"
    android:valueFrom="0"
    android:valueTo="1" />

</set>

到此:

<set xmlns:android="http://schemas.android.com/apk/res/android"
     duration="500">

  <alpha
    android:fromAlpha="0.0"
    android:toAlpha="1.0" />

  <scale
    android:fromXScale="0.0"
    android:toXScale="1.0"
    android:fromYScale="0.0"
    android:toYScale="1.0"
    android:pivotX="50%"
    android:pivotY="50%"
    android:interpolator="@android:anim/accelerate_decelerate_interpolator"/>

</set>