RecyclerView Item 的分割线 距边框距离问题总结

哈, 首先  今天Design 提了一个需求,废话少说~~! 上图

分割线 在中间显示,距离左边 边距是66px 右边依然是66px。

刚开始接到这个需求,感觉还阔以,挺简单的,但是在实现中 又有问题了,

怎么设置 都不能距离左右 有间距,上网上查依然没有解决方案。

网上有设置一个 View 然后给这个 View 设置宽高 颜色 但是 在我这里不能用,

因为我是自定义的控件 直接继承 ViewGroup 直接用 View 会有问题 影响了滑动控件。

我的解决方案如下:

 

我的 item 布局 是自定义的。在不改变自定义控件前提下 加上这个间隔线。

item 布局如下非常的简单:

<?xml version="1.0" encoding="utf-8"?>
<com.mxnavi.music.view.search.SwipeMenuLayout 
    xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    android:layout_width="match_parent"
    android:layout_height="@dimen/px_100"
    android:clickable="true"
    app:ios="true"
    app:leftSwipe="true"
    app:swipeEnable="true">

    //自定义的TextView
    <com.mxnavi.music.view.custom.CustomTextView
        android:id="@+id/tv_word"
        android:layout_width="match_parent"
        android:layout_height="@dimen/px_100"
        android:layout_centerVertical="true"
        android:layout_marginStart="@dimen/px_14"
        android:drawableLeft="@drawable/icon_search_history"
        android:drawablePadding="@dimen/px_14"
        android:gravity="center_vertical"
        android:paddingLeft="@dimen/px_66"
        android:maxEms="16"
        android:singleLine="true"
        android:textColor="@color/color_white_transparency_10"
        android:textSize="@dimen/px_21" />

    <Button
        android:id="@+id/bt_del"
        android:layout_width="@dimen/px_140"
        android:layout_height="@dimen/px_100"
        android:layout_alignParentEnd="true"
        android:layout_centerVertical="true"
        android:background="@color/search_history_delete_bg"
        android:gravity="center"
        android:text="删除"
        android:textColor="@color/color_white"
        android:textSize="@dimen/px_22" />
</com.mxnavi.music.view.search.SwipeMenuLayout>

然后再 Fragment 中 BindView 下一章会讲 很简单的一个标签。

@BindView(R.id.recycler_history)
EasyRecyclerView recyclerHistory;

recyclerHistory.addItemDecoration(getRecyclerViewDivider(R.drawable.search_history_solid));

RecyclerHistory 不用说 就是RecyclerView 历史记录。给RecyclerView每个item添加间隔线。

/**
     * 获取分割线
     *
     * @param drawableId 分割线id
     * @return
     */
    public RecyclerView.ItemDecoration getRecyclerViewDivider(@DrawableRes int drawableId) {
        DividerItemDecoration itemDecoration = new DividerItemDecoration(mContext, DividerItemDecoration.VERTICAL);
        itemDecoration.setDrawable(ContextCompat.getDrawable(mContext, drawableId));
        return itemDecoration;
    }

xml 布局 如下:

<?xml version="1.0" encoding="utf-8"?>
<inset xmlns:android="http://schemas.android.com/apk/res/android"
    android:insetLeft="66px"
    android:insetRight="66px">
    <shape>
        <!--分割线的高度,横向的RecyclerView,这里设置宽度即可-->
        <size android:height="1px" />
        <!--分割线的颜色-->
        <solid android:color="@color/search_dividing_line_color" />
    </shape>
</inset>

然后就完美解决了这个不改变 item 布局的情况下给每个 item 添加间隔线。

希望对你们有所帮助 哈哈! 虽然没有粉丝。

  • 4
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
要给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添加分割线了。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值