Android 在recyclerview中间距网格项

Android 在recyclerview中间距网格项,android,android-recyclerview,item-decoration,Android,Android Recyclerview,Item Decoration,我想在recyclerview中填充网格项,查看它目前在所有方面都有效(顶部、底部等) 我只想从顶部应用空格,右侧的任何人都可以帮助我更改现有代码 如果我正确理解了您想要做的事情,您可以进入项目的布局,在顶部父布局中指定页边顶部和页边右侧,这样每个项目都将具有相同的margini。我已经尝试过这一点。但是父cardview仅将margint应用于底部抱歉,我没有理解您的观点。您所说的“父cardview仅将边距应用于底部”是什么意思?请添加一些代码?添加xmlcode@GregorioPalam

我想在recyclerview中填充网格项,查看它目前在所有方面都有效(顶部、底部等)

我只想从顶部应用空格,右侧的任何人都可以帮助我更改现有代码


如果我正确理解了您想要做的事情,您可以进入项目的布局,在顶部父布局中指定页边顶部和页边右侧,这样每个项目都将具有相同的margini。我已经尝试过这一点。但是父cardview仅将margint应用于底部抱歉,我没有理解您的观点。您所说的“父cardview仅将边距应用于底部”是什么意思?请添加一些代码?添加xmlcode@GregorioPalam更新了△xml。
public class GridSpacingItemDecoration extends RecyclerView.ItemDecoration {
    private int spanCount;
    private int spacing;
    private boolean includeEdge;

    public GridSpacingItemDecoration(int spanCount, int spacing, boolean includeEdge) {
        this.spanCount = spanCount;
        this.spacing = spacing;
        this.includeEdge = includeEdge;
    }

    @Override
    public void getItemOffsets(Rect outRect, View view, RecyclerView parent, RecyclerView.State state) {
        int position = parent.getChildAdapterPosition(view); // item position
        int column = position % spanCount; // item column

        if (includeEdge) {
            outRect.left = spacing - column * spacing / spanCount; // spacing - column * ((1f / spanCount) * spacing)
            outRect.right = (column + 1) * spacing / spanCount; // (column + 1) * ((1f / spanCount) * spacing)

            if (position < spanCount) { // top edge
                outRect.top = spacing;
            }
            outRect.bottom = spacing; // item bottom
        } else {
            outRect.left = column * spacing / spanCount; // column * ((1f / spanCount) * spacing)
            outRect.right = spacing - (column + 1) * spacing / spanCount; // spacing - (column + 1) * ((1f /    spanCount) * spacing)
            if (position >= spanCount) {
                outRect.top = spacing; // item top
            }
        }
    }
}
 <?xml version="1.0" encoding="utf-8"?>
<android.support.v7.widget.CardView xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    android:layout_width="@dimen/margin_120dp"
    android:layout_height="@dimen/margin_120dp"
    android:background="@color/white"
    android:elevation="@dimen/margin_2"
    android:layout_marginRight="@dimen/margin_2"
    android:layout_marginTop="@dimen/margin_2"
    android:orientation="vertical"
    app:cardCornerRadius="@dimen/margin_2"
    app:cardPreventCornerOverlap="true">

    <RelativeLayout
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:orientation="vertical">

        <ImageView
            android:id="@+id/category_item"
            android:layout_width="@dimen/margin_60dp"
            android:layout_height="@dimen/margin_60dp"
            android:layout_centerHorizontal="true"
            android:layout_gravity="center"
            android:layout_marginTop="@dimen/margin_10dp"
            android:src="@drawable/home" />

        <TextView
            android:id="@+id/cat_name"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_alignParentBottom="true"
            android:layout_centerHorizontal="true"
            android:layout_gravity="center"
            android:gravity="bottom"
            android:padding="@dimen/margin_5dp"
            android:text="@string/app_name" />
    </RelativeLayout>
</android.support.v7.widget.CardView>