Як змінити колір лінії роздільника Android ListView?


400

Я хочу змінити колір ListViewрозділової лінії. Будь-яка допомога буде вдячна.

Відповіді:


765

Ви можете встановити це значення у файлі xml-макета, використовуючи android:divider="#FF0000". Якщо ви змінюєте колір / малюнок, вам також потрібно встановити / скинути висоту дільника.

<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="#FFCC00"
    android:dividerHeight="4px"/>

</LinearLayout>

11
Ви також повинні мати можливість вказати Drawableресурс android:divider. Існуючий дільник є градієнтом.
CommonsWare

62
Якщо ви зробите це в XML, переконайтеся, що висоту також використовуєте android: delierHeight, інакше ви не отримаєте жодної лінії
Ерік Новінс

8
З мого досвіду, читайте "слід скинути висоту дільника" на "повинен встановити висоту дільника"
dpjanes

44
Я б не рекомендував використовувати pxблок для визначення розмірів в Android, скористайтеся dpнатомість
Марек Себера

12
Схоже, може бути вагомий привід використовувати px в цьому конкретному випадку. Див: stackoverflow.com/a/12061612/10505
greg7gkb

163

Або ви можете кодувати це:

int[] colors = {0, 0xFFFF0000, 0}; // red for the example
myList.setDivider(new GradientDrawable(Orientation.RIGHT_LEFT, colors));
myList.setDividerHeight(1);

Сподіваюся, це допомагає


Ідеально, мої предмети були на тлі червонуватого градієнта, і ваш ефект зробив їх чудовими !!
Даркендорф

1
якщо ви продовжите ListActivity, замініть мій список на getListView ()
Азіз

87

Для однієї кольорової лінії використовуйте:

list.setDivider(new ColorDrawable(0x99F10529));   //0xAARRGGBB
list.setDividerHeight(1);

Важливо, що DividerHeight встановлюється після дільника , інакше ви нічого не отримаєте.


1
Дякую, я зателефонував до setDividerHeight () перед setDivider (), і роздільник не показаний.
Андреас Кльобер

3
Дуже корисний коментар щодо порядку операцій. Я просто провів 2 години, намагаючись змусити його працювати. Гарний дизайн, Android.
Нік Фролов

12

Ви також можете отримати кольори зі своїх ресурсів, використовуючи:

dateView.setDivider(new ColorDrawable(_context.getResources().getColor(R.color.textlight)));
dateView.setDividerHeight(1);

10

Версія XML для класного ефекту @Asher Aslan

<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android" >

    <gradient
        android:angle="180"
        android:startColor="#00000000"
        android:centerColor="#FFFF0000"
        android:endColor="#00000000"/>

</shape>

Ім'я для цієї форми як: list_driver.xml у папці, що виводиться

<ListView
        android:id="@+id/category_list"
        android:layout_width="fill_parent"
        android:layout_height="fill_parent" 
        android:divider="@drawable/list_driver"
        android:dividerHeight="5sp" />

6

Є два способи зробити те саме:

  1. Ви можете встановити значення android: delier = "# FFCCFF" у макеті xml-файлу. З цим вам також потрібно вказати висоту дільника на зразок цього андроїда: delierHeight = "5px ".

    <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent">
    
      <ListView 
      android:id="@+id/lvMyList"
      android:layout_width="match_parent"
      android:layout_height="match_parent"
      android:divider="#FFCCFF"
      android:dividerHeight="5px"/>
    
    </LinearLayout>
  2. Ви також можете це зробити програмно ...

    ListView listView = getListView();
    ColorDrawable myColor = new ColorDrawable(
        this.getResources().getColor(R.color.myColor)
    );
    listView.setDivider(myColor);
    listView.setDividerHeight();

2

Використовуйте код нижче у своєму XML-файлі

<ListView 
    android:id="@+id/listView"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:divider="#000000" 
    android:dividerHeight="1dp">
</ListView> 

2
Краще трохи пояснити, чому працює ваше рішення. Тільки відповіді з кодом можуть вирішити проблему, але це не обов'язково відповідає на запитання запитувача.
SuperBiasedMan

1

використовуючи програмно

           // Set ListView divider color
            lv.setDivider(new ColorDrawable(Color.parseColor("#FF4A4D93")));

            // set ListView divider height
            lv.setDividerHeight(2);

використовуючи xml

<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="#44CC00"
    android:dividerHeight="4px"/>

</LinearLayout>

0

Використовуйте android:divider="#FF0000"і android:dividerHeight="2px"для ListView.

<ListView 
android:id="@android:id/list"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:divider="#0099FF"
android:dividerHeight="2px"/>
Використовуючи наш веб-сайт, ви визнаєте, що прочитали та зрозуміли наші Політику щодо файлів cookie та Політику конфіденційності.
Licensed under cc by-sa 3.0 with attribution required.