Android CardView删除填充

Iva*_*iuk 33 android android-cardview

如何在下面的布局中摆脱这个奇怪的填充:

在此输入图像描述

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:card_view="http://schemas.android.com/apk/res-auto"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical"
    android:background="@color/ColorPrimaryDark">

    <android.support.v7.widget.CardView
        android:layout_width="fill_parent"
        android:layout_height="wrap_content"
        card_view:cardCornerRadius="10dp"
        android:layout_marginTop="9dp"
        android:layout_marginLeft="9dp"
        android:layout_marginRight="9dp"
        card_view:cardElevation="0.01dp"
        android:layout_marginBottom="0dp"
        card_view:cardPreventCornerOverlap="true"
        card_view:cardUseCompatPadding="true"
        card_view:cardBackgroundColor="@color/ColorPrimary">

        <RelativeLayout
            android:id="@+id/top_layout"
            android:layout_width="fill_parent"
            android:layout_height="180dp"
            android:background="@color/ColorPrimary">

            <ImageView
                android:id="@+id/img_thumbnail"
                android:layout_width="fill_parent"
                android:layout_height="180dp"
                android:scaleType="fitXY"
                android:background="@drawable/korabltest"/>

            <RelativeLayout
                android:id="@+id/inner_layout"
                android:layout_width="fill_parent"
                android:layout_height="36dp"
                android:background="#5c1b1b1b"
                android:layout_gravity="bottom"
                android:layout_alignParentBottom="true"
                android:layout_alignParentLeft="true"
                android:layout_alignParentStart="true">

                <TextView
                    android:id="@+id/tv_nature"
                    android:layout_width="wrap_content"
                    android:layout_height="50dp"
                    android:paddingLeft="5dp"
                    android:paddingRight="5dp"
                    android:layout_gravity="bottom"
                    android:gravity="center_vertical"
                    android:alpha="0.8"
                    android:textColor="#fff"
                    android:textSize="18sp"
                    android:text="Lexington"
                    android:layout_alignParentLeft="true"
                    android:layout_alignParentStart="true" />

                <TextView
                    android:id="@+id/tv_nature_1"
                    android:layout_width="wrap_content"
                    android:layout_height="50dp"
                    android:paddingLeft="5dp"
                    android:paddingRight="5dp"
                    android:layout_gravity="bottom"
                    android:gravity="center_vertical"
                    android:alpha="0.8"
                    android:textColor="#fff"
                    android:textSize="18sp"
                    android:textStyle="bold"
                    android:text="527 (31%)"
                    android:layout_alignParentBottom="true"
                    android:layout_alignParentRight="true"
                    android:layout_alignParentEnd="true" />
            </RelativeLayout>
        </RelativeLayout>
    </android.support.v7.widget.CardView>

</LinearLayout>
Run Code Online (Sandbox Code Playgroud)

fah*_*hmy 54

UDPATE

好吧,似乎有一个更简单的方法来做到这一点,而不是猜测填充和所有:

card_view:cardPreventCornerOverlap="false"
Run Code Online (Sandbox Code Playgroud)

或者使用java:

cardView.setPreventCornerOverlap(false)
Run Code Online (Sandbox Code Playgroud)

你可以在这里阅读所有相关内容.

原始答案

这是一种有意的填充,以避免内容在棒棒糖版本中从卡的圆角溢出(因为剪辑不可用).如果你想摆脱这一切在一起,你可以使用棒棒糖之前的版本负填充了contentPadding的属性CardView,如:

card_view:contentPadding="-8dp"
Run Code Online (Sandbox Code Playgroud)

或者使用java:

int padding = (int) TypedValue.applyDimension(TypedValue.COMPLEX_UNIT_DIP, 8, getResources().getDisplayMetrics());
cardView.setContentPadding(-padding,-padding,-padding,-padding);
Run Code Online (Sandbox Code Playgroud)

我不太确定哪个值能无缝地工作,你需要自己试验和看看.

  • 感谢您的回答,但将card_view:cardPreventCornerOverlap更改为false后,圆角完全消失了,而不仅仅是一个正方形。 (2认同)

Sho*_*que 7

请从您的代码中删除它 -

card_view:cardUseCompatPadding="true"
Run Code Online (Sandbox Code Playgroud)


s-h*_*ter 6

遇到了同样的问题,对我有用。

app:cardPreventCornerOverlap="false"
Run Code Online (Sandbox Code Playgroud)

对于 API < 21 的设备,我必须创建一个自定义 ImageView 类,重写 onDraw 来绘制圆角。

@Override
protected void onDraw(Canvas canvas) {
    float radius = getContext().getResources().getDimension(R.dimen.card_corner_radius);
    Path path = new Path();
    RectF rect = new RectF(0, 0, this.getWidth(), this.getHeight());
    path.addRoundRect(rect, radius, radius, Path.Direction.CW);
    canvas.clipPath(path);
    super.onDraw(canvas);
}
Run Code Online (Sandbox Code Playgroud)