如何设置按钮的顶部描边?

3

我的问题非常简单,关于按钮属性的问题。 我想制作一个只有上边框的按钮。在布局xml文件中应该设置什么?

我的xml文件如下:

<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">
    <item android:state_enabled="false">
        <shape>
            <solid android:color="@android:color/transparent"/>
            <stroke android:width="1dp" android:color="@color/btn_disable"
                    android:dashWidth="1dp" android:dashGap="0dp"/>
            <padding android:left="9dp" android:top="2dp"
                     android:right="9dp" android:bottom="2dp"/>
            <corners android:radius="@dimen/btn_radius" />
        </shape>
    </item>
    <item android:state_pressed="true" >
        <shape>
            <solid android:color="@color/white_pressed"/>
            <stroke android:width="1dp" android:color="@color/mint"
                    android:dashWidth="1dp" android:dashGap="0dp"/>
            <padding android:left="9dp" android:top="2dp"
                     android:right="9dp" android:bottom="2dp"/>
            <corners android:radius="@dimen/btn_radius" />
        </shape>
          </item>
    <item>
        <shape>
            <solid android:color="@null"/>
            <stroke android:width="1dp" android:color="@color/mint"
                    android:dashWidth="1dp" android:dashGap="0dp" />
            <corners android:radius="@dimen/btn_radius" />
        </shape>
    </item>
</selector>
1个回答

3
我无法确定您所寻找的确切形状,但是如果您只想要顶端的笔画并隐藏所有其他笔画,则可以使用layer-list来实现。
<layer-list xmlns:android="http://schemas.android.com/apk/res/android" >
    <item>
        <shape android:shape="rectangle">

            <solid android:color="your_stroke_colour" />

            <corners
                android:radius="your_radius" />

        </shape>
    </item>
    <item
        android:top="1dp"
        android:bottom="0dp"
        android:left="0dp"
        android:right="0dp">
        <shape android:shape="rectangle">

            <solid android:color="your_color" />

            <corners
                android:radius="your_radius" />

        </shape>
    </item>
</layer-list>

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接