原理:用一个和title布局一样的view覆盖在RecyclerView上,然后根据RcyclerView的滚动改变view的Y坐标,实现view的滑入和滑出。
第一步:布局
<FrameLayout android:layout_width="match_parent" android:layout_height="match_parent"> <android.support.v7.widget.RecyclerView android:id="@+id/rv_content" android:layout_width="match_parent" android:layout_height="match_parent" android:background="@color/colorCard" /> <include layout="@layout/view_node_title" /> //引用adapter中item中的title布局,保证标题样式一致 </FrameLayout>第二步:实现滚动监听
rvContent.addOnScrollListener(new RecyclerView.OnScrollListener() { @Override public void onScrollStateChanged(RecyclerView recyclerView, int newState) { super.onScrollStateChanged(recyclerView, newState); mTitleHeight = tvNodeTitle.getHeight(); } @Override public void onScrolled(RecyclerView recyclerView, int dx, int dy) { super.onScrolled(recyclerView, dx, dy); View view = mManager.findViewByPosition(mCurrentPosition + 1); if (view != null) { if (view.getTop() <= mTitleHeight) { tvNodeTitle.setY(-(mTitleHeight - view.getTop())); //根据下一个条目距离RecyclerView顶部的距离设置覆盖View的Y值,实现覆盖View的滑出和滑入。 } else { tvNodeTitle.setY(0); //覆盖View全部显示 } } if (mCurrentPosition != mManager.findFirstVisibleItemPosition()) { //表示条目已经改变 mCurrentPosition = mManager.findFirstVisibleItemPosition(); tvNodeTitle.setY(0); //重新设置覆盖View全部显示 if (map != null) { tvNodeTitle.setText(map.keyAt(mCurrentPosition)); //重新设置覆盖View的标题 } } } }); tvNodeTitle.setText(map.keyAt(0)); //设置初始条目显示标题为lsit的第一条。