SmartRefreshLayout数据不满一页时上滑不完全回弹

1.SmartRefreshLayout+RecyclerView使用。

项目build.gradle引入

//核心必须依赖
implementation 'com.scwang.smart:refresh-layout-kernel:2.0.3'    
//经典刷新头  
implementation 'com.scwang.smart:refresh-header-classics:2.0.3'    
 <com.scwang.smart.refresh.layout.SmartRefreshLayout
            android:id="@+id/swipe_refresh"
            android:layout_width="match_parent"
            android:layout_height="match_parent"
            android:background="@color/color_F2F2F2"
            android:visibility="gone">

            <androidx.recyclerview.widget.RecyclerView
                android:id="@+id/rv_fan"
                android:layout_width="match_parent"
                android:layout_height="wrap_content"
                android:scrollbars="none">             </androidx.recyclerview.widget.RecyclerView>
</com.scwang.smart.refresh.layout.SmartRefreshLayout>

2.基础使用。

//设置头部下拉刷新
swipeRefresh.setRefreshHeader(new ClassicsHeader(this));
//设置脚步上拉加载
swipeRefresh.setRefreshFooter(new ClassicsFooter(this));
//数据不满一页时,禁止上滑(不设置,数据不满一页上滑,不能自动完全回弹,第一个item会被覆盖。)
swipeRefresh.setEnableLoadMoreWhenContentNotFull(false);
//设置加载完成,脚部跟随数据显示,不设置,默认不显示,上滑时显示。
swipeRefresh.setEnableFooterFollowWhenNoMoreData(true);
//下拉刷新监听
swipeRefresh.setOnRefreshListener(new OnRefreshListener() {
    @Override
    public void onRefresh(RefreshLayout refreshlayout) {
        refreshWay = 1;
        currentPage = 1;
        mPresenter.getNormalFan(currentPage);
    }
});
//上拉加载监听
swipeRefresh.setOnLoadMoreListener(new OnLoadMoreListener() {
    @Override
    public void onLoadMore(RefreshLayout refreshlayout) {
        refreshWay = 2;
        currentPage++;
        mPresenter.getNormalFan(currentPage);
    }
});
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
实现这个效果可以使用 `UIScrollView` 的回弹效果。具体实现步骤如下: 1. 创建一个 `UIScrollView`,将其添加到相册的 `UIViewController` 中。 2. 将相册中的所有图片放置在 `UIScrollView` 中,并设置 `UIScrollView` 的 `contentSize` 等于所有图片的总宽度。 3. 启用 `UIScrollView` 的回弹效果,可以通过设置 `UIScrollView` 的 `bounces` 属性为 `YES` 来实现。 4. 监听 `UIScrollView` 的动事件,当动到第一张或最后一张图片时,将 `UIScrollView` 的 `contentOffset` 设置为零或最后一张图片的位置,触发回弹效果。 以下是一段示例代码: ```swift class ViewController: UIViewController, UIScrollViewDelegate { @IBOutlet weak var scrollView: UIScrollView! override func viewDidLoad() { super.viewDidLoad() scrollView.delegate = self scrollView.isPagingEnabled = true scrollView.contentSize = CGSize(width: view.frame.width * 3, height: view.frame.height) scrollView.bounces = true for i in 0..<3 { let imageView = UIImageView(image: UIImage(named: "image\(i+1)")) imageView.frame = CGRect(x: view.frame.width * CGFloat(i), y: 0, width: view.frame.width, height: view.frame.height) imageView.contentMode = .scaleAspectFit scrollView.addSubview(imageView) } } func scrollViewDidEndDecelerating(_ scrollView: UIScrollView) { if scrollView.contentOffset.x == 0 { scrollView.setContentOffset(CGPoint(x: 0, y: 0), animated: true) } else if scrollView.contentOffset.x == view.frame.width * 2 { scrollView.setContentOffset(CGPoint(x: view.frame.width * 2, y: 0), animated: true) } } } ``` 在这个示例中,我们创建了一个包含三张图片的相册,使用 `UIScrollView` 来实现动效果,并通过 `scrollViewDidEndDecelerating` 方法监听动事件,当动到第一张或最后一张图片时,通过设置 `UIScrollView` 的 `contentOffset` 来触发回弹效果。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值