Android:翻译动画无法正常工作

时间:2012-08-30 01:18:36

标签: java android animation android-animation

我是Android新动画并且尝试使用Property Animations。我试图使用翻译x属性来做滑动效果。但我没有得到我想要的结果。

我有一个布局:

<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="horizontal" >

    <LinearLayout
        android:id="@+id/parent"
        android:layout_width="wrap_content"
        android:layout_height="match_parent"
        android:orientation="horizontal" >

        <LinearLayout
            android:id="@+id/first"
            android:layout_width="320dp"
            android:layout_height="200dp"
            android:background="#00ff00" >
        </LinearLayout>

        <LinearLayout
            android:id="@+id/second"
            android:layout_width="320dp"
            android:layout_height="200dp"
            android:background="#0000ff" >
        </LinearLayout>
    </LinearLayout>

</LinearLayout>

根据布局。我在父线性布局中有两个线性布局,这些布局是水平放置的。并且仅显示第一个布局,第二个布局不在屏幕之外。我正在尝试设置父x属性的动画,以便使用翻译我将滑动父级,第一个将隐藏,第二个将显示。以下是我的代码:

    LinearLayout parent_;
    LinearLayout first_;
    LinearLayout second_;
@Override
public void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);

    parent_ = (LinearLayout) findViewById(R.id.parent);
    first_ = (LinearLayout) parent_.findViewById(R.id.first);
    second_ = (LinearLayout) parent_.findViewById(R.id.second);
}

只是为了模拟我正在使用选项菜单的动画。

static boolean a = true;
@Override
public boolean onOptionsItemSelected(MenuItem item) {

    if(a){
        ObjectAnimator animate = ObjectAnimator.ofFloat(parent_, "x", -parent_.getWidth());
        animate.setDuration(500);
        animate.start();
        animate.addListener(this);
        animate.addUpdateListener(this);
        a = false;
    } else {
        ObjectAnimator animate = ObjectAnimator.ofFloat(parent_, "x", -parent_.getWidth(), 0);
        animate.setDuration(500);
        animate.start();

        a = true;
    }
    return super.onOptionsItemSelected(item);
}

当我启动应用程序时,我的应用程序如下所示:

enter image description here

在动画之后,应用程序看起来像这样:

enter image description here

注意:白色区域实际上是截图的一部分。白色的背景。

动画之后

而不是显示蓝色布局。它完全向左滑动并隐藏起来。并且不显示蓝色布局。我试图在动画期间拍摄一个屏幕截图。它看起来像这样:

enter image description here

我做错了什么?我希望我能很好地解释我的问题....

1 个答案:

答案 0 :(得分:1)

在线性布局中,如果未显示子项,则不会将其布局,也不会成为测量的一部分(如图所示)。我必须使用RelativeLayout并将蓝色子项隐藏在绿色子项后面,这样它仍然是屏幕的一部分。它起作用了......