乐闻世界logo
搜索文章和话题

How to replace SwipeRefreshLayout loading animation with a Lottie animation

5 个月前提问
5 个月前修改
浏览次数7

1个答案

1

在使用Lottie动画替换SwipeRefreshLayout的加载动画过程中,主要步骤可以分为以下几个部分:

1. 添加依赖

首先,确保在项目的build.gradle文件中添加了Lottie的依赖:

gradle
dependencies { implementation 'com.airbnb.android:lottie:3.4.0' }

2. 移除原有的SwipeRefreshLayout

在布局文件中,删除或隐藏现有的SwipeRefreshLayout,因为我们将使用LottieAnimationView来创建自定义的下拉刷新动画。

3. 添加LottieAnimationView

在相同的布局文件中,添加一个LottieAnimationView,用于显示动画:

xml
<com.airbnb.lottie.LottieAnimationView android:id="@+id/lottieAnimationView" android:layout_width="wrap_content" android:layout_height="wrap_content" app:lottie_rawRes="@raw/loading_animation" // 这里替换成你的动画文件 app:lottie_autoPlay="false" app:lottie_loop="true" android:visibility="gone" />

4. 控制动画显示

接下来,在你的Activity或Fragment中,你需要控制这个LottieAnimationView的显示,以及动画的播放和停止:

java
LottieAnimationView lottieAnimationView = findViewById(R.id.lottieAnimationView); // 显示和隐藏动画 public void showLoadingAnimation() { lottieAnimationView.setVisibility(View.VISIBLE); lottieAnimationView.playAnimation(); } public void hideLoadingAnimation() { lottieAnimationView.cancelAnimation(); lottieAnimationView.setVisibility(View.GONE); }

5. 监听滑动事件

你需要自己实现滑动监听,当用户下拉时触发动画。这可以通过在父布局中添加如OnTouchListener来实现。

java
yourParentLayout.setOnTouchListener(new View.OnTouchListener() { @Override public boolean onTouch(View v, MotionEvent event) { switch (event.getAction()) { case MotionEvent.ACTION_DOWN: // 记录初次按下的位置 break; case MotionEvent.ACTION_MOVE: // 计算滑动距离,根据距离显示动画 if (isPullDown(event)) { lottieAnimationView.setProgress(calculateProgress(event)); } break; case MotionEvent.ACTION_UP: case MotionEvent.ACTION_CANCEL: // 手指放开后处理事件,如开始网络请求 if (shouldRefresh(event)) { showLoadingAnimation(); fetchData(); // fetchData() 是你的数据加载方法 } else { resetAnimation(); } break; } return true; } });

6. 进行网络请求并在完成后停止动画

网络请求完成后,调用hideLoadingAnimation()停止并隐藏动画。

java
public void fetchData() { // 执行网络请求... // 请求完成后 hideLoadingAnimation(); }

总结

通过上面的步骤,你可以用Lottie动画库替换传统的SwipeRefreshLayout加载动画,实现更丰富和流畅的用户体验。这种方法不仅可以使加载动画更加美观,还可以提供更多自定义的可能性,使得应用界面与众不同。

2024年8月23日 23:19 回复

你的答案