- 首先编写ReadAdapter类,可直接复制进行使用,来自小小小白冷博主的文章-b站材料2–Adapter源文件
package com.example.myapplication2.Adapter; import android.annotation.SuppressLint; import android.content.Context; import android.view.LayoutInflater; import android.view.View; import android.view.ViewGroup; import android.widget.TextView; import androidx.annotation.NonNull; import androidx.recyclerview.widget.RecyclerView; //这里的 myapplication2 在你进行复制后需要修改为你的项目名字 import com.example.myapplication2.R; public class ReadAdapter extends RecyclerView.Adapter{ @NonNull private Context mContext; private OnItemClickListener mListener; //private List list; public ReadAdapter(Context context , OnItemClickListener listener){ this.mContext = context; this.mListener = listener; } @Override public RecyclerView.ViewHolder onCreateViewHolder(@NonNull ViewGroup parent, int viewType) { //viewType可以通过这个,展示不同的item return new LinearViewHolder(LayoutInflater.from(mContext).inflate(R.layout.courseitem, parent, false)); //这里需要传入每个item长什么样的布局,需要去layout中去画我们的布局 } @Override //通过getItemViewType的返回值来选择具体的item显示 public void onBindViewHolder(@NonNull RecyclerView.ViewHolder holder, @SuppressLint("RecyclerView")final int position) { ((LinearViewHolder)holder).textView.setText("图片选择"); //如果是直接用viewholder的话,是不能用test view的 //将点击事件放到外面 holder.itemView.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { //Toast.makeText(mContext,"click..."+position,Toast.LENGTH_SHORT).show(); mListener.onClick(position); } }); } //去控制viewType的方法,根据位置的奇偶性来区分 @Override public int getItemViewType(int position) { if(position % 2 == 0){ return 0;//偶数 }else{ return 1; } } @Override public int getItemCount() { return 10; } class LinearViewHolder extends RecyclerView.ViewHolder{ private TextView textView; public LinearViewHolder(View itemView){ super(itemView); textView = itemView.findViewById(R.id.finish_title); } } //接口 public interface OnItemClickListener{ void onClick(int pos); } }
- 在界面布局中,ScrollView下添加线性布局,在线性布局中引用RecyclerView
- 新建布局文件 course-item 作为 ScrollView的内容,course-item的布局可以自己定义,之后会通过ReadAdapter中的代码加载进ScrollView中
即:
@Override
public RecyclerView.ViewHolder onCreateViewHolder(@NonNull ViewGroup parent, int viewType) {
//viewType可以通过这个,展示不同的item
return new LinearViewHolder(LayoutInflater.from(mContext).inflate(R.layout.courseitem, parent, false));
//这里需要传入每个item长什么样的布局,需要去layout中去画我们的布局
}
- 编写相关java类
//先声明控件
private RecyclerView rcfinished;
//在写相关事件
rcfinished=findViewById(R.id.rv_finished);
rcfinished.setLayoutManager(new LinearLayoutManager(ReadActivity.this));
rcfinished.setAdapter(new ReadAdapter(ReadActivity.this, new ReadAdapter.OnItemClickListener() {
@Override
public void onClick(int pos) {
Toast.makeText(ReadActivity.this,"click..."+pos,Toast.LENGTH_LONG).show();
}
}));



