前言
此次作业是在第一次作业——类微信界面设计的基础上,对其中的某一个lab添加RecycleView的使用.关于类微信界面有在我的第一篇博客讲到,不了解的可以先看一下.
实现过程
1.首先我们先在四个lab.xml文件里选择一个添加recyclerview布局,这里我选择lab01.xml,在里面添加如下代码.
<androidx.recyclerview.widget.RecyclerView
android:id="@+id/recyclerView"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_margin="10dp"
android:overScrollMode="never"
android:scrollbars="none"
app:layout_constraintBottom_toBottomOf="parent"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintHorizontal_bias="1.0"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toTopOf="parent"
app:layout_constraintVertical_bias="0.007" />
2.添加recyclerview后,我们需要新建一个对应的fragment.xml文件.目的是设计recyclerview内元素的xml样式.
<?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="100dp"
android:layout_margin="8dp"
android:background="@android:color/darker_gray"
android:orientation="vertical">
<TextView
android:id="@+id/textView1"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_margin="10dp"
android:text="1" />
<TextView
android:id="@+id/textView2"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_margin="10dp"
android:text="具体内容" />
</LinearLayout>
3.完成之后.我们就该创建适配器RecyclerView.Adapter .
class Myadapter extends RecyclerView.Adapter<Myadapter.Myviewholder> {
private List<String> list=new ArrayList<>();
private Context context;
private Object Myviewholder;
//传入数据
public Myadapter(Context context) {
this.context = context;
}
public void Data_List(List<String> list){
this.list=list;
notifyDataSetChanged();
}
@NonNull
@Override
public Myviewholder onCreateViewHolder( ViewGroup parent, int viewType) {
//创建Myviewholder,返回布局
View itemView = LayoutInflater.from(context).inflate(R.layout.fragment_blank,parent,false);
return new Myviewholder(itemView);
}
@Override
public void onBindViewHolder(@NonNull Myviewholder holder, int position) {
//数据与控件绑定
holder.textView1.setText(position+1+"");
holder.textView2.setText(list.get(position));
}
@Override
//返回项目总数
public int getItemCount() {
return list==null ? 0:list.size();
}
//绑定控件
public class Myviewholder extends RecyclerView.ViewHolder{
TextView textView1,textView2;
public Myviewholder(@NonNull View itemView) {
super(itemView);
textView1=itemView.findViewById(R.id.textView1);
textView2=itemView.findViewById(R.id.textView2);
}
}
}
4.完成适配器后,我们需要在对应的java文件中获取我们的RecyclerView对象,并将我们创建的适配器实例化,在这里我们需要设置adapter和LayoutManager.
public class weixinFragment extends Fragment {
private RecyclerView recyclerView;
private Context context;
private List<String> list = new ArrayList<>();
private Myadapter myAdapter;
public weixinFragment() {
}
//初始化数据
private void init_Data() {
list.add("巴塞罗那");
list.add("皇家马德里");
list.add("马德里竞技");
list.add("毕尔巴鄂竞技");
list.add("皇家社会");
list.add("阿拉维斯");
list.add("比利亚雷亚尔");
list.add("瓦伦西亚");
list.add("格拉纳达");
list.add("埃尔切");
list.add("赫塔菲");
list.add("加的斯");
list.add("皇家贝蒂斯");
list.add("塞维利亚");
list.add("奥萨苏纳");
list.add("韦斯卡");
list.add("维戈塞尔塔");
list.add("巴拉多利德");
list.add("莱万特");
list.add("埃瓦尔");
}
private void init_View() {
context=this.getActivity();
Myadapter myAdapter = new Myadapter(context);
//获取recyclerView
recyclerView = recyclerView.findViewById(R.id.recyclerView);
//设置LayoutManager,设置显示效果,这里选择横向
LinearLayoutManager linearLayoutManager = new LinearLayoutManager(context);
linearLayoutManager.setOrientation(LinearLayoutManager.HORIZONTAL);//纵向只需将HORIZONTAL改为VERTICAL即可
recyclerView.setLayoutManager(linearLayoutManager);
recyclerView.setHasFixedSize(true);
recyclerView.setAdapter(myAdapter);
myAdapter.Data_List(list);
}
@Override
public View onCreateView(LayoutInflater inflater, ViewGroup container,
Bundle savedInstanceState) {
// 获取fragment的Layout
View view=inflater.inflate(R.layout.tab01, container, false);
recyclerView=view.findViewById(R.id.recyclerView);
init_Data();
init_View();
return view;
}
}
5.这样我们的工作就完成了 .我们可以看看效果
总结
本次RecycleView的使用属于最基础的范畴,我也是在学习阶段,争取以后学习进阶式的RecycleView.
附上完整项目代码链接: