我在MaterialButton
中有两个LinearLayout
,并且我会根据它们单击某个对象时切换到的内部状态来更改其背景颜色和文本颜色。它在棒棒糖以上的所有android版本中都能正常工作。当我在棒棒糖中切换颜色时,它们在所有Android版本中的初始状态都可以正常工作。
这是初始状态的照片。
Lollipop以上所有android版本中正确颜色的照片。
Android Lollipop当前发生的情况的照片。
我不知道是什么情况。我尝试了许多不同的方法,但没有任何一种有效。
这是布局文件的XML代码
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:orientation="horizontal">
<android.support.design.button.MaterialButton
android:id="@+id/handymanServicesButton"
style="@style/View.RoundedMaterialButton"
android:layout_width="0dp"
android:layout_height="wrap_content"
android:layout_margin="@dimen/margin_medium"
android:layout_weight="1"
android:elevation="16dp"
android:onClick="@{view::handymanServices}"
android:text="@{viewModel.isHandymanUser() ? @string/handyman_services_button_label : @string/main_button_label}"
android:textAllCaps="false"
android:textSize="@dimen/text_size_small"
tools:text="@string/handyman_services_button_label" />
<android.support.design.button.MaterialButton
android:id="@+id/otherButton"
style="@style/RoundedMaterialButtonNotSelected"
android:layout_width="0dp"
android:layout_height="wrap_content"
android:layout_margin="@dimen/margin_medium"
android:layout_weight="1"
android:elevation="16dp"
android:onClick="@{view::other}"
android:text="@string/other_button_label"
android:textAllCaps="false"
android:textSize="@dimen/text_size_small" />
</LinearLayout>
我应用于按钮的样式。
<style name="View.RoundedMaterialButton">
<item name="android:minHeight">@dimen/buttonHeight</item>
<item name="android:elevation">@dimen/cardElevation</item>
<item name="android:gravity">center</item>
<item name="rippleColor">@color/material_ripple_color</item>
<item name="cornerRadius">24dp</item>
<item name="android:textSize">14sp</item>
<item name="android:textStyle">bold</item>
<item name="backgroundTint">@color/colorAccent</item>
<item name="android:textAllCaps">true</item>
<item name="android:textColor">@android:color/white</item>
<item name="android:textAppearance">@style/TextAppearance.MaterialComponents.Button</item>
</style>
<style name="RoundedMaterialButtonNotSelected" parent="View.RoundedMaterialButton">
<item name="backgroundTint">@android:color/white</item>
<item name="android:textColor">@color/colorAccent</item>
</style>
片段中更改颜色的代码。
private fun handymanServicesUi() {
binding.handymanServicesButton.backgroundTintList =
ContextCompat.getColorStateList(requireContext(), R.color.colorAccent)
binding.otherButton.backgroundTintList =
ContextCompat.getColorStateList(requireContext(), android.R.color.white)
binding.handymanServicesButton.setTextColor(Color.WHITE)
binding.otherButton.setTextColor(
ContextCompat.getColor(requireContext(), R.color.colorAccent))
}
fun handymanServices(@Suppress("UNUSED_PARAMETER") view: View) {
handymanServicesUi()
viewModel.switchToHandymanServices()
}
private fun otherUi() {
binding.handymanServicesButton.backgroundTintList =
ContextCompat.getColorStateList(requireContext(), android.R.color.white)
binding.otherButton.backgroundTintList =
ContextCompat.getColorStateList(requireContext(), R.color.colorAccent)
binding.handymanServicesButton.setTextColor(
ContextCompat.getColor(requireContext(), R.color.colorAccent))
binding.otherButton.setTextColor(Color.WHITE)
}
fun other(@Suppress("UNUSED_PARAMETER") view: View) {
otherUi()
viewModel.switchToOthers()
}
答案 0 :(得分:1)
为文本和背景创建颜色状态选择器。对于文本的颜色,您可以执行以下操作:
<!-- under res/colors/handyman_text_color_selector.xml-->
<selector xmlns:android="http://schemas.android.com/apk/res/android">
<item android:color="@color/colorAccent" android:state_selected="true" />
<item android:color="@android:color/white" />
</selector>
对“ backgroundTint”执行相同的操作,例如handyman_button_color_selector.xml
接下来,将它们应用于布局并使用这些颜色选择器。 (最好将它们添加到样式中)
<android.support.design.button.MaterialButton
android:id="@+id/handymanServicesButton"
style="@style/View.RoundedMaterialButton"
android:textColor="@color/handyman_text_color_selector"
app:backgroundTint="@color/handyman_button_color_selector" />
最后在Kotlin中,只需切换两个按钮:
binding.handymanServicesButton.isSelected = !isSelected
binding.otherButton.isSelected = isSelected
也请查看此issue,它有类似的问题。