RecyclerView的使用

RecyclerView是优化后的ListView,使用起来非常简单.主要记录一下使用方法以及注意点
使用RecyclerView需要设定LayoutManager.一般有三种

//线性布局,一行只有一个数据
LinearLayoutManager
//网格布局,可以制定一行有几列
GridLayoutManager
//增强版网格布局,可以制定水平还是竖直排列
StaggeredGridLayoutManager

使用方法如下:

RecyclerView recyclerView = (RecyclerView)findViewById(R.id.recyclerview);
recyclerView.setLayoutManager(new StaggeredGridLayoutManager(3, OrientationHelper.VERTICAL));
// 避免adapter数据变化时刷新整个layout
recyclerView.setHasFixedSize(true);

recyclerView加载数据也是需要adapter, 使用方法如下:

public class GridAdapter extends RecyclerView.Adapter<GridAdapter.GridHolder> {
    private List<String> datas;
    private LayoutInflater mInflater;
    private OnItemClickListener mListener;

    public interface OnItemClickListener{
        void onItemClick(View view, int position);
        void onItemLongClick(View view, int position);
    }

    public void setItemClickListener(OnItemClickListener mListener)
    {
        this.mListener = mListener;
    }

    public GridAdapter(Context context, List<String> datas) {
        this.mInflater = LayoutInflater.from(context);
        this.datas = datas;
    }
    @Override
    public GridHolder onCreateViewHolder(ViewGroup parent, int viewType) {

        GridHolder gridHolder = new GridHolder(mInflater.
        inflate(R.layout.item_grid, parent, false));
        return gridHolder;
    }
    @Override
    public void onBindViewHolder(final GridHolder holder, int position) {
        holder.textView.setText(datas.get(position));
        if (mListener != null)
        {
        }
    }

    @Override
    public int getItemCount() {
        return datas.size();
    }
    public class GridHolder extends RecyclerView.ViewHolder {
        TextView textView;
        public GridHolder(View itemView) {
            super(itemView);
            textView = (TextView)itemView.findViewById(R.id.id_num);
        }
    }
}

adapter中增加删除数据的时候需要用到

    public void addData(int position)
    {
        notifyItemInserted(position);
    }

    public void removeData(int position)
    {
        notifyItemRemoved(position);

    }

需要注意的是, onBindViewHolder中的position是初始化binder的position, 无论运行时数据怎么变化, position记录的都是一开始初始化的位置. 如果需要实时获得每一个item的position需要使用

int adapterPosition = holder.getAdapterPosition();

这样简单的recyclerview就加载好了, 但是每一个item都是拼凑在一起的,没有分割线或者间隙. 如果需要对每个item中间加上距离, 需要使用RecyclerView.ItemDecoration. 方法如下:

public class MarginDecoration extends RecyclerView.ItemDecoration {

    private int margin;

    public MarginDecoration(Context context) {
        margin = context.getResources().getDimensionPixelSize(R.dimen.item_margin);
    }

    @Override
    public void getItemOffsets(Rect outRect, View view, RecyclerView parent, RecyclerView.State state) {
        outRect.set(margin, margin, margin, margin);
    }
}

使用的时候

mRecyclerView.addItemDecoration(new MarginDecoration(getApplicationContext()));
RecyclerView是一个高度可定制的列表视图组件,它在Android开发中常用于展示大量数据。以下是使用RecyclerView的基本步骤: 1. **添加依赖**: - 在Gradle构建脚本中添加RecyclerView的依赖,如果是使用AndroidX,则在app模块的build.gradle文件中加入: ```gradle implementation 'com.google.android.material:material:1.4.0' ``` - 或者对于老版的support库,添加: ```gradle implementation 'com.android.support:recyclerview-v7:28.0.0' ``` 2. **添加布局文件**: 创建一个XML布局文件,例如`item_recycler_view.xml`,定义每个列表项的外观。 3. **在Activity/Fragment中声明 RecyclerView**: 在对应的布局文件中添加RecyclerView,指定其ID和一些基本属性,如宽度和高度。 ```xml <androidx.recyclerview.widget.RecyclerView android:id="@+id/recyclerView" android:layout_width="match_parent" android:layout_height="match_parent" /> ``` 4. **创建Adapter**: 创建一个继承自`RecyclerView.Adapter`的自定义适配器,负责管理数据源和视图的绑定。你需要覆盖` onCreateViewHolder()`, ` onBindViewHolder()` 和 ` getItemCount()` 方法。 5. **设置Adapter**: 在Activity/Fragment中,找到RecyclerView并设置Adapter。 ```java RecyclerView recyclerView = findViewById(R.id.recyclerView); recyclerView.setAdapter(new MyAdapter()); ``` 6. **设置LayoutManager**: 根据需求选择合适的LayoutManager,如 LinearLayoutManager, GridLayoutManager 等。设置在Adapter的构造函数中或者在Activity/Fragment中设置。 ```java recyclerView.setLayoutManager(new LinearLayoutManager(this)); ``` 7. **加载数据**: 将数据填充到适配器中,可以在Adapter的构造函数中完成,也可以在onStart或onCreateView方法里动态加载。 8. **设置ItemAnimator** (可选): 可以增强动画效果,如: ```java recyclerView.setItemAnimator(new DefaultItemAnimator()); ``` 9. **滚动监听事件** (可选): 添加OnScrollListener来响应滚动事件,例如分页加载更多。 至此,就完成了基础的RecyclerView使用。你可以进一步个性化设置,如监听点击事件、加载更多等功能。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值