RecyclerView项目实战之:自动吸顶

效果展示

在这里插入图片描述
接下来,你将学到:
RecyclerView基本使用
ItemDecoration
③优秀的算法思想
等知识点!

一.前期准备工作

1.将MainActivity布局改成RelativeLayout,添加RecyclerView

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    tools:context=".MainActivity">

    <androidx.recyclerview.widget.RecyclerView
        android:id="@+id/rv_list"
        android:layout_width="match_parent"
        android:layout_height="match_parent">

    </androidx.recyclerview.widget.RecyclerView>

</RelativeLayout>

2.新建rv_item_star布局文件,作为itemView布局

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout
    xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:background="@color/purple_500">
    <TextView
        android:id="@+id/tv_star"
        android:layout_width="match_parent"
        android:layout_height="60dp"
        android:textSize="20sp"
        android:gravity="center"/>
</RelativeLayout>

3.创建实体类

public class Star {
   
    private String name;
    private String group;

    public Star(String name, String group) {
   
        this.name = name;
        this.group = group;
    }

    public String getName() {
   
        return name;
    }

    public void setName(String name) {
   
        this.name = name;
    }

    public String getGroup() {
   
        return group;
    }

    public void setGroup(String group) {
   
        this.group = group;
    }
}

4.创建适配器

public class StarAdapter extends RecyclerView.Adapter<StarAdapter.StarViewHolder> {
   
    private Context context;
    private List<Star> starList;

    public StarAdapter(Context context, List<Star> starList) {
   
        this.context = context;
        this.starList = starList;
    }

    @NonNull
    @Override
    public StarViewHolder onCreateViewHolder(@NonNull ViewGroup parent, int viewType) {
   
        View view = LayoutInflater.from(context).inflate(R.layout.rv_item_star,null);
        return new StarViewHolder(view);
    }

    @Override
    public void onBindViewHolder(@NonNull StarViewHolder holder, int position) {
   
        holder.tv.setText(starList.get(position).getName());
    }

    @Override
    public int getItemCount() {
   
        //细节
        return starList == null ? 0 : starList.size();
    }

    public class StarViewHolder extends RecyclerView.ViewHolder{
   
        private TextView tv;
        public StarViewHolder(@NonNull View itemView) {
   
            super(itemView);
            tv = itemView.findViewById(R.id.tv_star);
        }
    }
}

5.创建继承自RecyclerView.ItemDecoration的类(自定义的)

public class StarDecoration extends RecyclerView.ItemDecoration {
   
    public StarDecoration(Context context) {
   
    }
}

此时的MainActivity

public class MainActivity extends AppCompatActivity {
   
    private List<Star> starList;
    @Override
    protected void onCreate(Bundle savedInstanceState) {
   
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        init();
        RecyclerView rv = findViewById(R.id.rv_list);
        //设置布局管理器和适配器
        rv.setLayoutManager(new LinearLayoutManager(this));
        rv.setAdapter(new StarAdapter(this,starList));
        //自定义分割线
        rv.addItemDecoration(new StarDecoration(this));
    }
    //初始化,为star集合添加数据
    private void init() {
   
        starList = new ArrayList<>();
        for(int i = 0;i < 4;i++){
   
            for(int j = 0;j < 20;j++){
   
                if(i % 2 == 0){
   
                    starList.add(new Star("何炅" + j,"快乐家族" + i));
                }else {
   
                    starList.add(new Star("汪涵" + j,"天天兄弟" + i));
                }
            }
        }
    }
}

运行一下,看效果
在这里插入图片描述

二.介绍下ItemDecoration

1.首先看一下系统提供的抽象类

public abstract static class ItemDecoration {
   
    	//绘制
        public void onDraw(@NonNull Canvas c, @NonNull RecyclerView parent, @NonNull State state) {
   
            onDraw(c, parent);
        }
        public void onDrawOver(@NonNull Canvas c, @NonNull RecyclerView parent,
                @NonNull State state) {
   
            onDrawOver(c, parent);
        }

		//设置Item偏移量
        public void getItemOffsets(@NonNull Rect outRect, @NonNull View view,
                @NonNull RecyclerView parent, @NonNull State state) {
   
            getItemOffsets(outRect, ((LayoutParams) view.getLayoutParams()).getViewLayoutPosition(),
                    parent);
        }
    }

2.看其抽象类的实现类

官方目前只提供了一个实现类DividerItemDecoration。它是跟LinearLayoutManager配套的。如果我们要实现自定义分割线,就得学习下人家系统实现类是怎么实现的。
在这里插入图片描述
我们如果想自定义参考线,就要看一下系统是如何实现某些方法的。所以我们看一下DividerItemDecoration的源码

public class DividerItemDecoration extends RecyclerView.ItemDecoration {
   
  	...
    private Drawable mDivider;
    private final Rect mBounds = new Rect();

    public DividerItemDecoration(Context context, int orientation) {
   
		//------------------------------------------
		//------------------------------------------
		//创建了一个Drawable,后面绘制分割线也是用Drawable绘制的
		//------------------------------------------
		//------------------------------------------
        mDivider = a.getDrawable(0);
		...
    }

    
  • 3
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值