我刚刚开始使用 Android 开发并尝试获得“卡片 UI”样式的 ListView,它还使用上下文操作栏突出显示要删除的多个项目等。我只想在选择项目时将背景颜色更改为蓝色.
我设法使用图层列表获得了我想要的外观,但是当以优雅的方式选择等时,我无法让背景颜色发生变化。据我了解,我需要为此使用可绘制的“选择器”吗?但是当我使用它时,我不再知道如何获得卡片 UI 的外观。
这是我希望它的外观,并且能够在选择时将背景更改为蓝色。
这是我对选择器可绘制对象所做的,从功能上讲,就能够在选择时更改背景颜色而言,这很好,但正如您所看到的那样,它看起来是错误的。我只需要底部的灰色,如上图。
list_item.xml
<?xml version="1.0" encoding="utf-8"?>
<FrameLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="?android:attr/listPreferredItemHeight">
<LinearLayout
android:layout_width="match_parent"
android:layout_height="match_parent"
android:layout_marginLeft="2dp"
android:layout_marginRight="2dp"
android:layout_marginTop="4dp"
android:layout_marginBottom="4dp"
android:background="@drawable/card_background">
<ImageView
android:id="@+id/list_image"
android:layout_width="50dip"
android:layout_height="50dip"
android:src="@drawable/horse_image"
android:scaleType="centerCrop" />
<TextView
android:id="@+id/horse_name"
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:layout_weight="1"
android:layout_gravity="left|center_vertical"
android:textSize="20dip"
android:layout_marginLeft="10dip"
android:text="@string/loading_horses" />
</LinearLayout>
</FrameLayout>
card_background.xml
<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">
<item android:state_pressed="true" android:bottom="2dp">
<shape
android:shape="rectangle"
android:dither="true">
<stroke android:width="5dp" android:color="#FFDDDDDD" />
<corners android:radius="2dp" />
<solid android:color="@android:color/white" />
<padding
android:bottom="8dp"
android:left="8dp"
android:right="8dp"
android:top="8dp" />
</shape>
</item>
<item android:state_activated="true" android:bottom="2dp">
<shape
android:shape="rectangle"
android:dither="true">
<stroke android:width="5dp" android:color="#FFDDDDDD" />
<corners android:radius="2dp" />
<solid android:color="@android:color/holo_blue_light" />
<padding
android:bottom="8dp"
android:left="8dp"
android:right="8dp"
android:top="8dp" />
</shape>
</item>
<item android:bottom="2dp">
<shape
android:shape="rectangle"
android:dither="true">
<stroke android:width="5dp" android:color="#FFDDDDDD" />
<corners android:radius="2dp" />
<solid android:color="@android:color/white" />
<padding
android:bottom="8dp"
android:left="8dp"
android:right="8dp"
android:top="8dp" />
</shape>
</item>
</selector>