如何在android中的按钮上添加动画

时间:2014-07-12 15:52:17

标签: android android-animation

我在Android平台上制作应用程序。我想在我的应用程序的按钮上添加动画。动画是这样的:如果我在一个布局上按下按钮,那么另一个按钮将添加到应用布局的左侧的相同布局。用户将会看到来自应用程序左侧的按钮的移动。

我不知道我该怎么做。请给我一些有用的博客/教程/文档。事先提醒:)

1 个答案:

答案 0 :(得分:0)

你可以使用viewswitcher添加一个按钮,点击另一个按钮,我有一个例子来切换图像和一个带有按钮和textview的线性布局。

<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=".MainActivity" >

<ViewSwitcher
    android:id="@+id/viewswitcher1"
    android:layout_width="match_parent"
    android:layout_height="wrap_content" >

    <ImageView
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:src="@drawable/a" />

    <LinearLayout
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:gravity="center"
        android:orientation="vertical" >

        <Button
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:text="Button" />

        <TextView
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:text="LinearLayout 2" />
    </LinearLayout>
</ViewSwitcher>

<LinearLayout
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:orientation="horizontal" >

    <Button
        android:id="@+id/prev"
        android:layout_width="0dp"
        android:layout_height="wrap_content"
        android:layout_weight="1"
        android:text="Previous" />

    <Button
        android:id="@+id/next"
        android:layout_width="0dp"
        android:layout_height="wrap_content"
        android:layout_weight="1"
        android:text="Next" />
</LinearLayout>

  import android.os.Bundle;
  import android.app.Activity;
  import android.view.View;
  import android.view.View.OnClickListener;
  import android.view.animation.Animation;
  import android.view.animation.AnimationUtils;
  import android.widget.Button;
  import android.widget.ViewSwitcher;

   public class MainActivity extends Activity {

Button buttonPrev, buttonNext;
ViewSwitcher viewSwitcher;

Animation slide_in_left, slide_out_right;

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

    buttonPrev = (Button) findViewById(R.id.prev);
    buttonNext = (Button) findViewById(R.id.next);
    viewSwitcher1 = (ViewSwitcher) findViewById(R.id.viewswitcher1);


    slide_in_left = AnimationUtils.loadAnimation(this,
            android.R.anim.slide_in_left);
    slide_out_right = AnimationUtils.loadAnimation(this,
            android.R.anim.slide_out_right);

    viewSwitcher1.setInAnimation(slide_in_left);
    viewSwitcher1.setOutAnimation(slide_out_right);


    buttonPrev.setOnClickListener(new OnClickListener() {

        @Override
        public void onClick(View arg0) {
            viewSwitcher1.showPrevious();

        }
    });

    buttonNext.setOnClickListener(new OnClickListener() {

        @Override
        public void onClick(View arg0) {
            viewSwitcher1.showNext();

        }
    });
    ;
}

}