activity跳轉時從上到下,退出時從下到上

需求:A activity 點擊跳轉B  activity時B要從上到下出來,B 退出時從下到上消失

首先寫兩個動畫文件:

這個是從上到下的動畫

<?xml version="1.0" encoding="utf-8"?>
<translate xmlns:android="http://schemas.android.com/apk/res/android"
    android:interpolator="@android:anim/accelerate_interpolator"
    android:fromYDelta="-100%p"
    android:toYDelta="0%p"
    android:duration="500">
</translate> 
這個是從下到上的動畫

<?xml version="1.0" encoding="utf-8"?>
<translate xmlns:android="http://schemas.android.com/apk/res/android"
    android:interpolator="@android:anim/accelerate_interpolator"
    android:fromYDelta="0%p"
    android:toYDelta="-100%p"
    android:duration="500">
</translate> 


跳轉時的操作

Intent intent = new Intent();
intent.setClass(A.this,B.class);
startActivityForResult(intent, Constants.SCENIC_REQUEST_CODE);
overridePendingTransition(R.anim.activity_anim_scenic_in, R.anim.activity_anim_scenic_out);

重點在於最後一句
overridePendingTransition(R.anim.activity_anim_scenic_in, R.anim.activity_anim_scenic_out);
這個是動畫展示,一定要放在start之後。

一定要記得在B Activity重寫finish方法

@Override
public void finish() {
   super.finish();
   overridePendingTransition(R.anim.activity_anim_scenic_in, R.anim.activity_anim_scenic_out);
}
在manifests文件中Bactivity引用一個styles

 <style name="anim_scenicchoose">
        <item name="android:windowNoTitle">true</item>
        <item name="android:windowIsTranslucent">true</item>
        <item name="android:windowBackground">@android:color/transparent</item>
  </style>
styles看需求需要自己改動的。




發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章