需求
系統(tǒng)默認(rèn)activity跳轉(zhuǎn)動(dòng)畫(huà)交互滿足不了項(xiàng)目需求凑术,需要自定義動(dòng)畫(huà)實(shí)現(xiàn)交互效果碟贾。
實(shí)現(xiàn)方法
Step1 - 自定義動(dòng)畫(huà)效果
在res/anim文件下自定義動(dòng)畫(huà)效果文件
-
open_enter
實(shí)現(xiàn)效果: 縮放從屏幕中間一點(diǎn)到全屏移盆,透明度從0到1
<?xml version="1.0" encoding="utf-8"?>
<set xmlns:android="http://schemas.android.com/apk/res/android"
android:interpolator="@android:anim/decelerate_interpolator">
<scale
android:duration="@android:integer/config_mediumAnimTime"
android:fromXScale="0.0"
android:fromYScale="0.0"
android:pivotX="50%"
android:pivotY="50%"
android:toXScale="1.0"
android:toYScale="1.0"/>
<alpha
android:duration="@android:integer/config_mediumAnimTime"
android:fromAlpha="0.0"
android:toAlpha="1.0"/>
</set>
- **open_exit**
實(shí)現(xiàn)效果: 縮放從整個(gè)屏幕 - 屏幕中間一點(diǎn)悼院,透明度從1到0
<set xmlns:android="http://schemas.android.com/apk/res/android"
android:interpolator="@android:anim/accelerate_interpolator">
<scale
android:duration="@android:integer/config_mediumAnimTime"
android:fromXScale="1.0"
android:fromYScale="1.0"
android:pivotX="50%"
android:pivotY="50%"
android:toXScale="0.0"
android:toYScale="0.0"/>
<alpha
android:duration="@android:integer/config_mediumAnimTime"
android:fromAlpha="1.0"
android:toAlpha="0.0"/>
</set>
-
close_enter
實(shí)現(xiàn)效果: 縮放從1.5倍屏幕 - 整屏幕,透明度從0.5到1
<set xmlns:android="http://schemas.android.com/apk/res/android"
android:interpolator="@android:anim/decelerate_interpolator">
<scale
android:duration="@android:integer/config_mediumAnimTime"
android:fromXScale="1.5"
android:fromYScale="1.5"
android:pivotX="50.0%"
android:pivotY="50.0%"
android:toXScale="1.0"
android:toYScale="1.0"/>
<alpha
android:duration="@android:integer/config_mediumAnimTime"
android:fromAlpha="0.5"
android:toAlpha="1.0"/>
</set>
-
close_exit
實(shí)現(xiàn)效果: 縮放從整屏幕到0.5屏幕味滞,透明度從1到0
<?xml version="1.0" encoding="utf-8"?>
<set xmlns:android="http://schemas.android.com/apk/res/android"
android:interpolator="@android:anim/decelerate_interpolator">
<scale
android:duration="@android:integer/config_mediumAnimTime"
android:fromXScale="1.0"
android:fromYScale="1.0"
android:pivotX="50.0%"
android:pivotY="50.0%"
android:toXScale="0.5"
android:toYScale="0.5"/>
<alpha
android:duration="@android:integer/config_mediumAnimTime"
android:fromAlpha="1.0"
android:toAlpha="0.0"/>
</set>
可以根據(jù)自己的需求修改動(dòng)畫(huà)效果
例如實(shí)現(xiàn) 進(jìn)入頁(yè)面屏幕左滑樱蛤,突出頁(yè)面屏幕右滑
見(jiàn) 附錄1
Step2 - 自定義樣式
在res/values/styles.xml中自定義樣式
<style name="Animation_Activity"
parent="@android:style/Animation.Activity">
<item name="android:activityOpenEnterAnimation">@anim/open_enter</item>
<item name="android:activityOpenExitAnimation">@anim/open_exit</item>
<item name="android:activityCloseEnterAnimation">@anim/close_enter</item>
<item name="android:activityCloseExitAnimation">@anim/close_exit</item>
</style>
<style name="AppTheme_" parent="Theme.AppCompat.Light.DarkActionBar">
<item name="android:windowNoTitle">true</item>
<item name="android:windowAnimationStyle">@style/Animation_Activity
</item>
</style>
-
說(shuō)明:
android:activityOpenEnterAnimation //新的activity創(chuàng)建進(jìn)入效果
android:activityOpenExitAnimation //activity還沒(méi)有finish()下退出效果
android:activityCloseEnterAnimation //上一個(gè)activity返回進(jìn)入效果
android:activityCloseExitAnimation //上一個(gè)activity finish()之后退出效果
這四個(gè)屬性按照順序記憶口訣是“新進(jìn)、舊出剑鞍;舊進(jìn)、新出”爽醋,android studio格式排版的默認(rèn)順序就是這個(gè)順序來(lái)的蚁署。
-
使app中所有界面跳轉(zhuǎn)實(shí)現(xiàn)自定義
在清單文件mainifests.xml中修改application的theme屬性為自定義的樣式
使FirstActivity跳轉(zhuǎn)到SecondActivity實(shí)現(xiàn)自定義
在FirstActivity的startActivity()之后使用overridePendingTransition()方法
//FirstActivity中
startActivity(new Intent(this, SecondActivity.class));
overridePendingTransition(R.anim.open_enter,R.anim.open_exit);
在SecondActivity的finish()方法后使用overridePendingTransition()方法
//SecondActivity
finish();
overridePendingTransition(R.anim.close_enter, R.anim.close_exit);
注意事項(xiàng)
關(guān)于overridePendingTransition()這個(gè)函數(shù)
- 挨著startActivity()或者finish()函數(shù)之后調(diào)用
- 適用 android2.0以及以上版本上
overridePendingTransition 這個(gè)函數(shù)會(huì)不起作用的原因:
- 在ActivityGroup等的嵌入式Activity中,使用
this.getParent().overridePendingTransition()
蚂四。 - 在一個(gè)Activity的內(nèi)部類中光戈,或者匿名類中哪痰,使用handler。
- 手機(jī)的顯示動(dòng)畫(huà)效果被關(guān)閉久妆, 設(shè)置->顯示->顯示動(dòng)畫(huà)效果重新打開(kāi)即可晌杰。
附錄1
open_enter
實(shí)現(xiàn)效果: 向左滑進(jìn)入屏幕
<?xml version="1.0" encoding="utf-8"?>
<set xmlns:android="http://schemas.android.com/apk/res/android"
android:interpolator="@android:anim/decelerate_interpolator">
<!--左滑:進(jìn)入屏幕-->
<translate
android:duration="@android:integer/config_mediumAnimTime"
android:fromXDelta="100%p"
android:toXDelta="0%p"/>
</set>
-
open_exit
實(shí)現(xiàn)效果: 向左滑動(dòng)推出屏幕
<?xml version="1.0" encoding="utf-8"?>
<set xmlns:android="http://schemas.android.com/apk/res/android"
android:interpolator="@android:anim/decelerate_interpolator">
<!--左滑:退出屏幕-->
<translate
android:duration="@android:integer/config_mediumAnimTime"
android:fromXDelta="0%p"
android:toXDelta="-100%p"/>
</set>
-
close_enter
實(shí)現(xiàn)效果: 向右滑動(dòng)進(jìn)入屏幕
<?xml version="1.0" encoding="utf-8"?>
<set xmlns:android="http://schemas.android.com/apk/res/android"
android:interpolator="@android:anim/decelerate_interpolator">
<!--右滑:進(jìn)入屏幕-->
<translate
android:duration="@android:integer/config_mediumAnimTime"
android:fromXDelta="-100%p"
android:toXDelta="0%p"/>
</set>
-
close_exit
實(shí)現(xiàn)效果: 向右滑動(dòng)退出屏幕
<?xml version="1.0" encoding="utf-8"?>
<set xmlns:android="http://schemas.android.com/apk/res/android"
android:interpolator="@android:anim/decelerate_interpolator">
<!--右滑:退出屏幕-->
<translate
android:duration="@android:integer/config_mediumAnimTime"
android:fromXDelta="-0%p"
android:toXDelta="100%p"/>
</set>