RecycleView的简单实现

原创 2017年01月02日 21:49:53

compile 'com.android.support:recyclerview-v7:25.1.0'

在module的gradle中引入recycleview库


Adapter实现    构造方法传入集合  作为数据的传递

public class MyAdapter extends RecyclerView.Adapter {

    @Bind(R.id.iv_item)
    ImageView ivItem;
    @Bind(R.id.tv_item)
    TextView tvItem;
    private List<String> itemDates = new ArrayList<>();

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

    @Override
    public RecyclerView.ViewHolder onCreateViewHolder(ViewGroup parent, int viewType) {
        //设置 item的布局   view
        View view = LayoutInflater.from(parent.getContext()).inflate(R.layout.item, parent, false);
        ButterKnife.bind(this, view);
        return new MyViewHolder(view);
    }

    @Override
    public void onBindViewHolder(RecyclerView.ViewHolder holder, int position) {
        //item布局里的子控件   可以设置  ,真实开发中往往   List的泛型是一个Bean对象
        tvItem.setText(itemDates.get(position));
    }

    @Override
    public int getItemCount() {
        return itemDates.size();
    }
}
主界面的实现如下:
public class MainActivity extends AppCompatActivity {
    @Bind(R.id.rv_main)
    RecyclerView rvMain;
    private List<String> itemDatas = new ArrayList<>();

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

        initView();
    }

    private void initView() {
        for (int i = 0; i < 10; i++) {
            itemDatas.add("黄忠" + i);
        }
	//recycleview一定要设置LayoutManager   否则无法展示   android官网是这么规定的   
//它还可以设置为其他的Grid布局   瀑布流布局等
        rvMain.setLayoutManager(new LinearLayoutManager(this, LinearLayoutManager.VERTICAL, false));
        rvMain.setAdapter(new MyAdapter(itemDatas));
    }
}
下面是item布局文件:
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:orientation="vertical" android:layout_width="match_parent"
    android:layout_height="60dp">
    <ImageView
        android:id="@+id/iv_item"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content" />
    <TextView
        android:id="@+id/tv_item"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content" />
</LinearLayout>
主界面的布局文件xml:
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    tools:context="com.soonbuy.dengjielin.recycleviewdemo.MainActivity">
    <android.support.v7.widget.RecyclerView
    android:id="@+id/rv_main"
    android:layout_width="match_parent"
    android:layout_height="match_parent"/>
</RelativeLayout>
有个主意事项:我用8.4.0 butterknife 的时候出现的问题    所以使用的是7.0.1版本   现在更新到了8.4.0版本
黄油刀你会在github发现这个事情
会多一行annotationProgrocessor   我引入的时候出错了  索性就用回7.0.1版本  了

实现的效果如图:


如果有帮到你,

相关文章推荐

使用recycleview实现简单的柱状图

简单的柱状图实现

recycleview多item布局的实现(简单聊天界面)

因项目需求,需要在一个列表中实现多个不同的布局方式 ,模拟了一个聊天界面 recycleview多item布局最主要的还是adapter部分,也就是适配器的写法 适配器代码如下:package c...

简单粗暴实现RecycleView的瀑布流的粘性头部(非ItemDecoration实现)

项目要用到粘性头部,以前的ListView和GridView的还好整,RecycleView的一片茫然,在github上找了很多发现好复杂,使用ItemDecoration实现,这货以我的智商真难搞懂...

快速实现实现RecycleView的二级菜单,简单易懂

第一次写,格式啥都不懂,瞎写了,只想把自己学到的记录下来,方便以后查看,也算是一个巩固学习吧!...

Kotlin 简单的recycleview

  • 2017年06月06日 10:30
  • 8MB
  • 下载

RecycleView简单使用

RecycleView简单使用读了那么多年的书让我明白一个道理。人要稳重,不要想到啥就做啥。做一行越久即使你不会,几年之后慢慢的你也会了,加上一点努力你或许你能成为别人眼中的专家。 参考blog:...

RecycleView和CardView简单使用

  • 2016年01月18日 21:20
  • 8.32MB
  • 下载

RecycleView简单介绍

通过此文可以简单了解以下: 1、RecycleView是什么 2、RecycleView的简单使用 3、RecycleView Item分割线的自定义 4、RecycleView的默认动画...

RecycleView和CardView的简单介绍和用法

很久之前在公司上遇到一个需求就是需要将ListView中的item布局改成每张每张卡片的那种样式,那时候还没接触到Design的各种UI框架,也算是挺久之前了。当时基本就慌了,心里骂了很多次什么傻B需...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:RecycleView的简单实现
举报原因:
原因补充:

(最多只允许输入30个字)