Как настроить тень в каждой ячейке ListView?
У меня есть пользовательская ячейка для Android ListView. Эта настраиваемая ячейка является относительной компоновкой с некоторыми видами внутри. Между каждой ячейкой есть пробел, поэтому я хочу добавить к нижней части ячейки тень.
Я гулял, но ничего не нашел? Я хочу добиться чего-то подобного:
![enter image description here]()
Спасибо!
Ответы
Ответ 1
Можно сделать двумя способами:
- 9-патч-изображения - нажмите ссылку для понимания 9 патчей
-
Использование списка слоев - создайте новый файл в файле res/drawable, который содержит:
<?xml version="1.0" encoding="utf-8"?>
<layer-list xmlns:android="http://schemas.android.com/apk/res/android">
<item >
<shape
android:shape="rectangle">
<solid android:color="@android:color/darker_gray" />
<corners android:radius="5dp"/>
</shape>
</item>
<item android:right="1dp" android:left="1dp" android:bottom="2dp">
<shape
android:shape="rectangle">
<solid android:color="@android:color/white"/>
<corners android:radius="5dp"/>
</shape>
</item>
</layer-list>
Затем добавьте этот файл списка слоев в качестве фона в свой макет списка элементов (например, Linearlayout или т.д.).
Ответ 2
Самый простой способ - создать тень в 9-патче. Пример такого типа:
![Box 9-Patch]()
Это намного больше, чем нужно, как 9-патч, но я хотел сделать его более крупным, например, ради.
Ответ 3
i применяю этот список слоев в качестве фона в вашем элементе списка элементов, выбранный цвет отключен....
<?xml version="1.0" encoding="utf-8"?>
<layer-list xmlns:android="http://schemas.android.com/apk/res/android">
<item >
<shape
android:shape="rectangle">
<solid android:color="@android:color/darker_gray" />
<corners android:radius="5dp"/>
</shape>
</item>
<item android:right="1dp" android:left="1dp" android:bottom="2dp">
<shape
android:shape="rectangle">
<solid android:color="@android:color/white"/>
<corners android:radius="5dp"/>
</shape>
</item>
</layer-list>
Ответ 4
Я еще не тестировал ваш точный сценарий, но вот как вы добавили бы прозрачный разделитель в представление списка:
<LinearLayout
xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="wrap_content"
android:layout_height="wrap_content">
<ListView
android:id="@+id/android:list"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:divider="@android:color/transparent"
android:dividerHeight="4dip"/>
</LinearLayout>
Это то, что вам нужно, если вы хотите добавить теневую линию программно.
<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android"
android:shape="rectangle">
<solid android:color="@android:color/transparent" />
<stroke
android:layout_marginLeft="10dip"
android:layout_marginRight="10dip"
android:width="match_content"
android:color="@color/black" />
<size android:height="1dp" />
</shape>
Цвет штриха может не отображаться как черный, поскольку он отображается поверх альфа-слоя. Кроме того, в настоящее время он рисует четыре стороны прямоугольника, а не только нижнюю сторону. (Мне нужно будет продолжить исследование этих двух проблем).
См. этот учебник, если вам нужна помощь в выяснении того, как связать все вместе.
Ответ 5
Создайте прямоугольник слоя, который выйдет из-под него и задайте свой собственный вид сотового фона в его xml.
<?xml version="1.0" encoding="utf-8"?>
<layer-list xmlns:android="http://schemas.android.com/apk/res/android" >
<!--shadow to bottom and right-->
<!--by pushing offset from top and left-->
<!--then set foreground-color in android:background in xml-->
<item
android:left="2dp"
android:right="0dp"
android:top="2dp"
android:bottom="0dp">
<shape
android:shape="rectangle">
<solid android:color="@android:color/darker_gray" />
</shape>
</item>
</layer-list>
in your cell.xml:
<RelativeLayout
android:layout_width="match_content"
android:layout_height="wrap_content"
android:background="@drawable/shadow">
<RelativeLayout
android:id="@+id/cell_stuff"
android:layout_width="match_content"
android:layout_height="match_content"
android:background="@android:color/holo_orange_light">
<!--cell stuff-->
</RelativeLayout>
</RelativeLayout>
ИЛИ все-в-одном
<?xml version="1.0" encoding="utf-8"?>
<layer-list xmlns:android="http://schemas.android.com/apk/res/android" >
<!--shadow to bottom and right-->
<!--by pushing offset from top and left-->
<item
android:left="2dp"
android:right="0dp"
android:top="2dp"
android:bottom="0dp">
<shape
android:shape="rectangle">
<solid android:color="@android:color/darker_gray" />
</shape>
</item>
<!--foreground-color to cover over non-shadow-->
<!--need to also offset in opposite direction-->
<item
android:left="0dp"
android:right="2dp"
android:top="0dp"
android:bottom="2dp">
<shape
android:shape="rectangle">
<solid android:color="@android:color/holo_orange_light"/>
</shape>
</item>
</layer-list>
in your cell.xml:
<RelativeLayout
android:layout_width="match_content"
android:layout_height="wrap_content"
android:background="@drawable/shadow_allinone">
<!--cell stuff-->
</RelativeLayout>
![введите описание изображения здесь]()