類似列表的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);
相關文章
- iOS動畫系列之七:實現類似Twitter的啟動動畫iOS動畫
- 可伸縮聚類演算法綜述(可伸縮聚類演算法開篇)聚類演算法
- View動畫、幀動畫View動畫
- swift 類似高德地圖和58同城上下滑動viewSwift地圖View
- 支援自動伸縮的消費者模式模式
- RN自定義元件封裝 - 播放類似PPT動畫元件封裝動畫
- k8s 自動伸縮 pod(HPA)K8S
- Android 動畫詳解:屬性動畫、View 動畫和幀動畫Android動畫View
- Node.js的可伸縮性Node.js
- Android備忘錄《View動畫(補間動畫)》AndroidView動畫
- k8s HPA(HorizontalPodAutoscaler)--自動水平伸縮K8S
- Qt實現遮罩效果並可以拖動伸縮QT遮罩
- HikariPool原始碼(三)資源池動態伸縮原始碼
- Serverless:基於個性化服務畫像的彈性伸縮實踐Server
- Redis 叢集伸縮原理Redis
- CSS-伸縮佈局CSS
- 【JavaScript框架封裝】實現一個類似於JQuery的動畫框架的封裝JavaScript框架封裝jQuery動畫
- 線上直播系統原始碼,使用ValueAnimator實現view放大縮小動畫效果原始碼View動畫
- CSS3 伸縮佈局CSSS3
- 直播系統中網頁類似app頁面切換動畫的實現方式網頁APP動畫
- 讓View具有減速效果的動畫——FlingAnimationView動畫
- 讓View具有彈性效果的動畫——SpringAnimationView動畫Spring
- Android自定義View播放Gif動畫AndroidView動畫
- Android 自定義View之下雨動畫AndroidView動畫
- powerpoint:縮放定位動畫動畫
- 基於Kubernetes的hpa實現pod例項數量的自動伸縮
- Knative Autoscaler 自定義彈性伸縮
- redis自學(37)叢集伸縮Redis
- 彈性佈局(伸縮佈局)
- Kubernetes彈性伸縮全場景解讀(五) - 定時伸縮元件釋出與開源元件
- [Swift]SpriteKit實現類似畫素鳥的小遊戲 - Crashy PlaneSwift遊戲
- 在微服務領域Spring Boot自動伸縮如何實現微服務Spring Boot
- Android 自定義View:屬性動畫(六)AndroidView動畫
- AutoScaling彈性伸縮配置重大升級
- 通過一個實際例子理解Kubernetes裡pod的自動scale - 水平自動伸縮
- RemoteBrowser:類似Puppeteer的瀏覽器自動化框架REM瀏覽器框架
- [提問交流]介面佈局如何設定為固定,不自動伸縮!
- jQuery實現的表格展開伸縮效果例項jQuery
- 可伸縮的微服務告警系統設計指南微服務