Добавить только верхнюю и нижнюю границу LinearLayout

Я хотел бы добавить только нижнюю и верхнюю границу на моем Linearlayout. Я попытался сделать это :

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

<item
    android:bottom="1dp"
    android:top="1dp">
    <shape android:shape="rectangle">
        <solid android:color="#FFFFFF" />
        <stroke
            android:width="1dp"
            android:color="#000" />
    </shape>
</item>
</layer-list>

но он добавляет границу вокруг фигуры..

не могли бы вы помочь мне, пожалуйста ?

8 ответов


сделать два файла и поставить код. вы можете установить верхнюю и нижнюю границу границы,

main.в XML

<TextView
      android:text="This is textline"
      android:background="@drawable/border_set"
/>

border_set.в XML

этот файл расположен в полный путь project_root/res/drawable/border_set.xml

<?xml version="1.0" encoding="utf-8"?>
<layer-list xmlns:android="http://schemas.android.com/apk/res/android" >
    <item>
      <shape 
        android:shape="rectangle">
            <stroke android:width="1dp" android:color="#FF000000" />
            <solid android:color="#FFDDDDDD" />

        </shape>
   </item>

   <item android:top="1dp" android:bottom="1dp"> 
      <shape 
        android:shape="rectangle">
            <stroke android:width="1dp" android:color="#000" />
            <solid android:color="#FFFFFF" />
        </shape>
   </item>

</layer-list>

Я думаю, вы можете создать этот 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="#000"/>
        </shape>
    </item>
    <item android:bottom="1dp" android:top="1dp">
        <shape android:shape="rectangle" >
            <solid android:color="#FFFFFF" />
        </shape>
    </item>
</layer-list>

подумайте о том, как сначала нарисовать прямоугольник с цветом границы, а затем положить поверх него прямоугольник с цветом фона, оставляя 1dp сверху и снизу.


вот решение. Он работает даже с прозрачным фоном.

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

    <item android:left="-2dp"  android:right="-2dp">
        <shape android:shape="rectangle">
            <stroke android:width="2dp" android:color="@color/borderColor" />
            <solid android:color="@color/backgroundColor" />
        </shape>
    </item>

</layer-list>

быстрый способ достичь этого:

  • добавить текст в нижней и/или верхней части макета.
  • установите ширину TextView в "match_parent"
  • установите высоту TextView примерно в " 1dp " или найдите толщину, которую вы хотели бы
  • установите фон TextView в цвет, который вы хотели бы, чтобы граница была

надеюсь, это поможет!


моя версия такова, только видна граница сверху и снизу, не показывает границы слева или справа. И фон прозрачный.

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

<layer-list xmlns:android="http://schemas.android.com/apk/res/android" 
    android:layout_width="match_parent" 
    android:layout_height="1dp">

    <item
        android:left="-1dp"
        android:right="-1dp"
        android:top="-1dp"
        android:bottom="1dp">
        <shape
            android:shape="rectangle">
            <stroke
                android:width="1dp"
                android:color="@color/BlueGrey_colorPrimary" />
            <solid android:color="@android:color/transparent" />
        </shape>
    </item>

</layer-list>

Я считаю, что это самый простой способ:

<View
    android:layout_width="match_parent"
    android:layout_height="2dp"
    android:background="#000000" />


его простой. Нарисуй 3 фигуры такой.

<?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="@color/menu_line_separator_in" />
        </shape>
    </item>
    <item android:bottom="1.5dp">
        <shape android:shape="rectangle" >
            <solid android:color="@color/menu_line_separator_out" />
        </shape>
    </item>
    <item android:top="1.5dp">
        <shape android:shape="rectangle" >
            <solid android:color="@color/menu_line_separator_out" />
        </shape>
    </item>

</layer-list>