此教程是完全针对新手,用最笨的方法和备注,只为能让学习的人看懂
因为我也在学
Activity的代码
public class LieBiaoActivity extends AppCompatActivity {
private RecyclerView recyclerView;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_liebiao);
recyclerView = findViewById(R.id.recyclerView);
//列表类型和 RecyclerView控件的Activity
recyclerView.setLayoutManager(new LinearLayoutManager(LieBiaoActivity.this));
//设置列表 这里是你自定义的适配器 RecyclerView控件的Activity
recyclerView.setAdapter(new LieBiaoAdapter(LieBiaoActivity.this));
}
}
适配器代码
实际上写多了会发现适配器代码都是差不多的
实在不会写就背
package com.huatex.recyclerlayout.Adapter;
import android.content.Context;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.TextView;
import com.huatex.recyclerlayout.R;
import androidx.annotation.NonNull;
import androidx.recyclerview.widget.RecyclerView;
//继承自Adapter androidx.recyclerview.widget.RecyclerView.Adapter
// 这里是创建时没有的,要自己加
public class LieBiaoAdapter extends RecyclerView.Adapter<LieBiaoAdapter.LinearViewHolder> {
//新建 定义一个变量
private Context context;
//构造方法
public LieBiaoAdapter(Context context) {
this.context = context;
}
@NonNull
@Override
// 这里创建时不是这样的 根据上面的内容替换为LinearViewHolder
public LieBiaoAdapter.LinearViewHolder onCreateViewHolder(@NonNull ViewGroup parent, int viewType) {
//这里传入上面定义的context ,然后加载列表布局
return new LinearViewHolder(LayoutInflater.from(context).inflate(R.layout.layout_liebiao_item, parent, false));
}
@Override // 这里也是替换的
public void onBindViewHolder(@NonNull LieBiaoAdapter.LinearViewHolder holder, int position) {
//这个方法是设置列表布局里面的控件内容的
holder.tv.setText("aaaa");
}
@Override
public int getItemCount() {
//这里设置的是列表个数
return 30;
}
//这个类是全新自定义的 对应上面的 <LieBiaoAdapter.LinearViewHolder>
//作用是获取到列表里面的控件
class LinearViewHolder extends RecyclerView.ViewHolder {
//找到控件
private TextView tv;
public LinearViewHolder(@NonNull View itemView) {
super(itemView);
//用传入的 itemView 来绑定控件 这样上面的holder就可以使用了
tv = itemView.findViewById(R.id.textView);
}
}
}
列表控件
列表显示的内容
注意这里的布局高度(注意是布局,不是文本控件),是wrap
不然底部会出现空白
最终效果