如何在XML drawable的中心绘制垂直形状

时间:2017-02-05 19:33:16

标签: android xml android-drawable xml-drawable

使用layer-list时,如何在XML drawable中绘制垂直线?我在drawable中声明了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/green"/>
        </shape>
    </item>

    <item android:top="0dp" android:left="1dp" android:bottom="0dp" android:right="5dp">
        <shape android:shape="rectangle">
            <size android:width="3dp"/>
            <solid android:color="@android:color/white"/>
        </shape>
    </item>
    <item android:top="0dp" android:left="5dp" android:bottom="0dp" android:right="1dp">
        <shape android:shape="rectangle">
            <size android:width="3dp"/>
            <solid android:color="@android:color/white"/>
        </shape>
    </item>
</layer-list>

当前结果

enter image description here

预期结果

enter image description here

2 个答案:

答案 0 :(得分:1)

<layer-list xmlns:android="http://schemas.android.com/apk/res/android">

<item
    android:width="16dp"
    android:left="15px">
    <shape
        android:shape="rectangle">
        <solid android:color="@color/colorAccent" />/>
        <size android:width="5dip" />
        <stroke android:color="@color/colorAccent" />
    </shape>
</item>
<item
    android:width="16dp"
    android:left="80px">

    <shape
        android:shape="rectangle">
        <solid android:color="@color/colorAccent" />/>
        <size android:width="5dip" />
        <stroke android:color="@color/colorAccent" />
    </shape>
</item>

<item
    android:width="16dp"
    android:left="140px">
    <shape
        android:shape="rectangle">
        <solid android:color="@color/colorAccent" />/>
        <size android:width="5dip" />
        <stroke android:color="@color/colorAccent" />
    </shape>
</item>

</layer-list>

答案 1 :(得分:0)

试试这个解决方案

抽拉/ shape.xml

<shape xmlns:android="http://schemas.android.com/apk/res/android"
android:shape="rectangle">
<solid android:color="@color/colorAccent" />/>
<size android:width="5dip" />
<stroke
    android:color="@color/colorAccent"
    />
</shape>

在布局文件中包含以下内容

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@+id/activity_main"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="horizontal">

<View
    android:layout_width="15dip"
    android:layout_height="wrap_content"
    android:layout_margin="@dimen/activity_horizontal_margin"
    android:background="@drawable/shape"></View>

<View
    android:layout_width="15dip"
    android:layout_height="wrap_content"
    android:layout_margin="@dimen/activity_horizontal_margin"
    android:background="@drawable/shape"></View>

<View
    android:layout_width="15dip"
    android:layout_height="wrap_content"
    android:layout_margin="@dimen/activity_horizontal_margin"
    android:background="@drawable/shape"></View>

</LinearLayout>

更改颜色并修复布局的边距。