![](/img/trans.png)
[英]Android RecyclerView with CardView: Margins between cards
[英]Want to add horizontal spacing between cards of CardView in android?
想在不使用 cardUseCompatPadding 的情况下在 CardView 的卡片之间添加间距,我该如何实现?
在行上设置 Padding,以便所有项目在每个项目之间设置间距
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:orientation="vertical"
android:background="#FFF"
android:padding="5dp"
android:layout_width="match_parent"
android:layout_height="wrap_content">
// here your views
</LinearLayout>
或者,像这样使用java来分离项目
RecyclerView.LayoutManager mLayoutManager = new LinearLayoutManager(getApplicationContext());
recyclerView.setLayoutManager(mLayoutManager);
recyclerView.setNestedScrollingEnabled(false);
recyclerView.setItemAnimator(new DefaultItemAnimator());
int spacingInPixels = getResources().getDimensionPixelSize(R.dimen.spacing);
recyclerView.addItemDecoration(new SpacesItemDecoration(spacingInPixels));
班级
public class SpacesItemDecoration extends RecyclerView.ItemDecoration {
private int space;
public SpacesItemDecoration(int space) {
this.space = space;
}
@Override
public void getItemOffsets(Rect outRect, View view,
RecyclerView parent, RecyclerView.State state) {
outRect.left = space;
outRect.right = space;
outRect.bottom = space;
// Add top margin only for the first item to avoid double space between items
if (parent.getChildLayoutPosition(view) == 0) {
outRect.top = space;
} else {
outRect.top = 0;
}
}
}
如果您使用数据绑定,您可能更喜欢检查列表项中的<Space />
组件以获取水平RecyclerView
间距
如下图;
<data>
<variable
name="data"
type="com.foo.Entity" />
<variable
name="position"
type="int" />
<import type="android.view.View" />
</data>
<LinearLayout
android:layout_width="wrap_content"
android:layout_height="45dp"
android:gravity="center"
android:orientation="horizontal">
<Space
android:layout_width="6dp"
android:layout_height="6dp"
android:visibility="@{position == 0 ? View.GONE : View.VISIBLE}" />
<RelativeLayout
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_centerInParent="true"
android:background="@drawable/gray_border">
<androidx.appcompat.widget.AppCompatTextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignParentStart="true"
android:layout_margin="8dp"
android:background="@color/white"
android:gravity="center"
android:lineSpacingExtra="4sp"
android:maxLines="1"
android:singleLine="true"
android:text="@{data.text}"
android:textColor="#6b778d"
android:textSize="12sp"
android:textStyle="normal"
tools:text="Foo" />
</RelativeLayout>
</LinearLayout>
你会看到;
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.