類似列表的view伸縮動畫
!!! 尼瑪轉成gif這麼卡 真實效果很流暢
1,寫出所要實現的動畫效果
private void doAnim(MyLin view, int i, final boolean v) {
// 運用PropertyValuesHolder 完成組合動畫
PropertyValuesHolder valuesHolder;
PropertyValuesHolder valuesHolder3;
ObjectAnimator objectAnimator;
// translationY : 縱向移動
// alpha : 透明度
if (v){ // 隱藏
valuesHolder = PropertyValuesHolder.ofFloat("translationY", 0.0f, -(view.getHeight())*i); // 這裡 *i 是因為每個控制元件向上移動的距離都不一樣
valuesHolder3 = PropertyValuesHolder.ofFloat("alpha", 1.0f, 0);
objectAnimator = ObjectAnimator.ofPropertyValuesHolder(view, valuesHolder,valuesHolder3);
}else{ // 顯示
valuesHolder = PropertyValuesHolder.ofFloat("translationY",-(view.getHeight())*i ,0.0f );
valuesHolder3 = PropertyValuesHolder.ofFloat("alpha",0f , 1.0f);
objectAnimator = ObjectAnimator.ofPropertyValuesHolder(view, valuesHolder,valuesHolder3);
}
objectAnimator.setDuration(500).start(); // 動畫執行時間 300 毫秒
}
objectAnimator.addListener(new AnimatorListenerAdapter() {
@Override
public void onAnimationEnd(Animator animation) {
if (v)
imageView.setVisibility(View.GONE); // 當收縮動畫完成時,隱藏所有view
}
});
2, 啟動動畫
@OnClick(R.id.image1)
public void onClick() {
for (int i = 0; i < myLins.size(); i++) {
if (v){ // v 是否已經隱藏和顯示標記
doAnim(myLins.get(i),i+1,v); //ViewGroup 中的每個view 都單獨執行一遍動畫
if ((myLins.size()-1) == i)
v = false;
}else {
myLins.get(i).setVisibility(View.VISIBLE); // 在開始動畫之前顯示出所有view
doAnim(myLins.get(i),i+1,v);
if ((myLins.size()-1) == i)
v = true;
}
}
}
3,因為佈局容器中新增android:animateLayoutChanges=”true”的屬性,當ViewGroup控制元件裡有View VISIBLE或GONE 時啟動預設動畫效果,所以當手動 setVisibility(View.VISIBLE/GONE ) 時會出現動畫重複的現象,
因此,將子控制元件顯現和消失的動畫置空,其他動畫不改變.
//初始化容器動畫
mTransitioner = new LayoutTransition();
ll.setLayoutTransition(mTransitioner); // ll 為ViewGroup
// view出現時 view自身的動畫效果置空
mTransitioner.setAnimator(LayoutTransition.APPEARING, null);
// view消失時 view自身的動畫效果置空
mTransitioner.setAnimator(LayoutTransition.DISAPPEARING, null);
相關文章
- 自定義view之可伸縮的圓弧與扇形View
- 可伸縮聚類演算法綜述(可伸縮聚類演算法開篇)聚類演算法
- 水平伸縮動畫導航選單實現詳解動畫
- iOS動畫系列之七:實現類似Twitter的啟動動畫iOS動畫
- View動畫、幀動畫View動畫
- 兩步實現類似格瓦拉的轉場動畫動畫
- RN自定義元件封裝 - 播放類似PPT動畫元件封裝動畫
- Node.js的可伸縮性Node.js
- CSS-伸縮佈局CSS
- Redis 叢集伸縮原理Redis
- jQuery 伸縮搜尋框jQuery
- swift 類似高德地圖和58同城上下滑動viewSwift地圖View
- CSS3 伸縮佈局CSSS3
- redis自學(37)叢集伸縮Redis
- 支援自動伸縮的消費者模式模式
- 網站架構的伸縮性設計網站架構
- JVM效能優化,提高Java的伸縮性JVM優化Java
- 彈性佈局(伸縮佈局)
- 【JavaScript框架封裝】實現一個類似於JQuery的動畫框架的封裝JavaScript框架封裝jQuery動畫
- Blitz4j - 可伸縮的日誌框架框架
- android 動畫 ——檢視動畫(View Animation)Android動畫View
- iOS 雙波浪動畫 – 類似淘寶個人資訊狀態列,京東金融等iOS動畫
- 線上直播系統原始碼,使用ValueAnimator實現view放大縮小動畫效果原始碼View動畫
- Twitter如何使用Redis提高可伸縮性Redis
- 直播系統中網頁類似app頁面切換動畫的實現方式網頁APP動畫
- Android 動畫詳解:屬性動畫、View 動畫和幀動畫Android動畫View
- Kubernetes彈性伸縮全場景解讀(五) - 定時伸縮元件釋出與開源元件
- 可伸縮的微服務告警系統設計指南微服務
- 簡析Uber的可伸縮監控:uMonitor和Neris
- jQuery實現的表格展開伸縮效果例項jQuery
- js頂部可以伸縮的導航選單效果JS
- 伸縮自如的時光軸實現——改進版
- IE CSS Bug系列:不正確的浮動伸縮BugCSS
- 構建高效且可伸縮的結果快取快取
- 可伸縮NoSQL資料庫的五條建議SQL資料庫
- 類似gitbook的wiki選擇Git
- mysql類似merge的操作MySql
- CSS 可伸縮圓角導航選單CSS