具有完全相同代码的按钮,产生两种不同的样式

Button with exactly the same code, produces two different styles

我有两组不同的按钮,一组在 activity 中,一组在列表视图中。它们具有非常相似的代码,但显示两种不同的样式。

头组按钮代码:

 <Button
        android:id="@+id/invoices_1year"
        android:layout_width="0dp"
        android:layout_height="fill_parent"
        android:layout_weight="0.2"
        android:onClick="refresh"
        android:text="@string/Invoices_1_year" />

而列表视图的按钮代码是:

<Button
    android:id="@+id/invoiceButton"
    android:layout_width="0dp"
    android:layout_height="wrap_content"
    android:layout_marginLeft="10dp"
    android:layout_weight="0.25"
    android:text="View Pdf" />

@ir2pid 的列表视图 Xml:

<ListView
    android:id="@+id/InvoiceList"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:layout_alignParentLeft="true"
    android:layout_alignParentStart="true"
    android:layout_below="@+id/searchArea" />

我在我的设备上得到的输出:

我的预期结果是两个按钮组看起来一样。

在 drawable 文件夹中创建 round.xml

<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android" >
    <item android:state_pressed="true" >
        <shape android:shape="rectangle"  >
            <corners android:radius="3dip" />
            <stroke android:width="1dip" android:color="#5e7974" />
            <gradient android:angle="-90" android:startColor="#e4d46f" android:endColor="#e4d079"  />
        </shape>
    </item>
    <item android:state_focused="true">
        <shape android:shape="rectangle"  >
            <corners android:radius="3dip" />
            <stroke android:width="1dip" android:color="#c7cf2d" />
            <solid android:color="#e9da67"/>
        </shape>
    </item>
    <item >
        <shape android:shape="rectangle"  >
            <corners android:radius="3dip" />
            <stroke android:width="1dip" android:color="#e7d851" />
            <gradient android:angle="-90" android:startColor="#e4d079" android:endColor="#87cf8d" />
        </shape>
    </item>
</selector>

并在按钮中添加

android:background="@drawable/round"

根据 Bala Raja 的回答,我找到了通用 material 设计按钮 xml 并将其修改为仅使用我指定的颜色。

这是我的round.xml

<inset xmlns:android="http://schemas.android.com/apk/res/android"
android:insetLeft="@dimen/abc_button_inset_horizontal_material"
android:insetTop="@dimen/abc_button_inset_vertical_material"
android:insetRight="@dimen/abc_button_inset_horizontal_material"
android:insetBottom="@dimen/abc_button_inset_vertical_material">

<shape android:shape="rectangle">

    <corners android:radius="@dimen/abc_control_corner_material" />
    <solid android:color="@color/ButtonGray" /> // My CUSTOM COLOR
    <padding android:left="@dimen/abc_button_padding_horizontal_material"
        android:top="@dimen/abc_button_padding_vertical_material"
        android:right="@dimen/abc_button_padding_horizontal_material"
        android:bottom="@dimen/abc_button_padding_vertical_material" />
</shape>

并在按钮 xml 中将背景更改为 android:background="@drawable/round"