【问题标题】:Strange behaviour while using PropertyAnimations OR is this a feature?使用 PropertyAnimations 时出现奇怪的行为或者这是一项功能吗?
【发布时间】:2014-03-26 01:03:01
【问题描述】:

我在搞砸PropertyAnimations。为此,我有一个简单(但冗长)的设置来玩。有两个Views 通过按钮单击在y-Axis 上切换位置。在这种平移过程中,通过缩放 View,一个 View 会变小另一个 View 会变大。

好的,这行得通!但我发现了一个非常奇怪的行为,让我感到惊讶。如果我在其他两个View 已经存在的布局中添加一个额外的View,动画将改变它的行为!

将不再有正常的y-Axis 翻译,动画现在会将Views 翻译成一个圆圈,也意味着x-Axis我想知道为什么添加一个简单的 View 会改变整个动画?

我想我无法更好地描述它,所以这是我重现问题的完整设置。只需在您第一次按下按钮后删除高度为 1dp 的视图,您就会看到。

这是我的视图布局:

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical"
    android:paddingBottom="@dimen/activity_vertical_margin"
    android:paddingLeft="@dimen/activity_horizontal_margin"
    android:paddingRight="@dimen/activity_horizontal_margin"
    android:paddingTop="@dimen/activity_vertical_margin"
    tools:context="com.example.inputtest.MainActivity$PlaceholderFragment" >

    <LinearLayout
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_gravity="center_vertical"
        android:orientation="vertical">

        <TextView
               android:id="@+id/origin"
               android:layout_width="match_parent"
               android:layout_height="wrap_content"
               android:paddingLeft="20dp"
               android:paddingRight="20dp"
               android:text="FOO"/>

        <View 
            android:layout_width="wrap_content"
            android:layout_height="1dp"
            android:layout_marginTop="20dp"
            android:layout_marginBottom="20dp"
            android:background="#000000"/>

        <TextView
               android:id="@+id/destination"
               android:layout_width="match_parent"
               android:layout_height="wrap_content"
               android:paddingLeft="20dp"
               android:paddingRight="20dp"
               android:text="BAR"/>

    </LinearLayout>
    <Button
        android:id="@+id/switcher"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_gravity="center_vertical"
        android:text="Switch"/>

</LinearLayout>

这是基本的启动Activity:

public class MainActivity extends ActionBarActivity {

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

        if (savedInstanceState == null) {
            getSupportFragmentManager().beginTransaction()
                    .add(R.id.container, new PlaceholderFragment()).commit();
        }
    }

    public static class PlaceholderFragment extends Fragment {

        public PlaceholderFragment() {}

        TextView foo;
        TextView bar;

        @Override
        public View onCreateView(LayoutInflater inflater,
                ViewGroup container,
                Bundle savedInstanceState) {
            View rootView = inflater.inflate(R.layout.fragment_main, container,
                    false);

            foo = (TextView)rootView.findViewById(R.id.origin);
            bar = (TextView)rootView.findViewById(R.id.destination);

            Button btn = (Button)rootView.findViewById(R.id.switcher);
            btn.setOnClickListener(new OnClickListener() {

                @Override
                public void onClick(View v) {
                    AnimatorSet scale1 = null;
                    AnimatorSet scale2 = null;
                    ObjectAnimator translate1 = null;
                    ObjectAnimator translate2 = null;

                    if (foo.getTranslationY() == 0) {
                        translate1 = ObjectAnimator.ofFloat(foo, "translationY", bar.getTop());
                        translate2 = ObjectAnimator.ofFloat(bar, "translationY", bar.getTop()*(-1));
                        scale1 = (AnimatorSet)AnimatorInflater.loadAnimator(getActivity(), R.animator.scaler);
                        scale2 = (AnimatorSet)AnimatorInflater.loadAnimator(getActivity(), R.animator.scaler2);
                    } else {
                        translate1 = ObjectAnimator.ofFloat(foo, "translationY", 0);
                        translate2 = ObjectAnimator.ofFloat(bar, "translationY", 0);
                        scale1 = (AnimatorSet)AnimatorInflater.loadAnimator(getActivity(), R.animator.scaler2);
                        scale2 = (AnimatorSet)AnimatorInflater.loadAnimator(getActivity(), R.animator.scaler);
                    }

                    translate1.setDuration(500L);
                    translate2.setDuration(500L);

                    scale1.setTarget(foo);
                    scale2.setTarget(bar);

                    AnimatorSet set = new AnimatorSet();
                    set.playTogether(scale1, scale2, translate1, translate2);
                    set.start();
                }
            });
            return rootView;
        }
    }
}

动画的 scaler.xml:

<?xml version="1.0" encoding="utf-8"?>
<set xmlns:android="http://schemas.android.com/apk/res/android" 
    android:ordering="sequentially">

    <set 
        android:ordering="together">

        <objectAnimator
            android:propertyName="scaleX"
            android:duration="250"
            android:valueTo="2.0"/>

        <objectAnimator
            android:propertyName="scaleY"
            android:duration="250"
            android:valueTo="2.0"/>

    </set>

    <set 
        android:ordering="together">

        <objectAnimator
            android:propertyName="scaleX"
            android:duration="250"
            android:valueTo="1.0"/>

        <objectAnimator
            android:propertyName="scaleY"
            android:duration="250"
            android:valueTo="1.0"/>
   </set>
</set>

动画的 scaler2.xml:

<?xml version="1.0" encoding="utf-8"?>
<set xmlns:android="http://schemas.android.com/apk/res/android" 
    android:ordering="sequentially">

    <set 
        android:ordering="together">

        <objectAnimator
            android:propertyName="scaleX"
            android:duration="250"
            android:valueTo="0.5"/>

        <objectAnimator
            android:propertyName="scaleY"
            android:duration="250"
            android:valueTo="0.5"/>
    </set>

    <set 
        android:ordering="together">

    <objectAnimator
            android:propertyName="scaleX"
            android:duration="250"
            android:valueTo="1.0"/>

        <objectAnimator
            android:propertyName="scaleY"
            android:duration="250"
            android:valueTo="1.0"/>
   </set>
</set>

【问题讨论】:

    标签: android animation android-animation behavior


    【解决方案1】:

    我玩了一下,找到了解决方案 :) 对我来说,圆圈动画甚至出现在只有 2 个视图时,所以我认为这与它无关,首先我认为这是一些布局限制,我把它改成了RelativeLayout,没区别……原因是你的比例因子是0.5和2.0!视图宽度加倍减半,因此内容似乎在移动,但只是缩放了。如果您始终将 scaleX 属性更改为 1.0f,您将只会看到一个 y 平移。

    我建议在代码或 xml 中创建所有动画,这似乎有点混乱 :) 我在这里写的内容可能很有趣......https://stackoverflow.com/a/22635237/2001247

    【讨论】:

    • mmh 这很有趣,因为如果我在设备上添加/删除具有相同缩放参数的视图,相同的设置会产生两个不同的动画。我为此使用了 KitKat。我为混乱的代码道歉,但现在我正在研究动画..
    • Nexus 5/KitKat 也在这里。在这些奇怪的时期,当这些事情发生时,我只是从一个新项目重新开始,只是从损坏的项目中复制并粘贴进去,这通常可以节省一天的时间。
    猜你喜欢
    • 1970-01-01
    • 2011-09-09
    • 2015-11-26
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2013-02-15
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多