如何将整理活动缩小为矩形

时间:2013-03-05 11:40:23

标签: android android-activity android-animation

在我的Android应用中,我有一个浮动Activity。它是从我的应用程序外部开始的,使用ActivityOptions.makeScaleUpAnimation从“原始”矩形向上扩展。当我的Activity完成时,我希望它与该动画相反:即当它淡出时缩小回那个矩形。

我知道我可以使用getIntent().getSourceBounds()获取矩形,我希望能够在完成此功能时使用overridePendingTransition(),但overridePendingTransition()只能接受修复XML资源:似乎没有办法让动画依赖于源边界。我还能用其他东西来达到这个效果吗?

我的应用程序适用于API 11+,但由于它只是一种美容效果,我会对依赖于更高版本的解决方案感到满意。

2 个答案:

答案 0 :(得分:8)

我认为除了overridePendingTransition调用之外,还有一种方法可以缩小活动窗口。但是,此代码可能有所帮助:

向上扩展

ActivityOptions opts = ActivityOptions.makeCustomAnimation(getActivity(),R.anim.scale_up,0); startActivity(new Intent(this,SecondActivity.class),opts.toBundle());

这是scale_up动画文件:

<set  xmlns:android="http://schemas.android.com/apk/res/android">
    <scale
    android:fromXScale="0"
    android:toXScale="1.0"
    android:fromYScale="0"
    android:toYScale="1.0"
    android:pivotX="50%p"
    android:pivotY="50%p"
    android:duration="500"/>
</set>

缩小

从现有活动中调用此代码:

finish();

overridePendingTransition(0, R.anim.scale_down);

这是scale_down动画文件:

<set xmlns:android="http://schemas.android.com/apk/res/android">
   <scale
    android:fromXScale="1.0"
    android:toXScale="0"
    android:fromYScale="1.0"
    android:toYScale="0"
    android:pivotX="50%p"
    android:pivotY="50%p"
    android:duration="250"/>
</set>

您可以改变X和Y比例以获得所需的矩形。希望这会有所帮助。

答案 1 :(得分:3)

根据我的上一条评论,这是我尝试过的解决方案,它的确有效。您可能需要修改以满足您的要求。

在清单中实现具有透明背景且没有标题的活动:

       <activity
        android:name="com.example.backgroundsensor.AnimatedActivity"
        android:theme="@android:style/Theme.Translucent.NoTitleBar"
        android:label="Animated activity" /> 

并让它使用以下布局设置内容视图:

  <FrameLayout xmlns:android="http://schemas.android.com/apk/res/android"
   xmlns:tools="http://schemas.android.com/tools"
   android:id="@+id/container"
   android:layout_width="match_parent"
   android:layout_height="match_parent"
   android:background="@android:color/transparent"
   tools:ignore="MergeRootFrame" >

    <View
         android:id="@+id/visibleAreaView"
        android:layout_width="300dp"
        android:layout_height="300dp"
        android:layout_gravity="center"
        android:background="@android:color/holo_green_dark" />

 </FrameLayout>

您将在屏幕上看到visibleAreaView,因为活动是透明的。您可以在activity()的OnCreate中设置视图的边界。

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

      // set the bounds of the animateView
  }

此外,覆盖完成方法,如下所示:

boolean animateFirst=true;
@Override
public void finish() {
     if(animateFirst)
     {
         animateFirst = false;
         loadAnim();

     }else
     {
         super.finish();
     }
}

 public void loadAnim() {

    View v = findViewById(R.id.animateView);
    float x= v.getX() + v.getRight()/2;
    float y = v.getY();
    anim = new ScaleAnimation(1.0f, 0.0f,1.0f, 0.0f, x, y);
    anim.setDuration(300);
    anim.setAnimationListener(new AnimationListener() {

        @Override
        public void onAnimationStart(Animation animation) {
            // TODO Auto-generated method stub

        }

        @Override
        public void onAnimationRepeat(Animation animation) {
            // TODO Auto-generated method stub

        }

        @Override
        public void onAnimationEnd(Animation animation) {
            findViewById(R.id.animateView).setVisibility(View.GONE);
            AnimatedActivity.this.finish();
        }
    });
    v.startAnimation(anim);

}