Закругленные углы cardView не работают в RecyclerView-Android?

мой android устройство 4.3 и не работайте за углом cardView :

<android.support.v7.widget.CardView xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/tools"
    xmlns:card_view="http://schemas.android.com/apk/res-auto"
    android:id="@+id/CardStart"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:layout_marginBottom="5dp"
    android:layout_marginLeft="20dp"
    android:layout_marginRight="20dp"
    android:scaleType="centerCrop"
    app:cardUseCompatPadding="true"
    card_view:cardBackgroundColor="@color/BlackTrans"
    card_view:cardCornerRadius="5dp"
    card_view:cardElevation="0dp">

    <LinearLayout
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:orientation="horizontal">

        <LinearLayout
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:orientation="vertical">

            <TextView
                android:id="@+id/txtTitle"
                android:layout_width="match_parent"
                android:layout_height="wrap_content" />

            <TextView
                android:id="@+id/txtDescription"
                android:layout_width="match_parent"
                android:layout_height="wrap_content" />
        </LinearLayout>

        <LinearLayout
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:orientation="vertical">

            <ImageButton
                android:id="@+id/imgbIcon"
                android:layout_width="wrap_content"
                android:layout_height="match_parent"
                android:src="@drawable/ic_serch" />
        </LinearLayout>
    </LinearLayout>
</android.support.v7.widget.CardView>

и я пишу код bellow в своем классе, но еще не работаю:

if (android.os.Build.VERSION.SDK_INT < Build.VERSION_CODES.LOLLIPOP)
{
    holder.CardStart.setCardElevation(0);
    holder.CardStart.setBackgroundColor(ContextCompat.getColor(context,R.color.BlackTrans));
    holder.CardStart.setRadius(5);
    holder.CardStart.setUseCompatPadding(true);
}

3 ответов


оказывается, что звонит View.setBackgroundColor(int) на CardView удаляет закругленные углы.

изменить цвет фона карты и сохранить углы, нужно позвонить .

это может быть так для некоторых посетителей этого поста.


при наследовании CardView, Я предлагаю добавить следующий метод для защиты ваших углов от случайного удаления:

/**
 * Override prevents {@link View#setBackgroundColor(int)} being called,
 * which removes the rounded corners.
 */
@Override
public void setBackgroundColor(@ColorInt int backgroundColor) {
    setCardBackgroundColor(backgroundColor);
}

в частности, я работал над пользовательским представлением реализация для React Native и React автоматически применяла цвет фона к представлению. Это переопределение решило эту проблему; это означает, что другим разработчикам не нужно знать детали базового представления.


попробуйте добавить эти два атрибута в свой вид карты

card_view:cardPreventCornerOverlap="false"
card_view:cardUseCompatPadding="true"

вот документация для первого атрибута (который содержит ссылку на второй) https://developer.android.com/reference/android/support/v7/widget/CardView.html#setPreventCornerOverlap(boolean)

это должно сделать трюк


используйте это в самом верхнем объявлении макета в файле макета xml:

xmlns:card_view="http://schemas.android.com/apk/res-auto"

это решило проблему для меня.