Android的supportV7中默认按钮的颜色设置

Android的supportV7中默认按钮的颜色设置,第1张

我们知道,在styles.xml文件里面可以设置主题,在主题中设置的一些颜色,将会应用到默认的AppCompat控件上,从而很简单的就可以保持整个APP在UI上的一致性。下面是一个例子:

至于各种控件是如何应用这些颜色设置的,则需要经过更多的尝试了。

比如Activity导航栏默认的图标颜色是colorControlNormal,导航栏的底色是colorPrimary,沉浸式状态栏默认的颜色是colorPrimaryDark;

比如FAB的默认颜色是colorAccent;

比如AppCompatCheckBox默认的选中状态的颜色是colorAccent,而默认的未选择状态的颜色的colorControlNormal;

比如AppCompatSpinner的下拉图标的默认颜色也是colorControlNormal。

......

其实涉及到的主要的就是下面这几个参数:

那么问题来了,如果你使用蓝色的沉浸式状态栏,导航栏上的图标则使用白色,那在这个Activity中使用AppCompatCheckBox的时候,未选择状态就也是白色的,此时如果在白色的背景色下,用户就看不出这是个AppCompatCheckBox了。这时候怎么办?如下图(图中使用的是AppCompatSpinner):

其实很简单,在这个AppCompatCheckBox上使用app:theme="@style/MyCheckBox",然后在styles.xml中添加新的

但是需要注意的是,这样可能引起控件其他默认属性的变化,比如CheckBox的textSize会变成1(不使用app:theme的时候和APP的默认字体大小一样)。

android:theme和app:popupTheme的作用,以及在android 3.0以下不起作用问题的解决

可以用代码设置替换Button的背景颜色

btn.setBackgroundDrawable(getResources().getDrawable(R.drawable.图片的路径))

android点击以后改变button的颜色的方法为:

1、新建 drawable/button_font_style.xml

<?xml version="1.0" encoding="utf-8"?>

<selector xmlns:android="http://schemas.android.com/apk/res/android">

<item android:state_pressed="true" android:color="#fff"/>

<item android:state_focused="true" android:color="#fff"/>

<item android:color="#000" />

</selector>

2、添加至需要的xml里即可

<android:textColor="@drawable/button_font_style">


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/tougao/11102757.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-13
下一篇 2023-05-13

发表评论

登录后才能评论

评论列表(0条)

保存