实现两个RecyclerView联动

做APP项目很多的时候,都会有两个列表联动,商城类项目居多,简单的记录下两个RecyclerView联动效果。

关键代码:

1.xml代码:




    

        

        
    

2.联动关键代码

   listGoods.addOnScrollListener(new RecyclerView.OnScrollListener() {//商品列表的滚动监听
            @Override
            public void onScrolled(@NonNull RecyclerView recyclerView, int dx, int dy) {
                super.onScrolled(recyclerView, dx, dy);
                // 第一个可见位置
                int firstItemPosition = recyclerView.getChildLayoutPosition(recyclerView.getChildAt(0));
                String firstItemPosition_typeId=goodsDatas.get(firstItemPosition).getGoodsTypeId();//第一个可见商品的分类ID
                if(!TextUtils.isEmpty(firstItemPosition_typeId)){
                    for(int i=0;i
  /**
     * 分类点击事件
     * @param adapter
     * @param view
     * @param position
     */
    @Override
    public void onItemChildClick(BaseQuickAdapter adapter, View view, int position) {
        for(int i=0;i= 0 && movePosition < mRecyclerView.getChildCount()) {
                int top = mRecyclerView.getChildAt(movePosition).getTop();
                mRecyclerView.smoothScrollBy(0, top);//dx>0===>向左  dy>0====>向上
            }
        } else {
            // 第三种可能:跳转位置在最后可见项之后
            mRecyclerView.smoothScrollToPosition(position);
            mToPosition = position;
            mShouldScroll = true;

            //监听事件的设置,仅仅是为了第三种情况,即:要跳转的位置在可见项之后
            mRecyclerView.addOnScrollListener(new RecyclerView.OnScrollListener() {
                @Override
                public void onScrollStateChanged(RecyclerView recyclerView, int newState) {
                    super.onScrollStateChanged(recyclerView, newState);
                    if (mShouldScroll && RecyclerView.SCROLL_STATE_IDLE == newState) {//
                        mShouldScroll = false;
                        smoothMoveToPosition(mRecyclerView, mToPosition);
                    }
                }
            });
        }
    }

效果图(仿美团效果)

实现两个RecyclerView联动_第1张图片

你可能感兴趣的:(实现两个RecyclerView联动)