web-dev-qa-db-ja.com

角の丸い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>

そして、私はクラスで以下のコードを書きますが、まだ機能していません:

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);
}
10
user4813855

CardViewView.setBackgroundColor(int)を呼び出すと、丸みを帯びた角が削除されることがわかりました。

カードの背景色を変更して角を保持するには、代わりにCardView.setCardBackgroundColor(int)を呼び出す必要があります。

これは、この投稿への特定の訪問者に当てはまる場合があります。


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は自動的に背景色をビューに適用していました。このオーバーライドにより、この問題は解決しました。 ;これは、他の開発者が基になるビューの詳細を知る必要がないことを意味します。

46

カードビューにこの2つの属性を追加してみてください

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

これが最初の属性のドキュメントです(2番目の属性への参照が含まれています) https://developer.Android.com/reference/Android/support/v7/widget/CardView.html#setPreventCornerOverlap(boolean) ==

これはトリックを行う必要があります

2
Mathias Cabano

xmlレイアウトファイルの最上位のレイアウト宣言でこれを使用します。

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

これは私にとって問題を解決しました。

1