这些Android系统样式中的颜色属性你知道吗?
Android 系统样式中的颜色属性
推荐阅读看完后彻底搞清楚Android中的 Attr 、 Style 、Theme
几个常用的颜色属性
先放上一张经典的图片,图片来自网络。
这张图在网上很是流传,也不知道当初是哪位大神标注的,很好的说明了 Android 系统中的几个常用的颜色属性的作用范围。
在开发者官网 R.attr 中给我们列出了所有的系统属性,我们可以在这里面找到对应的颜色属性所代表的意思。
通常我们新建一个项目的时候在 res/values/styles.xml 中会有下面的定义 Application 的主题样式。
<resource>
<!-- Base application theme. -->
<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>
</style>
</resource>
其实样式远远不止如此,在 Android 5.0 开始 Android 系统引入了 Material Design 风格,各个控件在这样主题下面,风格有很大的变化。为了在不同版本的系统中统一 UI 样式,设置自定义的 Theme 继承自 Theme.AppCompat 系列就可以了。
关于 AppCompat 相关主题提供的系统属性,可以参考源码:https://android.googlesource.com/platform/frameworks/support/+/400d2df7dfb0f72117b84854035829b6eaaf3150/v7/appcompat/res/values-v21/themes_base.xml
同时由于部分属性的版本兼容问题,为了避免添加多个版本的 styles 文件,可以省略 android: 命名空间
colorPrimary
App Bar 的背景颜色,也是一个 APP 的主色调。不过 ActionBar 已经不鼓励使用了,由 Toolbar 来代替,需要给 Toolbar 来设置背景颜色。
<android.support.v7.widget.Toolbar
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:background="?attr/colorPrimary" />
colorPrimaryDark
status bar(状态栏)的背景色,仅适用于 Android 5.0及其以上版本。也就是在这个版本你直接可以通过修改这个属性来修改状态栏的颜色。
colorAccent
许多控件在选中状态或者获取到焦点的时候会使用这个颜色,比如:
- CheckBox:checked 状态
- RadioButton:checked 状态
- SwitchCompat:checked 状态
- EditText:获取焦点的时候的下划线和光标颜色
- TextInputLayout:悬浮 label 字体颜色
- 等等
android:navigationBarColor
navigation bar 的背景色,仅用于 Android 5.0及其以上
colorControlNormal
某些 View 处于普通状态下的颜色。
比如:
没有被选中的 CheckBox 或者没有被选中的 RadioButton
失去焦点时的 EditText ,Toolbar 溢出按钮颜色
等等
colorControlActivated
在某些时候 colorControlActivated 是 colorAccent 的替代品。这种情况下 colorControlActivate 的颜色是会覆盖 colorAccent 的颜色的。也就是说,如果你没有设置的话默认的颜色就是 colorAccent 的颜色
比如:
- CheckBox 和 RadioButton 的 checked 状态
colorControlHightlight
所有可点击 View 触摸状态下的 Ripple 效果。仅对 Android 5.0 及其以上有效
colorButtonNormal
Button normal 状态下的背景色。
这种设置和 Button 的 android:background 所不同的是,在 Android5.0 或者更高的版本上使用 colorButtonNormal 的时候会依然保持阴影和 Ripple 触摸效果
android:windowBackground
窗口背景色,诸如此类还有 android:background android:colorBackground 等
android:textColorPrimary
APP 的主要文字颜色,比如 actionbar
文本的颜色,比如 Button 中的文本颜色,EditText 中的文本颜色,AlertDialog 中的文本颜色。但是不包括 TextView 中的文字颜色,TextView 中的文字颜色还需要 TextColor 来控制。
当然在设置了 TextColor 的话,TextColor 优先。
editTextColor:
默认 EditView 输入框字体颜色
TextColor
TextView 的文字颜色
更多查看这里
样式介绍
从 Android 5.0 开始,Android 系统引入了 Material Design风格。
md 的主题有:
- @android:style/Theme.Material(暗主题)
- @android:style/Theme.Material.Light(亮主题)
- @android:style/Theme.Material.Light.DarkActionBar
当然了为了兼容性,我们一般使用j兼容包里面的 Them.AppCompat 主题
与之对应的样式主要有 Them.AppCompat 和 ThemeOverlay.AppCompat ,当然他们两个又有各自的子类。
这两种样式也有不同的使用方法
Theme.AppCompat 一般用于设置整个应用程序的全局主题
ThemeOverlay.AppCompat 用于覆盖特定视图的主题,覆盖相关的属性使他们成为亮或者暗 尤其是在 Toolbar 中运用。
这样说可以不太容易明白,下面通过一个例子来说明。
比如说先我的整个 APP 的主题是这样的
<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>
</style>
默认的文字的颜色是黑的的,那么显示效果就会是这样的

这里使用了一个 Titlbar 这样效果和整体很不搭配,我们需要的是 Titlbar 的背景使用我们的 colorPrimary 字体的颜色使用 浅色文本样式 的颜色,那么这样我们就可以自己定义一个样式
<style name="sencond" parent="ThemeOverlay.AppCompat.Dark.ActionBar">
<item name="android:background">@color/colorPrimary</item>
</style>

