Android下拉刷新终极指南:Ultra-Pull-To-Refresh源码解析与最佳实践

Android下拉刷新终极指南:Ultra-Pull-To-Refresh源码解析与最佳实践

【免费下载链接】android-Ultra-Pull-To-Refresh Ultra Pull to Refresh for Android. Support all the views. 【免费下载链接】android-Ultra-Pull-To-Refresh 项目地址: https://gitcode.com/gh_mirrors/an/android-Ultra-Pull-To-Refresh

Ultra Pull to Refresh是一款功能强大的Android下拉刷新库,支持所有类型的视图组件,为开发者提供了灵活且易于定制的下拉刷新解决方案。作为已停止维护的下拉刷新项目的替代方案,它继承于ViewGroup,可以包含任何View,功能比SwipeRefreshLayout更加强大,使用简单且设计优良,定制UI样式就像给ListView添加Header View一样简单,支持API LEVEL >= 8。

为什么选择Ultra-Pull-To-Refresh?

Ultra-Pull-To-Refresh之所以能成为众多Android开发者的首选下拉刷新库,源于其出色的特性和优势。它不仅支持所有View,如ListView、GridView、ScrollView、FrameLayout,甚至TextView,还支持各种下拉刷新交互方式,满足不同应用场景的需求。

Android Ultra-Pull-To-Refresh支持的视图展示

多样化的交互方式

  • 下拉刷新(iOS风格):提供类似iOS系统的下拉刷新体验,下拉到一定程度后释放即可触发刷新。
  • 释放刷新(经典风格):下拉到指定位置后,需要释放才能触发刷新操作。
  • 刷新时头部保持(新浪微博风格):刷新过程中,头部会一直保持显示状态。
  • 刷新时头部不保持(微信朋友圈风格):刷新完成后,头部会自动隐藏。
  • 自动刷新:进入界面时自动触发刷新操作,无需用户手动下拉。

高度可定制性

开发者可以根据自己的需求,轻松定制下拉刷新的UI样式和交互行为。无论是修改头部的布局、颜色,还是调整刷新的动画效果,都能通过简单的配置实现。

快速集成Ultra-Pull-To-Refresh

集成Ultra-Pull-To-Refresh到你的Android项目中非常简单,只需按照以下步骤操作即可。

中央库依赖

项目已经发布到了Maven中央库,包括aarapklib两种格式。在Maven或者Gradle下可直接引入。

最新版版本号: 1.0.11,发布到了:https://oss.sonatype.org/content/repositories/snapshots

在gradle中添加仓库:

maven {
    url 'https://oss.sonatype.org/content/repositories/snapshots'
}

稳定版可使用Maven中央库:

mavenCentral()

pom.xml文件中添加依赖(最新版):

<dependency>
    <groupId>in.srain.cube</groupId>
    <artifactId>ultra-ptr</artifactId>
    <type>aar</type>
    <!-- or apklib format, if you want -->
    <!-- <type>apklib</type> -->
    <version>1.0.11</version>
</dependency>

在gradle / Android Studio中添加依赖(最新版):

compile 'in.srain.cube:ultra-ptr:1.0.11'

配置参数详解

Ultra-Pull-To-Refresh提供了6个可配置的参数,通过这些参数可以调整下拉刷新的行为和效果:

  • 阻尼系数:默认值为1.7f,阻尼系数越大,下拉时感觉越吃力。
  • 触发刷新时移动的位置比例:默认值为1.2f,当移动距离达到头部高度的1.2倍时可触发刷新操作。
  • 回弹延时:默认值为200ms,是回弹到刷新高度所用的时间。
  • 头部回弹时间:默认值为1000ms
  • 刷新时保持头部:默认值为true
  • 下拉刷新/释放刷新:默认为释放刷新。

XML中配置示例

<in.srain.cube.views.ptr.PtrFrameLayout
    android:id="@+id/store_house_ptr_frame"
    xmlns:cube_ptr="http://schemas.android.com/apk/res-auto"
    android:layout_width="match_parent"
    android:layout_height="match_parent"

    cube_ptr:ptr_resistance="1.7"
    cube_ptr:ptr_ratio_of_header_height_to_refresh="1.2"
    cube_ptr:ptr_duration_to_close="300"
    cube_ptr:ptr_duration_to_close_header="2000"
    cube_ptr:ptr_keep_header_when_refresh="true"
    cube_ptr:ptr_pull_to_fresh="false" >

    <LinearLayout
        android:id="@+id/store_house_ptr_image_content"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:background="@color/cube_mints_333333"
        android:clickable="true"
        android:padding="10dp">

        <in.srain.cube.image.CubeImageView
            android:id="@+id/store_house_ptr_image"
            android:layout_width="match_parent"
            android:layout_height="match_parent" />
    </LinearLayout>

