詳談Android動畫效果translate、scale、alpha、rotate
動畫類型
Android的animation由四種類型組成
XML中
| alpha | 漸變透明度動畫效果 |
| scale | 漸變尺寸伸縮動畫效果 |
| translate | 畫面轉(zhuǎn)換位置移動動畫效果 |
| rotate | 畫面轉(zhuǎn)移旋轉(zhuǎn)動畫效果 |
JavaCode中
| AlphaAnimation | 漸變透明度動畫效果 |
| ScaleAnimation | 漸變尺寸伸縮動畫效果 |
| TranslateAnimation | 畫面轉(zhuǎn)換位置移動動畫效果 |
| RotateAnimation | 畫面轉(zhuǎn)移旋轉(zhuǎn)動畫效果 |
Android動畫模式
Animation主要有兩種動畫模式:
一種是tweened animation(漸變動畫)
| XML中 | JavaCode |
| alpha | AlphaAnimation |
| scale | ScaleAnimation |
一種是frame by frame(畫面轉(zhuǎn)換動畫)
| XML中 | JavaCode |
| translate | TranslateAnimation |
| rotate | RotateAnimation |
Android動畫解析
alpha xml 淡出效果
<?xml version="1.0" encoding="utf-8"?> <set xmlns:android="http://schemas.android.com/apk/res/android"> <alpha android:fromAlpha="1.0" android:toAlpha="0.0" android:duration="500" /> </set> <!-- fromAlpha:開始時透明度 toAlpha: 結(jié)束時透明度 duration:動畫持續(xù)時間 -->
alpha xml 淡入效果
<?xml version="1.0" encoding="utf-8"?> <set xmlns:android="http://schemas.android.com/apk/res/android"> <alpha android:fromAlpha="0.0" android:toAlpha="1.0" android:duration="500" /> </set> <!-- fromAlpha:開始時透明度 toAlpha: 結(jié)束時透明度 duration:動畫持續(xù)時間 -->
rotate.xml 旋轉(zhuǎn)效果:
<?xml version="1.0" encoding="utf-8"?> <set xmlns:android="http://schemas.android.com/apk/res/android"> <rotate android:interpolator="@android:anim/accelerate_decelerate_interpolator" android:fromDegrees="300" android:toDegrees="-360" android:pivotX="10%" android:pivotY="100%" android:duration="10000" /> </set> <!-- fromDegrees 動畫開始時的角度 toDegrees 動畫結(jié)束時物件的旋轉(zhuǎn)角度,正代表順時針 pivotX 屬性為動畫相對于物件的X坐標(biāo)的開始位置 pivotY 屬性為動畫相對于物件的Y坐標(biāo)的開始位置 -->
scale.xml 縮放效果:
<?xml version="1.0" encoding="utf-8"?>
<set xmlns:android="http://schemas.android.com/apk/res/android">
<scale
android:interpolator= "@android:anim/decelerate_interpolator"
android:fromXScale="0.0"
android:toXScale="1.5"
android:fromYScale="0.0"
android:toYScale="1.5"
android:pivotX="50%"
android:pivotY="50%"
android:startOffset="0"
android:duration="10000"
android:repeatCount="1"
android:repeatMode="reverse" />
</set>
<!--
fromXDelta,fromYDelta 起始時X,Y座標(biāo),屏幕右下角的座標(biāo)是X:320,Y:480
toXDelta, toYDelta 動畫結(jié)束時X,Y的座標(biāo) --> <!--
interpolator 指定動畫插入器
常見的有加速減速插入器 accelerate_decelerate_interpolator
加速插入器 accelerate_interpolator,
減速插入器 decelerate_interpolator。
fromXScale,fromYScale, 動畫開始前X,Y的縮放,0.0為不顯示, 1.0為正常大小
toXScale,toYScale, 動畫最終縮放的倍數(shù), 1.0為正常大小,大于1.0放大
pivotX, pivotY 動畫起始位置,相對于屏幕的百分比,兩個都為50%表示動畫從屏幕中間開始
startOffset, 動畫多次執(zhí)行的間隔時間,如果只執(zhí)行一次,執(zhí)行前會暫停這段時間,
單位毫秒 duration,一次動畫效果消耗的時間,單位毫秒,
值越小動畫速度越快 repeatCount,動畫重復(fù)的計數(shù),動畫將會執(zhí)行該值+1次
repeatMode,動畫重復(fù)的模式,reverse為反向,當(dāng)?shù)谂即螆?zhí)行時,動畫方向會相反。
restart為重新執(zhí)行,方向不變 -->
translate.xml 移動效果:
<?xml version="1.0" encoding="utf-8"?> <set xmlns:android="http://schemas.android.com/apk/res/android"> <translate android:fromXDelta="320" android:toXDelta="0" android:fromYDelta="480" android:toYDelta="0" android:duration="10000" /> </set> <!-- fromXDelta,fromYDelta 起始時X,Y座標(biāo),屏幕右下角的座標(biāo)是X:320,Y:480 toXDelta, toYDelta 動畫結(jié)束時X,Y的座標(biāo) -->
以上這篇詳談Android動畫效果translate、scale、alpha、rotate就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
Android漲姿勢知識點之你沒用過的BadgeDrawable
現(xiàn)在Android中有許多的應(yīng)用仿蘋果的在應(yīng)用圖標(biāo)上顯示小紅點,下面這篇文章主要給大家介紹了關(guān)于Android漲姿勢知識點之你沒用過的BadgeDrawable的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),需要的朋友可以參考下2022-09-09
Android RecycleView滑動停止后自動吸附效果的實現(xiàn)代碼(滑動定位)
這篇文章主要介紹了Android RecycleView滑動停止后自動吸附效果的實現(xiàn)代碼(滑動定位),本文通過實例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-10-10
Android使用Walle實現(xiàn)多渠道打包功能的實現(xiàn)示例
這篇文章主要介紹了Android使用Walle實現(xiàn)多渠道打包功能的實現(xiàn)示例,幫助大家更好的理解和學(xué)習(xí)使用Android開發(fā),感興趣的朋友可以了解下2021-04-04
Android 滑動返回Activity的實現(xiàn)代碼
這篇文章主要介紹了Android 滑動返回Activity的實現(xiàn)代碼的相關(guān)資料,這里是訪微信滑動返回主頁的功能,需要的朋友可以參考下2017-07-07
利用Android中的TextView實現(xiàn)逐字顯示動畫
在安卓程序啟動的時候,想逐字顯示一段話,每個字都有一個從透明到不透明的漸變動畫。那如何顯示這個效果,下面一起來看看。2016-08-08