<androidx.appcompat.widget.Toolbar
android:theme="@style/sencond"
app:title="@string/app_name"
android:layout_width="match_parent"
android:layout_height="wrap_content"/>
然后把这个样式给 Titlbar设置上,这样效果就合适了。
当然你自己完全可以用属性来自己完成。

这是 ThemOverlay 样式的全部样式了,每个样式里面的内容都很简单。就是修改一些最基本的属性,不像 Theme 一样里面有那么多的内容。
参考:https://juejin.im/post/58f8b651b123db006238dd8d
这些Android系统样式中的颜色属性你知道吗?的更多相关文章
- CSS覆盖公共样式中的某个属性
CSS如何覆盖公共样式中的某个属性?利用CSS样式的优先级. 如下例子: <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transition ...
- Android系统简介(中):系统架构
Android的系统架构栈分为4层,从上往下分别是Applications.Application framework.Libraries & Android Runtime.Linux ...
- 针对firefox ie6 ie7 ie8的css样式中的line-height属性
针对firefox ie6 ie7 ie8的css样式中的line-height属性 以前我们大部分都是用!important来hack,对于ie6和firefox测试可以正常显示,但是ie7以上对! ...
- 浅谈Android系统开发中LOG的使用
文章转载至CSDN社区罗升阳的安卓之旅,原文地址:http://blog.csdn.net/luoshengyang/article/details/6581828 在程序开发过程中,LOG是广泛使用 ...
- 浅谈Android系统开发中LOG的使用【转】
本文转载自:http://blog.csdn.net/luoshengyang/article/details/6581828 在程序开发过程中,LOG是广泛使用的用来记录程序执行过程的机制,它既可以 ...
- 在android系统调试中使用tinyalsa命令【转】
本文转载自:http://blog.csdn.net/tangdexi112/article/details/17579021 我们在进行音频调试的时候,需要使用tinymix.tinyplay.ti ...
- Notepad++中的颜色属性大全
Indent guideline style 缩进参考线的颜色 Brace highlight style 鼠标指针在框架左右时框架的颜色(如css中{} js中的()) Bad brace c ...
- Android系统更改状态栏字体颜色
随着时代的发展,Android的状态栏都不是乌黑一片了,在Android4.4之后我们可以修改状态栏的颜色或者让我们自己的View延伸到状态栏下面.我们可以进行更多的定制化了,然而有的时候我们使用的是 ...
- Notepad++中的颜色属性设置大全
Indent guideline style 缩进参考线的颜色Brace highlight style 鼠标指针在框架左右时框架的颜色(如css中{} js中的())Bad brace col ...
随机推荐
- Eclipse——关联源代码
Eclipse——关联源代码 摘要:本文主要说明了如何在Eclipse里关联源代码. 下载源码包 首先去想要关联的jar包的官网下载对应jar包的源代码,拿Tomcat的类库举例,先去官网下载源码包: ...
- 在kubernetes 集群内访问k8s API服务
所有的 kubernetes 集群中账户分为两类,Kubernetes 管理的 serviceaccount(服务账户) 和 useraccount(用户账户).基于角色的访问控制(“RBAC”)使用 ...
- Mysql 主从复制搭建-极简版
前言 自己在百度.Google一番踩坑搭建成功后,记录一下,也希望后来人不再被这些坑到. 这里为了方便使用 docker,不会的同学请移步相关 Docker 教程. 正文 1. 启动 mysql #启 ...
- IT兄弟连 HTML5教程 CSS3属性特效 新增颜色模式
对于设计人员和开发人员来说,CSS一直是web设计过程中重要的一部分.网页外观主要由CSS控制,编写CSS代码可以任意改变我们的网页布局以及网页内容的样式.随着CSS3的出现以及越来越多的浏览器对它的 ...
- soapUI 之 测试文件上传 [6]
在接口测试中会遇到需要上传文件的操作,比如头像修改等.那么soapui是怎么实现这部分测试的呢.以下以文件上传接口为例. 一.获取文件上传接口 可以通过开发直接提供的接口文档,或者自己抓包获取接口信息 ...
- JVM常用参数详解
JVM整个堆大小=年轻代大小 + 年老代大小 + 持久代大小,在JDK1.8及之后的版本由于永久代被元空间替代,所以jdk1.8中的堆=年轻代大小 + 年老代大小.本文使用的是JDK1.8 1.堆 ...
- Ligg.WinOa-000: Windows运维自动化编程实战--前言
本开源项目Ligg.WinOa是一个基于Ligg.EasyWinApp的Windows运维自动化应用.通过Ligg.EasyWinForm生成2个功能界面:管理员工具箱和用户工具箱:通过Lig ...
- angular cli + primeNG
目录: 1.安装 angular cli 2.创建项目 3.构建路由 4.新建组件 5.组件之间的通信 6.引入primeNG 7.修改primeNG组件样式 8.问题 -------------- ...
- vue引入ElementUI库
element国内网站:https://element.eleme.cn/#/zh-CN 引入ElementUI命令:npm install element-ui --save (网速不好用cnp ...
- QGIS 3.4 3.6 另存栅格图层到GeoPackage出现覆盖问题 解决方案
转载请声明:博客园 @秋意正寒 升级你的QGIS到3.8或以上 这在3.4.x和3.6.x都存在同样的问题.在老版本QGIS重,如果新建一个GeoPackage,先存入栅格数据就没有这个问题,但是如果 ...