RecyclerView使用总结



1、RecyclerView用途:实现ListView,GridView,瀑布流


2、RecyclerView用法:

<pre class="html" name="code">rv.setLayoutManager(new LinearLayoutManager(getActivity()));//设置布局
        rv.setAdapter(adapter);//设置适配器
        rv.setItemAnimator(new DefaultItemAnimator());//设置动画
        rv.addItemDecoration(new DividerGridItemDecoration(this));//设置分割线


 
 
3、三种布局:
LinearLayoutManager :线性布局
GridLayoutManager :网格布局
StaggeredGridLayoutManager:瀑布流布局





4、自定义适配器






a、自定义ViewHolder
b、重写onCreateViewHolder方法,返回自定义viewholder
c、重写onBindViewHolder方法,绑定viewholder







package com.recyclerview.example.annieliu.recyclerviewtest;

import android.content.Context;
import android.support.v7.widget.RecyclerView;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.TextView;

import java.util.List;

import de.greenrobot.event.EventBus;

/**
 * Created by annieliu on 2016/2/5.
 */
public class MyRecyclerAdapter extends RecyclerView.Adapter<MyRecyclerAdapter.MyViewHolder>{

    private List<String> data;
    private Context ctx;

    public MyRecyclerAdapter(List<String> data, Context ctx) {
        this.data = data;
        this.ctx = ctx;
    }

    @Override
    public MyViewHolder onCreateViewHolder(ViewGroup parent, int viewType) {
        return new MyViewHolder(LayoutInflater.from(ctx).inflate(R.layout.list_item,parent,false));
    }

    @Override
    public void onBindViewHolder(MyViewHolder holder, final int position) {
        final String value=data.get(position);
        holder.tv.setText(value);

        holder.tv.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                EventBus.getDefault().post(value);
            }
        });

    }

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

    class MyViewHolder extends RecyclerView.ViewHolder{
        TextView tv;
        public MyViewHolder(View itemView) {
            super(itemView);
            tv=(TextView)itemView.findViewById(R.id.tv_list_item_num);
        }
    } 

}






5、动画

提供一种自定义动画:DefaultItemAnimator;其他自定义动画:https://github.com/gabrielemariotti/RecyclerViewItemAnimators






6、分割线:没有提供默认分割线;可继承RecyclerView.ItemDecoration 实现自定义分割线;参考资料:http://blog.csdn.net/lmj623565791/article/details/45059587
 
7、其他:item的点击事件可以使用EventBus实现,优点:解耦合;具体参见另一篇博文。
 
参考资料:http://blog.csdn.net/lmj623565791/article/details/45059587





                
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值