</in.srain.cube.views.ptr.PtrFrameLayout>

Java代码中配置

// the following are default settings
mPtrFrame.setResistance(1.7f);
mPtrFrame.setRatioOfHeaderHeightToRefresh(1.2f);
mPtrFrame.setDurationToClose(200);
mPtrFrame.setDurationToCloseHeader(1000);
// default is false
mPtrFrame.setPullToRefresh(false);
// default is true
mPtrFrame.setKeepHeaderWhenRefresh(true);

特色风格展示

Ultra-Pull-To-Refresh提供了多种特色风格,让你的下拉刷新界面更加个性化。

StoreHouse风格

StoreHouse风格支持使用字符串(A-Z, 0-7以及 - .)或资源文件中的路径信息来定义头部样式。

使用字符串示例:

// header
final StoreHouseHeader header = new StoreHouseHeader(getContext());
header.setPadding(0, LocalDisplay.dp2px(15), 0, 0);

/**
 * using a string, support: A-Z 0-9 - .
 * you can add more letters by {@link in.srain.cube.views.ptr.header.StoreHousePath#addChar}
 */
header.initWithString('Alibaba');

使用资源文件中的路径信息示例:

header.initWithStringArray(R.array.storehouse);

资源文件 res/values/arrays.xml 内容如下:

<resources>
    <string-array name="storehouse">
        <item>0,35,12,42,</item>
        <item>12,42,24,35,</item>
        <item>24,35,12,28,</item>
        <item>0,35,12,28,</item>
        <item>0,21,12,28,</item>
        <item>12,28,24,21,</item>
        <item>24,35,24,21,</item>
        <item>24,21,12,14,</item>
        <item>0,21,12,14,</item>
        <item>0,21,0,7,</item>
        <item>12,14,0,7,</item>
        <item>12,14,24,7,</item>
        <item>24,7,12,0,</item>
        <item>0,7,12,0,</item>
    </string-array>
</resources>

Material风格

5.0 Material风格具有独特的阴影效果,为下拉刷新增添了现代感。

Android Ultra-Pull-To-Refresh的Material风格展示

处理刷新逻辑

通过PtrHandler,可以检查确定是否可以下拉刷新以及在合适的时间刷新数据。

public interface PtrHandler {

    /**
     * 检查是否可以执行下来刷新,比如列表为空或者列表第一项在最上面时。
     * <p/>
     * {@link in.srain.cube.views.ptr.PtrDefaultHandler#checkContentCanBePulledDown}
     */
    public boolean checkCanDoRefresh(final PtrFrameLayout frame, final View content, final View header);

    /**
     * 需要加载数据时触发
     *
     * @param frame
     */
    public void onRefreshBegin(final PtrFrameLayout frame);
}

例子:

ptrFrame.setPtrHandler(new PtrHandler() {
    @Override
    public void onRefreshBegin(PtrFrameLayout frame) {
        frame.postDelayed(new Runnable() {
            @Override
            public void run() {
                ptrFrame.refreshComplete();
            }
        }, 1800);
    }

    @Override
    public boolean checkCanDoRefresh(PtrFrameLayout frame, View content, View header) {
        // 默认实现,根据实际情况做改动
        return PtrDefaultHandler.checkContentCanBePulledDown(frame, content, header);
    }
});

常见问题解决

ViewPager滑动冲突

可以使用disableWhenHorizontalMove()方法来解决与ViewPager的滑动冲突。

长按LongPressed

通过setInterceptEventWhileWorking()方法可以处理长按事件。

总结

Ultra-Pull-To-Refresh作为一款强大的Android下拉刷新库,凭借其丰富的功能、高度的可定制性和简单的集成方式,成为了Android开发者实现下拉刷新功能的理想选择。无论是新手还是有经验的开发者,都能快速上手并将其应用到自己的项目中,为用户带来更加流畅和友好的下拉刷新体验。

要开始使用Ultra-Pull-To-Refresh,你可以通过以下命令clone仓库: git clone https://gitcode.com/gh_mirrors/an/android-Ultra-Pull-To-Refresh

【免费下载链接】android-Ultra-Pull-To-Refresh Ultra Pull to Refresh for Android. Support all the views. 【免费下载链接】android-Ultra-Pull-To-Refresh 项目地址: https://gitcode.com/gh_mirrors/an/android-Ultra-Pull-To-Refresh

创作声明:本文部分内容由AI辅助生成(AIGC),仅供参考

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值