Android按钮背景掩盖了按钮文本

时间:2014-09-20 21:14:08

标签: android xml button layout background

我有一个看起来像我想要的按钮。唯一的问题是它掩盖了文本。我知道它涵盖了它并且文本显示在它后面,因为如果我删除了android:background属性,则显示文本。

我的目标是让按钮在按钮顶部显示文字。

这是我的按钮:

<Button
    android:layout_width="match_parent"
    android:layout_height="65dp"
    android:layout_margin="30dp"
    android:background="@drawable/timecrunchbutton"
    android:text="Test"
    android:textColor="@color/white"/>

以及timecrunchbutton.xml:

<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android" >
    <item android:state_pressed="true" >
        <layer-list xmlns:android="http://schemas.android.com/apk/res/android">
            <!-- Top 1dp Shadow -->
            <item>
                <shape android:shape="rectangle">
                    <solid android:color="@color/blue" />
                    <corners android:radius="7dp" />
                </shape>
            </item>
            <!-- Light bottom color -->
            <item android:top="1dp">
                <shape android:shape="rectangle">
                    <solid android:color="@color/darkblue" />
                    <corners android:radius="7dp" />
                    <stroke android:width="1px" android:color="#248349"/>
                    <padding
                        android:top="28dp"
                        android:bottom="36dp" />
                </shape>
            </item>
        </layer-list>
    </item>
    <item>
        <layer-list xmlns:android="http://schemas.android.com/apk/res/android">
            <!-- Bottom 3dp Shadow -->
            <item>
                <shape android:shape="rectangle">
                    <solid android:color="@color/darkblue" />
                    <corners android:radius="7dp" />
                </shape>
            </item>
            <!-- Light top color -->
            <item android:bottom="3dp">
                <shape android:shape="rectangle">
                    <solid android:color="@color/blue" />
                    <corners android:radius="7dp" />
                    <stroke android:width="1px" android:color="#22A863"/>
                    <padding
                        android:top="36dp"
                        android:bottom="28dp" />
                </shape>
            </item>
        </layer-list>
    </item>
</selector>

2 个答案:

答案 0 :(得分:1)

尝试使用

机器人:layout_height =&#34; WRAP_CONTENT&#34;

在Button定义中而不是

机器人:layout_height =&#34; 65dp&#34;

答案 1 :(得分:0)

好吧,这可能听起来很愚蠢,但我觉得我也要问这个问题:你的@ drawable / timecrunchbutton是白色的吗?还是有很多白色?