RecyclerView去除底部分割线

RecyclerView 默认的分割线DividerItemDecoration 在最后一个item显示的时候也会有一个分割线,影响应用整体的美观。


通过DividerItemDecoration 源码发现分割线的行数是通过childCount来判断的,而childCount正是我们分割线的个数,那去除最后一个分割线也就简单了。

    public void drawHorizontal(Canvas c, RecyclerView parent)
    {
        int childCount = parent.getChildCount();
        for (int i = 0; i < childCount; i++)
        {
            final View child = parent.getChildAt(i);
            final RecyclerView.LayoutParams params = (RecyclerView.LayoutParams) child
                    .getLayoutParams();
            final int left = child.getLeft() - params.leftMargin;
            final int right = child.getRight() + params.rightMargin
                    + mDivider.getIntrinsicWidth();
            final int top = child.getBottom() + params.bottomMargin;
            final int bottom = top + mDivider.getIntrinsicHeight();
            mDivider.setBounds(left, top, right, bottom);
            mDivider.draw(c);
        }
    }

    public void drawVertical(Canvas c, RecyclerView parent)
    {
        final int childCount = parent.getChildCount();
        for (int i = 0; i < childCount; i++)
        {
            final View child = parent.getChildAt(i);

            final RecyclerView.LayoutParams params = (RecyclerView.LayoutParams) child
                    .getLayoutParams();
            final int top = child.getTop() - params.topMargin;
            final int bottom = child.getBottom() + params.bottomMargin;
            final int left = child.getRight() + params.rightMargin;
            final int right = left + mDivider.getIntrinsicWidth();

            mDivider.setBounds(left, top, right, bottom);
            mDivider.draw(c);
        }
    }

我们只需要重写一个类,把childCount  改为childCount-1,那此问题就解决了。

    public void drawHorizontal(Canvas c, RecyclerView parent)
    {
        int childCount = parent.getChildCount();
        for (int i = 0; i < childCount-1; i++)
        {
            final View child = parent.getChildAt(i);
            final RecyclerView.LayoutParams params = (RecyclerView.LayoutParams) child
                    .getLayoutParams();
            final int left = child.getLeft() - params.leftMargin;
            final int right = child.getRight() + params.rightMargin
                    + mDivider.getIntrinsicWidth();
            final int top = child.getBottom() + params.bottomMargin;
            final int bottom = top + mDivider.getIntrinsicHeight();
            mDivider.setBounds(left, top, right, bottom);
            mDivider.draw(c);
        }
    }

    public void drawVertical(Canvas c, RecyclerView parent)
    {
        final int childCount = parent.getChildCount();
        for (int i = 0; i < childCount-1; i++)
        {
            final View child = parent.getChildAt(i);

            final RecyclerView.LayoutParams params = (RecyclerView.LayoutParams) child
                    .getLayoutParams();
            final int top = child.getTop() - params.topMargin;
            final int bottom = child.getBottom() + params.bottomMargin;
            final int left = child.getRight() + params.rightMargin;
            final int right = left + mDivider.getIntrinsicWidth();

            mDivider.setBounds(left, top, right, bottom);
            mDivider.draw(c);
        }
    }


  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要给RecyclerView添加分割线,可以通过以下步骤实现: 1. 在RecyclerView的布局文件中,添加如下代码: ``` <androidx.recyclerview.widget.RecyclerView android:id="@+id/recycler_view" android:layout_width="match_parent" android:layout_height="match_parent" android:divider="@drawable/divider" android:dividerHeight="1dp" /> ``` 其中,`divider`是你自定义的drawable文件,用于绘制分割线,`dividerHeight`是分割线的高度。 2. 在drawable文件夹下,添加`divider.xml`文件,内容如下: ``` <shape xmlns:android="http://schemas.android.com/apk/res/android" android:shape="rectangle"> <size android:width="1dp" android:height="1dp" /> <solid android:color="@android:color/darker_gray" /> </shape> ``` 这里我们使用了一个矩形的shape,设置它的宽和高都为1dp,然后填充灰色作为分割线的颜色。 3. 在RecyclerView的Adapter中,需要重写`getItemCount()`方法,让它返回数据源的大小(包括分割线)。 ``` @Override public int getItemCount() { return data.size() * 2 - 1; } ``` 这里我们假设数据源为`data`,并且每个item之间都需要添加分割线,所以数据源的大小要乘以2,再减去1。 4. 最后,在RecyclerView的Adapter中,重写`onBindViewHolder()`方法,根据item的位置,判断它是否为分割线,然后设置分割线的可见性。 ``` @Override public void onBindViewHolder(@NonNull RecyclerView.ViewHolder holder, int position) { if (position % 2 == 1) { // 是分割线 holder.itemView.setVisibility(View.GONE); } else { // 是数据项 holder.itemView.setVisibility(View.VISIBLE); // 设置数据项的内容 } } ``` 这里我们通过判断位置是否为奇数来判断它是否为分割线,如果是分割线,则设置可见性为`GONE`,否则设置可见性为`VISIBLE`,同时设置数据项的内容。 通过以上步骤,我们就可以给RecyclerView添加分割线了。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值