Android Recyclerview设置Item之间的间距

本文介绍了如何在RecyclerView中为每个item添加底部内边距,特别是解决最后一项缺失下边距的问题。通过在item布局文件中设置根布局的paddingBottom,然后在RecyclerView中设置clipToPadding为false并添加paddingBottom,可以确保所有item包括最后一项都有8dp的下边距。这种方法避免了自定义LayoutParams和ItemDecoration的复杂性。

其实不需要自定义LinearLayout.LayoutParams 跟RecyclerView.ItemDecoration。
假设:要在recycleView的每条item的下加一个8dp的边距:
第一步:
在每个item的布局的根布局加上paddingBottom。

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:paddingBottom="9dp">

    <RelativeLayout
        android:layout_width="wrap_content"
        android:layout_height="wrap_content">

        <TextView
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_marginLeft="16dp"
            android:layout_marginTop="13dp"
            android:textColor="#ff5e5c5c"
            android:textSize="9sp"/>
    </RelativeLayout>

</RelativeLayout>

此时前面的所以item都有8dp的下边距,但是最后一条item没有下边距;

第二步:
在RecycleView里设置属性clipToPadding、paddingBottom就可以了

<androidx.recyclerview.widget.RecyclerView
            android:id="@+id/recy_alert_list"
            android:layout_width="match_parent"
            android:layout_height="match_parent"
            android:clipToPadding="false"
            android:paddingBottom="8dp"/>

此处的paddingBottom由于受到clipToPadding属性的影响并不会作用到所有的子item中,设置完以后,你就会看到,最后一条item也有了8dp的底部内边距。

使用`androidx.recyclerview.widget.RecyclerView`实现 item 间距,通常可通过自定义`ItemDecoration`类来完成。以下为具体步骤与示例代码: ### 1. 自定义`ItemDecoration`类 自定义一个类继承自`RecyclerView.ItemDecoration`,并重写`getItemOffsets`方法。此方法能够为每个 item 设置偏移量,进而实现间距效果。示例代码如下: ```java package com.rivotek.recyclerview; import android.graphics.Rect; import android.view.View; import androidx.annotation.NonNull; import androidx.recyclerview.widget.RecyclerView; public class ItemDecor extends RecyclerView.ItemDecoration { private int space; public ItemDecor(int space) { this.space = space; } @Override public void getItemOffsets(@NonNull Rect outRect, @NonNull View view, @NonNull RecyclerView parent, @NonNull RecyclerView.State state) { if (parent.getChildLayoutPosition(view) != 0) { outRect.top = space; } } } ``` 上述代码里,`ItemDecor`类的构造函数接收一个`space`参数,用来表示 item 之间间距。在`getItemOffsets`方法中,除首个 item 外,其余 item 的顶部都会设置一个间距`space` [^1]。 ### 2. 在布局文件中添加`RecyclerView` 在布局文件里添加`RecyclerView`,示例代码如下: ```xml <androidx.recyclerview.widget.RecyclerView android:id="@+id/recyclerView" android:layout_width="match_parent" android:layout_height="match_parent"/> ``` 由于`RecyclerView`并非内置在系统 SDK 中,所以要写出其完整的包名路径 [^2][^3]。 ### 3. 在代码中设置`ItemDecoration` 在 Activity 或者 Fragment 中获取`RecyclerView`实例,并且为其设置自定义的`ItemDecoration`,示例代码如下: ```java import androidx.appcompat.app.AppCompatActivity; import androidx.recyclerview.widget.LinearLayoutManager; import androidx.recyclerview.widget.RecyclerView; import android.os.Bundle; public class MainActivity extends AppCompatActivity { @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); // 获取 RecyclerView 实例 RecyclerView recyclerView = findViewById(R.id.recyclerView); // 设置布局管理器 recyclerView.setLayoutManager(new LinearLayoutManager(this)); // 创建 ItemDecor 实例,设置间距为 10px ItemDecor itemDecor = new ItemDecor(10); // 为 RecyclerView 设置 ItemDecor recyclerView.addItemDecoration(itemDecor); // 设置适配器等其他操作 // ... } } ``` 上述代码中,创建了一个`ItemDecor`实例,将间距设置为 10px,然后通过`recyclerView.addItemDecoration(itemDecor)`方法为`RecyclerView`设置了该`ItemDecoration` [^1]。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值