在进行一些MaterialDesign规范开发的时候,比如之前说到的CoordinateLayout实现的向上折叠效果的时候,如果依然使用ListVIEw,那么这种效果是做不出来的,因为ListVIEw不兼容这个控件,而替代它的就是RecyclerVIEw。
和ListVIEw的区别:
①RecyclerVIEw只关心item的重用和缓存
②RecyclerVIEw不关心item的分隔风格(交给Itemdecoration)
③RecyclerVIEw不关心item的动画(交给ItemAnimator)
④RecyclerVIEw不关心item的布局(交给LayoutManager)
本文为初探,所以先不详解②③④这几个内容,先记录一下用法和遇到的坑,后续有时间再更新!
先放一下效果图,动画效果在之前的博客也有提到,可以参考,主要的是中间的RecyclerVIEw,这里主要讲如何使用它以及遇到的一些问题
先添加依赖,版本无所谓:
compile 'com.androID.support:recyclervIEw-v7:23.1.1'
布局文件如下,注意最后一个属性可以不用理,这是用来协调动画效果的(就是把上面图片推上去的效果)
<androID.support.v7.Widget.RecyclerVIEwandroID:ID="@+ID/main_lv"androID:layout_wIDth="match_parent"androID:layout_height="match_parent"app:layout_behavior="@string/appbar_scrolling_vIEw_behavior"/>
@R_419_6942@一个Adapter继承自RecyclerVIEw.Adapter,代码如下:
public class MyAdapter extends RecyclerVIEw.Adapter { private static final String TAG = "MyAdapter"; private final List<Map<String,Object>> data; private final VIEw root; private OnItembuttonClickListener Listener; public MyAdapter(List<Map<String,Object>> data,VIEw root) { this.data = data; this.root = root; } public voID setonItembuttonClickListener(OnItembuttonClickListener Listener){ this.Listener = Listener; } class VIEwHolder extends RecyclerVIEw.VIEwHolder { TextVIEw reason,money,date; button delete,alter; public VIEwHolder(VIEw itemVIEw) { super(itemVIEw); reason = (TextVIEw) itemVIEw.findVIEwByID(R.ID.main_rv_item_reason); money = (TextVIEw) itemVIEw.findVIEwByID(R.ID.main_rv_item_money); date = (TextVIEw) itemVIEw.findVIEwByID(R.ID.main_rv_item_date); delete = (button) itemVIEw.findVIEwByID(R.ID.main_rv_item_remove); alter = (button) itemVIEw.findVIEwByID(R.ID.main_rv_item_alter); } } @OverrIDe public RecyclerVIEw.VIEwHolder onCreateVIEwHolder(VIEwGroup parent,int vIEwType) { VIEwHolder vh = new VIEwHolder(LayoutInflater.from(parent.getContext()).inflate(R.layout .main_lv_item,null)); return vh; } @OverrIDe public voID onBindVIEwHolder(RecyclerVIEw.VIEwHolder holder,final int position) { final VIEwHolder vh = (VIEwHolder) holder; vh.date.setText(data.get(position).get("date").toString()); vh.reason.setText(data.get(position).get("reason").toString()); vh.money.setText(data.get(position).get("money").toString()); vh.delete.setonClickListener(new VIEw.OnClickListener() { @OverrIDe public voID onClick(VIEw v) { Snackbar snackbar = Snackbar.make(root,"Are you sure to delete it?",Snackbar.LENGTH_LONG); snackbar.setAction("YES",new MyOnClickListener(vh.getLayoutposition())); snackbar.show(); } }); vh.alter.setonClickListener(new VIEw.OnClickListener() { @OverrIDe public voID onClick(VIEw v) { Listener.OnItemAlter(vh.getLayoutposition()); } }); } @OverrIDe public int getItemCount() { return data.size(); } private class MyOnClickListener implements VIEw.OnClickListener { private final int position; public MyOnClickListener(int position) { this.position = position; } @OverrIDe public voID onClick(VIEw v) { Listener.OnItemDelete(position); } } interface OnItembuttonClickListener { voID OnItemAlter(int position); voID OnItemDelete(int position); }}
解析:构造方法中获取到数据源以及根VIEw,根VIEw用来显示Snackbar,如果不知道Snackbar,请看上一篇。然后创建一个内部类,继承自RecyclerVIEw.VIEwHolder,用它来保存每一个Item的全部控件。接下来重写几个方法:getItemCount、onBindVIEwHolder以及onCreateVIEwHolder,他们分别是返回item个数,绑定VIEwHolder以及创建VIEwHolder,创建VIEwHolder就是通过Item的布局文件获取每个控件的实例,绑定VIEwHolder就是把数据源中的数据映射到Item的控件中,因为我们的Item中还有删除和修改按钮,所以我们为它们添加点击事件也是在onBindVIEwHolder中进行。接下来我们定义一个接口OnItembuttonClickListener并且定义两个方法分别用来回调点击删除和修改,并创建接口的对象,在按钮点击的时候分别调用接口的两个方法,并传入点击的item的position。
Activity部分代码如下:
rv = (RecyclerVIEw) findVIEwByID(R.ID.main_lv);adapter = new MyAdapter(data,root);rv.setLayoutManager(new linearlayoutmanager(this,linearlayoutmanager.VERTICAL,false)); // 设置布局,否则无法正常使用adapter.setonItembuttonClickListener(this);rv.setAdapter(adapter);
@OverrIDe public voID OnItemAlter(int position) { //Intent intent = new Intent(MainActivity.this,Alteractivity.class); //intent.putExtra("ID",Integer.parseInt(data.get(position).get("ID").toString())); //intent.putExtra("date",data.get(position).get("date").toString()); //intent.putExtra("money",data.get(position).get("money").toString()); //intent.putExtra("reason",data.get(position).get("reason").toString()); //startActivityForResult(intent,REQUEST_ALTER); } @OverrIDe public voID OnItemDelete(int position) { Log.d(TAG,"OnItemDelete() called with: " + "position = [" + position + "]"); //Map<String,Object> backup = data.get(position); //data.remove(position); //database.execsql("delete from tally where ID=?",new String[]{backup.get // ("ID").toString()}); adapter.notifyItemRemoved(position); }
解析:获取RecyclerVIEw的实例之后,设置对应的布局管理器,然后通过setonItembuttonClickListener设置回调函数并实现,最后给RecyclerVIEw设置adapter即可。
遇到的问题:
①刚开始忘记设置布局,RecyclerVIEw不显示出来
②因为我们在删除item之后调用了notifyItemRemoved方法来显示动画并刷新,在onBindVIEwHolder中,对删除按钮监听之后调用接口方法的时候传入了position,这个position是错误的,因为在绑定的时候固定了,如果数据源的数据被删除了,数据源的size会变小,这个position就不再对应于数据源的每一个项就会产生混乱,所以这里应该传入vIEwholder.getLayoutposition()所得到的值,这个值是对应点击而产生的。
③如果在RecyclerVIEw的第一项前面插入一个item,并且调用notifyItmeInserted(0),是不会播放动画效果的。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持编程小技巧。
总结以上是内存溢出为你收集整理的学习Android开发之RecyclerView使用初探全部内容,希望文章能够帮你解决学习Android开发之RecyclerView使用初探所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)