Я столкнулся с этой проблемой с ICS / JB, потому что кнопки по умолчанию для темы Holo состоят из слегка прозрачных изображений. Для фона это особенно заметно.
Пряник против ICS +:
Копировать все нарисованные состояния и изображения для каждого разрешения и сделать прозрачные изображения сплошными - это боль, поэтому я выбрал более грязное решение: заверните кнопку в держатель с белым фоном. Вот грубая отрисовка XML (ButtonHolder), которая делает именно это:
Ваш XML-файл
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
style="@style/Content">
<RelativeLayout style="@style/ButtonHolder">
<Button android:id="@+id/myButton"
style="@style/Button"
android:text="@string/proceed"/>
</RelativeLayout>
</LinearLayout>
ButtonHolder.xml
<?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/white"/>
</shape>
</item>
</layer-list>
styles.xml
.
.
.
<style name="ButtonHolder">
<item name="android:layout_height">wrap_content</item>
<item name="android:layout_width">wrap_content</item>
<item name="android:background">@drawable/buttonholder</item>
</style>
<style name="Button" parent="@android:style/Widget.Button">
<item name="android:layout_height">wrap_content</item>
<item name="android:layout_width">wrap_content</item>
<item name="android:textStyle">bold</item>
</style>
.
.
.
Однако это приводит к появлению белой границы, потому что изображения кнопок Holo включают поля для учета нажатого пространства:
Таким образом, решение состоит в том, чтобы дать белому фону запас (4дп работал для меня) и закругленные углы (2дп), чтобы полностью скрыть белый цвет, но сделать кнопку сплошной:
ButtonHolder.xml
<?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="@android:color/transparent"/>
</shape>
</item>
<item android:top="4dp" android:bottom="4dp" android:left="4dp" android:right="4dp">
<shape android:shape="rectangle">
<solid android:color="@color/white"/>
<corners android:radius="2dp" />
</shape>
</item>
</layer-list>
Окончательный результат выглядит следующим образом:
Вы должны выбрать этот стиль для v14 +, а также настроить или исключить его для Gingerbread / Honeycomb, потому что размеры их собственных кнопок отличаются от ICS и JB (например, этот точный стиль за кнопкой Gingerbread приводит к появлению небольшого белого цвета под кнопка).