我想去掉按钮的阴影,使它看起来更平坦。
我现在有这个:
但我想要的是:
我想去掉按钮的阴影,使它看起来更平坦。
我现在有这个:
但我想要的是:
当前回答
更新材料组件
如果你之前使用过这样的东西:
<style name="MyTheme" parent="Theme.AppCompat.Light.NoActionBar">
<item name="android:buttonStyle">@style/NoShadowButton</item>
</style>
<style name="NoShadowButton" parent="Widget.AppCompat.Button">
<item name="android:stateListAnimator">@null</item>
</style>
和我一样,你也在挠头,想知道为什么你已经迁移到了Theme.MaterialComponents.Light。*,这是因为buttonStyle只引用AppCompat按钮样式-有一个新的样式materialButtonStyle。这解决了我的问题:
<style name="MyTheme" parent="Theme.MaterialComponents.Light.NoActionBar">
<item name="materialButtonStyle">@style/Widget.MaterialComponents.Button.UnelevatedButton</item>
</style>
这里有一个很好的指南,告诉您还有哪些已经更改,以及如何正确迁移。
其他回答
使用这个作为你的按钮的背景可能会有所帮助,根据你的需要改变颜色
<?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">
<solid android:color="@color/app_theme_light" />
<padding
android:left="8dp"
android:top="4dp"
android:right="8dp"
android:bottom="4dp" />
</shape>
</item>
<item>
<shape android:shape="rectangle">
<solid android:color="@color/app_theme_dark" />
<padding
android:left="8dp"
android:top="4dp"
android:right="8dp"
android:bottom="4dp" />
</shape>
</item>
</selector>
我使用自定义样式
<style name="MyButtonStyle" parent="@style/Widget.AppCompat.Button.Borderless"></style>
别忘了加上
<item name="android:textAllCaps">false</item>
否则按钮文本将是大写的。
@Alt-Cat的答案对我有用!
r.t r. borderlessbuttonstyle不包含阴影。
按钮的文档很棒。
同样,你也可以在你的自定义按钮中,在第二个构造函数中设置这个样式。
public CustomButton(Context context, AttributeSet attrs) {
this(context, attrs, R.attr.borderlessButtonStyle);
}
它要求API级别为21
android:outlineProvider="none"
材质设计按钮添加到按钮xml: 风格= " @style / Widget.MaterialComponents.Button.UnelevatedButton”