Как показать разделитель между элементами прядильщика?

Я использую listviews и расширенные представления, у которых есть разделители, и я могу их установить, но на spinner его внешний вид выглядит как разделитель между элементами.

Кто-нибудь, у кого есть идея, как это исправить?

Ответ 1

Для людей с одинаковой проблемой, я чуть не поднялся, я получил представление о том, как получить разделитель.

Я добавил разделительную линию в нижней части моего пользовательского макета для каждого элемента

<?xml version="1.0" encoding="utf-8"?>

<RelativeLayout android:id="@+id/RelativeLayout01"
    android:layout_width="fill_parent" android:layout_height="fill_parent"
    xmlns:android="http://schemas.android.com/apk/res/android" style="@style/ListItem2">

    <TextView android:id="@+id/Text" android:layout_width="fill_parent"
        android:layout_height="wrap_content" android:layout_alignParentLeft="true"
        style="@style/SpinnerView_Text" android:paddingLeft="10dip" />

    <ImageView android:id="@+id/icon" android:layout_width="wrap_content"
        android:layout_height="wrap_content" android:src="@drawable/arrowright"
        android:layout_alignParentRight="true" android:layout_centerInParent="true"
        android:layout_marginRight="20dip" />

</RelativeLayout>

<ImageView android:id="@+id/Divider1" android:layout_width="fill_parent"
    android:layout_height="1dip" style="@style/Divider"></ImageView>

Ответ 2

Мне удалось найти более подходящее решение для этой проблемы (без включения разделителя в макет одного элемента).

Что вам нужно сделать, это определить в своей теме действия

        <item name="android:dropDownListViewStyle">@style/App.Style.Spinner</item>

а затем создайте правильный стиль с помощью

   <style name="App.Style.Spinner" parent="@style/Widget.Sherlock.Light.ListView.DropDown">
           <item name="android:dividerHeight">10dip</item>
           <item name="android:divider">@drawable/mydivider</item>
   </style>

Ответ 3

Это сработало для меня:

<style name="SpinnerStyle" parent="Widget.AppCompat.ListView.DropDown">
        <item name="android:divider">#d1d1d1</item>
        <item name="android:dividerHeight">0.5dp</item>
    </style>

<style name="AppTheme" parent="Theme.AppCompat.Light.DarkActionBar">
        <!-- Customize your theme here. -->
        <item name="android:dropDownListViewStyle">@style/SpinnerStyle</item>

Преимущество использования этого заключается в том, что он не удаляет эффект пульсации при наведении.

Ответ 4

Основываясь на ответе @Talihawk, я заставил его работать только для конкретного. Вместо того, чтобы настраивать тему своей деятельности, задайте тему непосредственно для просмотра spinner:

<style name="MatchSpinnerStyle" parent="android:style/Widget.ListView.DropDown">
    <item name="android:divider">#123456</item>
    <item name="android:dividerHeight">1dp</item>
</style>

<style name="MatchSpinnerTheme" parent="AppTheme">
    <item name="android:dropDownListViewStyle">@style/MatchSpinnerStyle</item>
</style>

и

<android.support.v7.widget.AppCompatSpinner
    android:layout_width="match_parent"
    android:layout_height="wrap_content"        
    android:theme="@style/MatchSpinnerTheme"/>