Android實現透明動畫
本文實例為大家分享了Android實現透明動畫的具體代碼,供大家參考,具體內容如下
首頁是有一個 Activity
public class AlphaAnimationActivity extends AppCompatActivity { private ImageView mImageView; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_frame_animation); //只是一張普通的圖片 mImageView = findViewById(R.id.imageview); ... 這是若干個按鈕 用來啟動動畫 }1 補間動畫方式
1.1 xml 方式
目錄文件夾 res/anim/alpha.xml
<?xml version='1.0' encoding='utf-8'?><set xmlns:android='http://schemas.android.com/apk/res/android'> <alphaandroid:duration='3000'android:fromAlpha='0.0'android:toAlpha='1.0'> </alpha></set>
然后在 Java 代碼中使用如下:
//補間動畫方式 - xmlpublic void start1() { //加載動畫xml Animation lAnimation = AnimationUtils.loadAnimation(this, R.anim.alpha); //設置并開啟動畫 mImageView.startAnimation(lAnimation); }
1.2 java 代碼方式
//補間動畫方式 - javaprivate void start2() { //創建透明動畫 Animation lAnimation = new AlphaAnimation(0.0f, 1.0f); //設置動畫時間 lAnimation.setDuration(3000); //設置動畫 mImageView.startAnimation(lAnimation);}2 屬性動畫方式
1.1 ValueAnimator xml 方式
目錄文件夾 res/animator/alpha_animator.xml
<animator xmlns:android='http://schemas.android.com/apk/res/android' android:valueFrom='0' android:valueTo='255' android:duration='2000' android:valueType='intType'/>
然后代碼中
//屬性動畫方式 - ValueAnimator - xmlpublic void start3() { // 載入XML動畫 ValueAnimator animator = (ValueAnimator) AnimatorInflater.loadAnimator(this, R.animator.alpha_animator); animator.addUpdateListener(new ValueAnimator.AnimatorUpdateListener() { @Override public void onAnimationUpdate(ValueAnimator animation) { int currentValue = (int) animation.getAnimatedValue(); Log.d('屬性動畫', 'onAnimationUpdate: ' + animation.getAnimatedValue()); // 將改變后的值賦給對象的屬性值,下面會詳細說明 mImageView.setImageAlpha(currentValue); //刷新視圖,即重新繪制,從而實現動畫效果 mImageView.requestLayout(); } }); // 啟動動畫 animator.start();}
1.2 ValueAnimator java 代碼方式
//屬性動畫方式 - ValueAnimator - javapublic void start4() { // 第一步:設置動畫屬性的初始值 & 結束值 // ofInt()作用有兩個 // 1. 創建動畫實例 // 2. 將傳入的多個Int參數進行平滑過渡:此處傳入0和1,表示將值從0平滑過渡到 255 // 如果傳入了3個Int參數 a,b,c ,則是先從a平滑過渡到b,再從b平滑過渡到 c,以此類推 ValueAnimator anim = ValueAnimator.ofInt(0, 255); // 設置動畫運行的時長 anim.setDuration(500); // 設置動畫延遲播放時間 anim.setStartDelay(500); // 設置動畫重復播放次數 = 重放次數+1 // 動畫播放次數 = infinite時,動畫無限重復 anim.setRepeatCount(0); // 設置重復播放動畫模式 // ValueAnimator.RESTART(默認):正序重放 // ValueAnimator.REVERSE:倒序回放 anim.setRepeatMode(ValueAnimator.RESTART); // 第二步:將改變的值手動賦值給對象的屬性值:通過動畫的更新監聽器 // 設置 值的更新監聽器 // 即:值每次改變、變化一次,該方法就會被調用一次 anim.addUpdateListener(new ValueAnimator.AnimatorUpdateListener() { @Override public void onAnimationUpdate(ValueAnimator animation) { int currentValue = (Integer) animation.getAnimatedValue(); // 獲得改變后的值 System.out.println(currentValue); // 輸出改變后的值 // 步驟4:將改變后的值賦給對象的屬性值,下面會詳細說明 mImageView.setImageAlpha(currentValue); // 步驟5:刷新視圖,即重新繪制,從而實現動畫效果 mImageView.requestLayout(); } }); //第三步 啟動動畫 anim.start(); // 啟動動畫 // ValueAnimator 類是先改變值,然后 手動賦值 給對象的屬性從而實現動畫;是 間接 對對象屬性進行操作 // ValueAnimator 類本質上是一種 改變 值 的操作機制}
1.3 ObjectAnimator xml 方式
目錄文件夾 animator/alpha_object_animator.xml
<objectAnimator xmlns:android='http://schemas.android.com/apk/res/android' android:propertyName='alpha' android:valueFrom='1' android:valueTo='0' android:duration='2000' android:valueType='floatType' ></objectAnimator>
//屬性動畫方式 - ObjectAnimator - xmlpublic void start5() { // 載入XML動畫 Animator animator = AnimatorInflater.loadAnimator(this, R.animator.alpha_object_animator); // 設置動畫對象 animator.setTarget(mImageView); // 啟動動畫 animator.start(); Log.d('動畫','ObjectAnimator - xml'); }
1.4 ObjectAnimator java 代碼方式
//屬性動畫方式 - ObjectAnimator - javapublic void start6() { ObjectAnimator anim = ObjectAnimator.ofFloat(mImageView, 'alpha', 1f, 0f, 1f); // 表示的是: // 動畫作用對象是mButton // 動畫作用的對象的屬性是透明度alpha // 動畫效果是:常規 - 全透明 - 常規 // ofFloat()作用有兩個 anim.setDuration(500); // 設置動畫運行的時長 anim.setStartDelay(500); // 設置動畫延遲播放時間 anim.setRepeatCount(0); // 設置動畫重復播放次數 = 重放次數+1 // 動畫播放次數 = infinite時,動畫無限重復 anim.setRepeatMode(ValueAnimator.RESTART); // 設置重復播放動畫模式 // ValueAnimator.RESTART(默認):正序重放 // ValueAnimator.REVERSE:倒序回放 anim.start(); }
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持好吧啦網。
相關文章:
