RecycleView 有下拉刷新情况下实现悬浮框效果

简介

1.当需求需要下拉刷新时,在Activity布局中添加一个和adapter布局一样的悬浮框布局,在代码中显示隐藏控制;

2.当需求没有下拉刷新时,就简单了,直接在adapter布局中定义一个悬浮框布局就可以了;


效果图


代码如下:

private int mSuspensionHeight;

private int mCurrentPosition = 0;

tvHeader:Activity布局中的tv;

mSuspensionBar: activity 布局中的悬浮框Layout;


recyclerView.addOnScrollListener(new RecyclerViewListener());



class RecyclerViewListener extends RecyclerView.OnScrollListener{
        @Override
        public void onScrollStateChanged(RecyclerView recyclerView, int newState) {
            super.onScrollStateChanged(recyclerView, newState);
            mSuspensionHeight = mSuspensionBar.getHeight();
        }


        @Override
        public void onScrolled(RecyclerView recyclerView, int dx, int dy) {
            super.onScrolled(recyclerView, dx, dy);
            View viewPosition = mLinearLayoutManager.findViewByPosition(mCurrentPosition);

/**

  *处理position为0的情况

          */
            if (viewPosition != null) {
                if (viewPosition.getTop() == 0 && mLinearLayoutManager.findFirstVisibleItemPosition() == 1
                        || dy == 0 && mLinearLayoutManager.findFirstVisibleItemPosition() == 0) {
                    tvHeader.setVisibility(View.GONE);
                    return;
                }
            }


            tvHeader.setVisibility(View.VISIBLE);

                    if (显示悬浮框布局的判断条件) {
                        View view = mLinearLayoutManager.findViewByPosition(mCurrentPosition + 1);
                        if (view != null) {
                            if (view.getTop() <= mSuspensionHeight) {
                                mSuspensionBar.setY(-(mSuspensionHeight - view.getTop()));
                            } else {
                                mSuspensionBar.setY(0);
                            }
                        }
                    }
               


                if (mCurrentPosition != mLinearLayoutManager.findFirstVisibleItemPosition()) {
                    mCurrentPosition = mLinearLayoutManager.findFirstVisibleItemPosition();
                    mSuspensionBar.setY(0);


                    tvHeader.setText(”赋值“);


                }
        }
    }

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值