我正在开发Android应用程序并使用材料设计。
的AndroidManifest.xml
<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
package="com.app.android">
<application
android:allowBackup="true"
android:icon="@mipmap/ic_launcher"
android:label="@string/app_name"
android:roundIcon="@mipmap/ic_launcher_round"
android:supportsRtl="true"
android:theme="@style/AppTheme">
<activity android:name=".registration.RegistrationActivity">
<intent-filter>
<action android:name="android.intent.action.MAIN" />
<category android:name="android.intent.category.LAUNCHER" />
</intent-filter>
</activity>
</application>
</manifest>
styles.xml
<style name="AppTheme" parent="Theme.AppCompat.Light.NoActionBar">
<!-- Customize your theme here. -->
<item name="colorPrimary">@color/colorPrimary</item>
<item name="colorPrimaryDark">@color/colorPrimaryDark</item>
<item name="colorAccent">@color/colorAccent</item>
<item name="drawerArrowStyle">@style/DrawerArrowStyle</item>
<item name="android:textViewStyle">@style/RobotoTextViewStyle</item>
<item name="buttonStyle">@style/RobotoButtonStyle</item>
<!-- to change back button color to white -->
<item name="colorControlNormal">@android:color/white</item>
</style>
<style name="RobotoButtonStyle" parent="android:Widget.Holo.Button">
<item name="android:fontFamily">@font/lato_medium</item>
</style>
activity_registration.xml
<Button
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:paddingEnd="@dimen/default_view_padding_right"
android:paddingStart="@dimen/default_view_padding_left"
android:text="@string/registration_sign_up"
android:textColor="@android:color/white"
app:layout_constraintTop_toBottomOf="@id/til_registration_business_state" />
RegistrationActivity.kt
class RegistrationActivity : AppCompatActivity() {
override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
setContentView(R.layout.activity_registration)
}
}
有谁知道为什么材料设计背景颜色和反馈颜色没有设置在按钮上?
答案 0 :(得分:1)
您应该使用 android:theme
而不是 android:style
。
首先设置按钮父parent="Base.Widget.AppCompat.Button
唐&#39;吨
style="@style/RobotoButtonStyle"
待办事项
android:theme="@style/RobotoButtonStyle"
礼貌用于 Android Material Design Button Styles 。
对于特定按钮:
如果需要更改特定按钮的样式,可以定义新样式,继承上述父样式之一。在下面的示例中,我只更改了背景和字体颜色:
<style name="AppTheme.Button" parent="Widget.AppCompat.Button.Colored">
<item name="colorButtonNormal">@color/Red</item>
<item name="android:textColor">@color/White</item>
</style>
然后你只需要在按钮上应用这个新样式:
android:theme="@style/AppTheme.Button"
答案 1 :(得分:1)
(与支持库v7一起使用)
好的,只需替换
<style name="RobotoButtonStyle" parent="android:Widget.Holo.Button">
<item name="android:fontFamily">@font/lato_medium</item>
</style>
与
<style name="RobotoButtonStyle" parent="Widget.AppCompat.Button.Colored">
<item name="colorButtonNormal">@color/Accent</item>
<item name="android:textColor">@color/White</item>
<item name="android:fontFamily">@font/lato_medium</item>
</style>
,因为,您已经在<item name="buttonStyle">@style/RobotoButtonStyle</item>
设置了AppTheme
,而您的清单中的应用程序正在使用AppTheme
,这意味着您的应用程序中的每个按钮采用RobotoButtonStyle
。