如何在卡片视图中将卡片变灰?

Amr*_*916 5 android kotlin android-cardview

我有一个卡片视图,动态列出一组卡片。我为此使用了recyclerview。现在我想通过使卡变灰或类似的方式来禁用卡(基于值)。这是包含卡片视图的布局

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:orientation="vertical">

    <android.support.v7.widget.CardView
        android:layout_width="112dp"
        android:layout_height="140dp"
        android:layout_margin="10dp"
        android:clickable="true"
        android:focusable="true"
        android:scaleType="fitXY">

        <RelativeLayout
            android:layout_width="100dp"
            android:layout_height="150dp"
            android:padding="8dp">

            <ImageView
                android:id="@+id/appIcon"
                android:layout_width="match_parent"
                android:layout_height="62dp"
                android:padding="5dp"
                tools:ignore="VectorDrawableCompat" />

            <TextView
                android:id="@+id/name"
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:layout_below="@+id/appIcon"
                android:layout_centerInParent="true"
                android:gravity="center"
                android:textAppearance="@style/Base.TextAppearance.AppCompat.Small"
                android:textColor="@drawable/selector"
                android:textSize="10dp"
                android:textStyle="bold" />

            <TextView
                android:id="@+id/appVersion"
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:layout_alignParentBottom="true"
                android:layout_alignParentEnd="true"
                android:layout_marginBottom="5dp"
                android:layout_marginEnd="1dp"
                android:text="version 0.0"
                android:textAppearance="@style/Base.TextAppearance.AppCompat.Small"
                android:textSize="8dp" />

        </RelativeLayout>

    </android.support.v7.widget.CardView>

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

我找到了一些相关的查询,并尝试使用选择器并将每个字段而不是整个卡片变灰。

<selector xmlns:android="http://schemas.android.com/apk/res/android">
    <item android:state_enabled="true" android:color="@color/colorAppName" />
    <item android:state_enabled="false" android:color="@color/colorPrimary" />

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

在我的班级(Adapter.kt)

name = itemView.findViewById(R.id.name) as TextView
if(value==true)
{
  name.isEnabled=false
}
Run Code Online (Sandbox Code Playgroud)

但我想禁用整个卡。请帮忙

Sur*_*nav 1

您可以将色调设置为相对布局,该布局是项目设计中卡片视图的直接子级。您必须在 xml 中执行此操作:

 <android.support.v7.widget.CardView
        android:layout_width="112dp"
        android:layout_height="140dp"
        android:layout_margin="10dp"
        android:clickable="true"
        android:focusable="true"
        android:scaleType="fitXY">

        <RelativeLayout
            android:id="@+id/relParent"
            android:background="#fff"
            android:layout_width="100dp"
            android:layout_height="150dp"
            android:padding="8dp">
      ....>
Run Code Online (Sandbox Code Playgroud)

我在RelativeLayout中添加了两个属性,第一个是id,第二个是background。

现在在适配器中你可以这样做:

if(value==true)  
{
itemView.relParent.background.setColorFilter(Color.parseColor("#6F6F6F"),PorterDuff.Mode.SRC_IN)
        itemView.relParent.isEnabled=false
}
else
{
itemView.relParent.background.setColorFilter(Color.parseColor("#FFFFFF"),PorterDuff.Mode.SRC_IN)
        itemView.relParent.isEnabled=true
}
Run Code Online (Sandbox Code Playgroud)

注意:您必须从 xml 将背景设置为relativelayout,否则 itemView.relParent.background 将返回 null 并且您的应用程序将崩溃。

更新 您需要为您的卡片设置前景颜色,在这种情况下,请执行以下操作:

itemView.cardDashboard.foreground= ColorDrawable(Color.parseColor("#906F6F6F"))
Run Code Online (Sandbox Code Playgroud)

这里的cardDashboard是您在项目设计中使用的卡片视图。

所以最终的代码将是这样的:

       if(value==true)  
        {
        itemView.cardDashboard.foreground= ColorDrawable(Color.parseColor("#906F6F6F"))     
   itemView.relParent.isEnabled=false
        }
        else
        {
        itemView.cardDashboard.foreground= ColorDrawable(Color.parseColor("#006F6F6F"))
                itemView.relParent.isEnabled=true
        }
Run Code Online (Sandbox Code Playgroud)