RecyclerView(一) 基本运用

本文详细介绍如何在Android项目中从零开始使用RecyclerView。首先在build.gradle中添加必要的库依赖,然后在XML布局文件中初始化RecyclerView组件。接着创建自定义适配器,并在Activity中设置LayoutManager和Adapter,最后运行应用完成RecyclerView的集成。

一.build.gradle文件中加载RecyclerView库

dependencies {
    implementation 'com.android.support:appcompat-v7:28.0.0'
    implementation 'com.android.support:recyclerview-v7:28.0.0'

}

二.xml文件中初始化RecyclerView

 <android.support.v7.widget.RecyclerView
      android:id="@+id/recyclerView"
      android:layout_width="match_parent"
      android:layout_height="match_parent">


  </android.support.v7.widget.RecyclerView>

 

三.设置RecyclerView的适配器

  class MyAdapter extends RecyclerView.Adapter<MyViewHolder> {

        private final Context context;
        private final List<Integer> datas;

        MyAdapter(Context context, List<Integer> datas) {
            this.context = context;
            this.datas = datas;
        }

        @NonNull
        @Override
        public MyViewHolder onCreateViewHolder(@NonNull ViewGroup viewGroup, int i) {
            View view = LayoutInflater.from(context).inflate(R.layout.item_data, viewGroup, false);

            return new MyViewHolder(view);
        }

        @Override
        public void onBindViewHolder(@NonNull MyViewHolder myViewHolder, int position) {

            TextView title = myViewHolder.itemView.findViewById(R.id.tv_title);
            title.setText("第" + position + "个Item");
        }

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

    class MyViewHolder extends RecyclerView.ViewHolder {

        public MyViewHolder(@NonNull View itemView) {
            super(itemView);
        }
    }

四.初始化RecyclerView

  mRecyclerView = findViewById(R.id.recyclerView);
        LinearLayoutManager linearLayoutManager =
                new LinearLayoutManager(this, LinearLayoutManager.VERTICAL, false);
        mRecyclerView.setLayoutManager(linearLayoutManager);
        MyAdapter myAdapter = new MyAdapter(this, datas);
        mRecyclerView.setAdapter(myAdapter);

五.运行,完成!!

六.知识点

1. LinearLayoutManager(Context context, int orientation, boolean reverseLayout) ,orientation可为LinearLayoutManager.VERTICAL和LinearLayoutManager.HORIZONTAL,reverseLayout如果是true,则item布局是倒序排序

2. StaggeredGridLayoutManager(int spanCount, int orientation) ,spanCount指一屏占多少格,该布局需要在onBindViewHolder中动态改变布局大小

3.GridLayoutManager(Context context, int spanCount, int orientation, boolean reverseLayout) 

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值