【Android从零单排系列二十五】《Android视图控件——RecyclerView》

2023-07-17 20:28:34 浏览数 (3)

前言

小伙伴们,在上文中我们介绍了Android视图组件Gallery,本文我们继续盘点,介绍一下视图控件的RecyclerView。

一 RecyclerView基本介绍

RecyclerView是Android支持库中的一个强大的视图容器,用于显示和管理大量数据集合的列表或网格。它是目前推荐使用的替代方式之一。

二 RecyclerView使用方法

在项目的build.gradle文件中添加RecyclerView的依赖:

代码语言:javascript复制
implementation 'androidx.recyclerview:recyclerview:<version>'

在布局文件中添加RecyclerView控件:

代码语言:javascript复制
<androidx.recyclerview.widget.RecyclerView
    android:id="@ id/recyclerView"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    ... />

创建一个适配器(Adapter)类,继承自RecyclerView.Adapter。适配器负责提供数据和创建子项视图。

代码语言:javascript复制
public class MyAdapter extends RecyclerView.Adapter<MyAdapter.ViewHolder> {

    private List<String> data;

    public MyAdapter(List<String> data) {
        this.data = data;
    }

    @NonNull
    @Override
    public ViewHolder onCreateViewHolder(@NonNull ViewGroup parent, int viewType) {
        // 创建ViewHolder,并关联对应的布局文件
        View view = LayoutInflater.from(parent.getContext()).inflate(R.layout.item_layout, parent, false);
        return new ViewHolder(view);
    }

    @Override
    public void onBindViewHolder(@NonNull ViewHolder holder, int position) {
        // 绑定数据到ViewHolder的视图上
        String item = data.get(position);
        holder.textView.setText(item);
    }

    @Override
    public int getItemCount() {
        return data.size();
    }

    public static class ViewHolder extends RecyclerView.ViewHolder {
        TextView textView;

        public ViewHolder(@NonNull View itemView) {
            super(itemView);
            textView = itemView.findViewById(R.id.textView);
        }
    }
}

在Activity或Fragment中初始化RecyclerView,并设置布局管理器和适配器:

代码语言:javascript复制
RecyclerView recyclerView = findViewById(R.id.recyclerView);

// 创建布局管理器,可以是LinearLayoutManager、GridLayoutManager等
RecyclerView.LayoutManager layoutManager = new LinearLayoutManager(this);
recyclerView.setLayoutManager(layoutManager);

// 创建适配器,并设置给RecyclerView
List<String> data = ...; // 准备数据集合
MyAdapter adapter = new MyAdapter(data);
recyclerView.setAdapter(adapter);

三 RecyclerView常见属性及方法

常见属性:

  1. android:id:设置RecyclerView的唯一标识符。
  2. android:layout_widthandroid:layout_height:设置RecyclerView的宽度和高度。
  3. android:layoutManager:指定RecyclerView的布局管理器,可以是LinearLayoutManager、GridLayoutManager或其他自定义的布局管理器。
  4. android:scrollbars:指定是否显示滚动条。
  5. android:padding:设置RecyclerView的内边距。

常见方法:

  1. setAdapter(Adapter adapter):设置RecyclerView的适配器,用于提供数据和创建视图。
  2. setLayoutManager(LayoutManager layoutManager):设置RecyclerView的布局管理器,决定如何排列和定位子项视图。
  3. setOnClickListener(View.OnClickListener listener):为整个RecyclerView设置点击事件监听器。
  4. addOnScrollListener(RecyclerView.OnScrollListener listener):添加滚动监听器,以便在滚动状态发生变化时执行相应操作。
  5. smoothScrollToPosition(int position):平滑地滚动RecyclerView到指定位置。

此外,RecyclerView还提供了很多其他方法和回调接口,用于处理子项的交互、动画效果、拖放和侧滑等功能。我们可以根据具体需求来选择和使用这些方法。

四 RecyclerView简单案例

首先,在布局文件中添加RecyclerView控件(例如,activity_main.xml):

代码语言:javascript复制
<androidx.recyclerview.widget.RecyclerView
    android:id="@ id/recyclerView"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    />

创建一个用于显示数据的子项布局文件(例如,item_layout.xml),可以根据实际需求定义布局:

代码语言:javascript复制
<TextView
    xmlns:android="http://schemas.android.com/apk/res/android"
    android:id="@ id/textView"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:textSize="16sp"
    android:padding="8dp" />

创建适配器类(例如,MyAdapter.java):

代码语言:javascript复制
public class MyAdapter extends RecyclerView.Adapter<MyAdapter.ViewHolder> {

    private List<String> data;

    public MyAdapter(List<String> data) {
        this.data = data;
    }

    @NonNull
    @Override
    public ViewHolder onCreateViewHolder(@NonNull ViewGroup parent, int viewType) {
        View view = LayoutInflater.from(parent.getContext()).inflate(R.layout.item_layout, parent, false);
        return new ViewHolder(view);
    }

    @Override
    public void onBindViewHolder(@NonNull ViewHolder holder, int position) {
        String item = data.get(position);
        holder.textView.setText(item);
    }

    @Override
    public int getItemCount() {
        return data.size();
    }

    public static class ViewHolder extends RecyclerView.ViewHolder {
        TextView textView;

        public ViewHolder(@NonNull View itemView) {
            super(itemView);
            textView = itemView.findViewById(R.id.textView);
        }
    }
}

在Activity中初始化RecyclerView并设置适配器(例如,在MainActivity.java中):

代码语言:javascript复制
public class MainActivity extends AppCompatActivity {

    private RecyclerView recyclerView;
    private MyAdapter adapter;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

        recyclerView = findViewById(R.id.recyclerView);

        // 创建布局管理器,可以选择LinearLayoutManager、GridLayoutManager等
        LinearLayoutManager layoutManager = new LinearLayoutManager(this);
        recyclerView.setLayoutManager(layoutManager);

        // 准备数据集合
        List<String> data = new ArrayList<>();
        data.add("Item 1");
        data.add("Item 2");
        data.add("Item 3");
        data.add("Item 4");
        data.add("Item 5");

        // 创建适配器,并设置给RecyclerView
        adapter = new MyAdapter(data);
        recyclerView.setAdapter(adapter);
    }
}

五 总结

RecyclerView是Android平台上的一个强大而灵活的视图容器,用于展示大量数据列表或网格布局。它是ListView的升级版本,并提供更好的性能和更丰富的功能。

与ListView相比,RecyclerView具有许多优势:

  1. 灵活性:RecyclerView提供了更高级别的自定义选项,使开发者可以灵活控制列表项的布局、动画效果和交互行为。
  2. 复用机制:RecyclerView引入了ViewHolder模式,可以重复利用子项的视图,在滚动过程中减少布局操作,提高性能。
  3. 增强的布局管理器(LayoutManager):RecyclerView支持不同类型的布局管理器,如线性布局、网格布局、瀑布流布局等,可以轻松实现各种列表和网格展示方式。
  4. 动画效果:RecyclerView内置了过渡动画和默认的布局动画效果,也可以自定义动画效果,为列表的数据变化和用户交互增加视觉吸引力。
  5. 事件处理:RecyclerView提供了方便的回调接口来处理点击、长按等事件,并且支持滚动监听器和拖拽排序等高级交互功能。

使用RecyclerView可以更好地管理和展示大量数据,同时也能够根据需要进行高度定制。它成为Android应用开发中常用的UI组件,广泛应用于各种应用场景,如社交媒体、新闻阅读、电子商务等。

0 人点赞