<?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=".recyclerView.LinearRecyclerViewActivity">
<androidx.recyclerview.widget.RecyclerView //建一个recyclerview
android:id="@+id/linearRecyclerView"
android:layout_width="match_parent"//宽度匹配父容器(这里是全部占满)
android:layout_height="wrap_content"/>//高度内容包裹
</RelativeLayout>
//item.xml 用于recyclerview生成的素材
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout
xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:padding="20dp">
<TextView
android:id="@+id/recycler_textview"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:text="hello"
android:textSize="24sp"
android:textColor="@color/black"/>
</LinearLayout>
public class LinearRecyclerViewActivity extends AppCompatActivity {
private RecyclerView linearRecyclerView;
private List<String> data;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_linear_recycler_view);
// 数据
data = new ArrayList<>();
for (int i = 0; i < 15; i++) {
data.add("哈哈"+i);
}
linearRecyclerView = findViewById(R.id.linearRecyclerView);//获取recyclerview
linearRecyclerView.setLayoutManager(new LinearLayoutManager(this));//设置为线性布局,默认垂直排列
//通过lambda传入匿名实现类 并编写方法 view就是内部中传入的texeView项
linearRecyclerView.setAdapter(new LinearAdapter(data,view->{
Toast.makeText(this,"sad"+view.getText(),Toast.LENGTH_SHORT).show();
}));//设置适配器
//下面代码均为设置每个项之间的下划线
DividerItemDecoration dividerItemDecoration =
new DividerItemDecoration(this,DividerItemDecoration.VERTICAL);
dividerItemDecoration.setDrawable(Objects.requireNonNull
(ResourcesCompat.getDrawable(getResources(),R.drawable.decoration,null)));//自己的图片
//为项添加下划线
linearRecyclerView.addItemDecoration(dividerItemDecoration);
}
}
//适配器的固定写法,继承于RecyclerView.Adapter且定义一个内部类作为视图持有者ViewHolder
public class LinearAdapter extends RecyclerView.Adapter<LinearAdapter.LinearViewHolder> {
private List<String> data;
private OnItemClickListener onItemClickListener;//自定义的项点击事件接口
LinearAdapter(List<String> data,OnItemClickListener onItemClickListener){
this.data = data;
this.onItemClickListener = onItemClickListener;
}
@NonNull
@Override
//理解为为recyclerview设置要生成的素材xml,这里素材是自建的item.xml
//设置好素材返回viewholder
public LinearViewHolder onCreateViewHolder(@NonNull ViewGroup parent, int viewType) {
View view = LayoutInflater.from(parent.getContext())
.inflate(R.layout.item,parent,false);
return new LinearViewHolder(view);
}
@Override
//理解对viewholder中的每个项元素遍历做数据绑定
public void onBindViewHolder(@NonNull LinearViewHolder holder, int position) {
holder.textView.setText(data.get(position));
//项点击事件,调用自定义的接口中写的方法 这样就能从外部传入一个实现类,点击时就是调用的外部实现类中的方法
holder.textView.setOnClickListener(v -> {
onItemClickListener.onClick(holder.textView);
});
}
@Override
//理解为要recyclerview要生成的项个数 根据传进来的list数据动态生成
public int getItemCount() {
return data.size();
}
//自定义的ViewHolder 上面所有操作都是在操作这个玩意
//理解为在onCreateViewHolder这步设置了素材item.xml,这个viewholder能够获取出来item.xml中的元素
class LinearViewHolder extends RecyclerView.ViewHolder{
public TextView textView;//item.xml中的一个元素
public LinearViewHolder(@NonNull View itemView) {
super(itemView);
textView = itemView.findViewById(R.id.recycler_textview);//获取出来这个元素
}
}
//自定义接口用于从外部来写项的点击事件
interface OnItemClickListener{
public void onClick(TextView view);//参数随便定义
}
}
总结
个人通俗理解一个viewholder对应一个item项,遍历生成 getItemCount() 个viewholder 在 onCreateViewHolder 函数中生成出来;然后通过onBindViewHolder 函数 做一些遍历时的处理
如果理解不对的话希望各位对我进行纠正!笔者正处于安卓入门的阶段!