RecyclerView底部分割线去除的方法
程序员文章站
2023-01-21 10:12:05
概述
之前我们抛出了一个问题就是recyclerview在显示列表的时候,最底部也就是最后一个item后面还有分割线,这大大影响界面的美观。这篇文章就是解决这个问题的。...
概述
之前我们抛出了一个问题就是recyclerview在显示列表的时候,最底部也就是最后一个item后面还有分割线,这大大影响界面的美观。这篇文章就是解决这个问题的。
自定义分割线
通过分析源码后我们发现没有相关的方法来处理这一需求,所以只能自定义分割线,通过上一篇文章的基础我们知道肯定是修改getitemoffsets。那我们的思路是让这个方法在到最后一个条目时,不偏移分割线的间隙。同时也要修改ondraw方法,让他不再绘制最后一条分割线。
private void drawhorizontal(canvas c, recyclerview parent, state state) { int childcount = parent.getchildcount() - 1; int left = 0; int top = parent.getpaddingtop(); int right = 0; int bottom = parent.getheight() - parent.getpaddingbottom(); for (int i = 0; i < childcount; i++) { view view = parent.getchildat(i); recyclerview.layoutparams params = (layoutparams) view.getlayoutparams(); //考虑,padding left = view.getright(); right = left + divider.getintrinsicheight(); //我们在自定义drawable的是是,写死了高度,所以只能用高度 divider.setbounds(left, top, right, bottom); divider.draw(c); } } /** * 思路:就是获取每个item,计算divider的left,top,right,bottom */ private void drawvertical(canvas c, recyclerview parent, state state) { int childcount = parent.getchildcount() - 1; int left = parent.getpaddingleft(); int top = 0; int right = parent.getwidth() - parent.getpaddingright(); //考虑右边的padding int bottom = 0; for (int i = 0; i < childcount; i++) { //不绘制最后一个条目的分割线 view view = parent.getchildat(i); recyclerview.layoutparams params = (layoutparams) view.getlayoutparams(); //考虑,padding top = view.getbottom() + params.topmargin; //就是当前view底部到顶部的距离 bottom = top + divider.getintrinsicheight() - params.bottommargin; //就是top+divider高度 divider.setbounds(left, top, right, bottom); divider.draw(c); } } @override public void getitemoffsets(rect outrect, view view, recyclerview parent, state state) { int childadapterposition = parent.getchildadapterposition(view); int lastcount = parent.getadapter().getitemcount() - 1; //如果当前条目与是最后一个条目,就不设置divider padding if (childadapterposition == lastcount) { outrect.set(0, 0, 0, 0); return; } log.d("tag", childadapterposition + "," + lastcount); if (orientation == linearlayoutcompat.horizontal) { outrect.set(0, 0, divider.getintrinsicheight(), 0); //0,0,30,0,设置宽度 } else { outrect.set(0, 0, 0, divider.getintrinsicheight()); //0,0,0,30,设置高度 } }
使用这个自定义分割线的效果图如下:
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。