关闭 x
IT技术网
    技 采 号
    ITJS.cn - 技术改变世界
    • 实用工具
    • 菜鸟教程
    IT采购网 中国存储网 科技号 CIO智库

    IT技术网

    IT采购网
    • 首页
    • 行业资讯
    • 系统运维
      • 操作系统
        • Windows
        • Linux
        • Mac OS
      • 数据库
        • MySQL
        • Oracle
        • SQL Server
      • 网站建设
    • 人工智能
    • 半导体芯片
    • 笔记本电脑
    • 智能手机
    • 智能汽车
    • 编程语言
    IT技术网 - ITJS.CN
    首页 » 安卓开发 »正确使用 Android 的 Theme 和 Style

    正确使用 Android 的 Theme 和 Style

    2014-11-29 00:00:00 出处:eoe Android开发者社区
    分享

    Android 5.0 可以给一个 view 单独设置一个 theme 了,其主要用途就是用在 ToolBar 上, 比如 当前使用白色主题但是想使用黑色的 ToolBar ,只要在 ToolBar 的 xml 文件 中添加 android:theme=”@android:style/ThemeOverlay.Material.Dark.ActionBar” 即可。

    <Toolbar  
        android:layout_height=" android:attr/actionBarSize"
        android:layout_width="match_parent"
        android:theme="@android:style/ThemeOverlay.Material.Dark.ActionBar" />

    该功能在 5.0 之前也存在,只是无法单独在 View 上设置而已,比如 5.0之前的 Theme.Holo.Light.DarkActionBar 主题,就是白色主题但是 ActionBar 是黑色。这种底层实现方式是通过一个 actionBarWidgetTheme 来引入一个新的主题。

    <style name="Theme.Holo.Light.DarkActionBar">
        <item name="android:actionBarWidgetTheme">@android:style/Theme.Holo</item>
    </style>

    底层实现细节

    底层是通过 ContextThemeWrapper 类实现的,顾名思义该类所做的工作就是在当前 context 上装饰另外一个 theme,来覆盖(改变)一些控件的属性。

    因此,在 5.0 中又引入了一种新的 theme – ThemeOverlay ,主要有这么两种:

    ThemeOverlay.Material.Light ThemeOverlay.Material.Dark

    分别为 白色 和黑色的。把这两个 theme 装饰到 Theme.Material 上来修改部分的样式为白色或者黑色。同样,对于特殊的 ActionBar 而言,也有两个衍生出来的 ThemeOverlay theme:

    ThemeOverlay.Material.Light.ActionBar ThemeOverlay.Material.Dark.ActionBar

    这两个 theme 应该只使用在 5.0 的新 属性actionBarTheme 或者 Toolbar 上(上面的 xml 代码示例)。 这两个 theme 目前只是把 colorControlNormal 修改为android:textColorPrimary 的值并把所有的文字和图标都设置为不透明的。

    android:theme

    android:theme 是 5.0 中新添加到 View 上的属性。需要注意的是, 该属性会传递给所有子控件,例如:

    <LinearLayout
        android:theme="@android:style/ThemeOverlay.Material.Dark">
    
        <!--这里面的所有 view 都会使用 ThemeOverlay.Material.Dark theme,除非你在单独给某个 view 设置一个新的 theme 属性  -->
    
    </LinearLayout>

    5.0 还引入了一个新的 theme 属性: colorEdgeEffect ,该属性可以定制一个 View 过度滑动的(颜色)效果, 通过上面的 方式可以很容易的修改一个 View 的 过度滑动效果;

    由于这是一个 theme 里面的 属性,所以无法直接应用到 View 上,我们可以自定义一个 Overlay theme, 在里面设置 colorEdgeEffect 的值,然后在 View 上通过 android:theme 属性来设置这个自定义的 theme 即可。

    自定义theme res/values/themes.xml

    <style name=”RedThemeOverlay” parent=”android:ThemeOverlay.Material”>
    <item name=”android:colorEdgeEffect”>#FF0000</item>
    </style>

    然后把该 theme 设置到 view 上:

    <ListView … android:theme=”RedThemeOverlay” />

    通过上面同样的方式,您可以自定义所有 theme 里面的属性。

    Theme VS Style

    那么问题来了, Theme 和 Style 到底有啥区别呢? 他们的定义方式是一模一样的,只是使用的地方不一样而已。

    Theme 是用来设置应用全局 主题风格的, 5.0 上可以让你局部的调整设计风格;

    而 Style 主要是用在 View 上的,当你在 view 上设置 style 的时候,LayoutInflater 会读取 该 style 的内容并在任意单独设置的样式之前把该内容设置到 AttributeSet 中。

    总结起来就是: Theme 是全局的;Style 是局部的。

    需要注意的是,假如您使用 AppCompat V21 的话,当前 AppCompat 只能在android.support.v7.widget.Toolbar 上使用 Theme 属性。

    上一篇返回首页 下一篇

    声明: 此文观点不代表本站立场;转载务必保留本文链接;版权疑问请联系我们。

    别人在看

    正版 Windows 11产品密钥怎么查找/查看?

    还有3个月,微软将停止 Windows 10 的更新

    Windows 10 终止支持后,企业为何要立即升级?

    Windows 10 将于 2025年10 月终止技术支持,建议迁移到 Windows 11

    Windows 12 发布推迟,微软正全力筹备Windows 11 25H2更新

    Linux 退出 mail的命令是什么

    Linux 提醒 No space left on device,但我的空间看起来还有不少空余呢

    hiberfil.sys文件可以删除吗?了解该文件并手把手教你删除C盘的hiberfil.sys文件

    Window 10和 Windows 11哪个好?答案是:看你自己的需求

    盗版软件成公司里的“隐形炸弹”?老板们的“法务噩梦” 有救了!

    IT头条

    公安部:我国在售汽车搭载的“智驾”系统都不具备“自动驾驶”功能

    02:03

    液冷服务器概念股走强,博汇、润泽等液冷概念股票大涨

    01:17

    亚太地区的 AI 驱动型医疗保健:2025 年及以后的下一步是什么?

    16:30

    智能手机市场风云:iPhone领跑销量榜,华为缺席引争议

    15:43

    大数据算法和“老师傅”经验叠加 智慧化收储粮食尽显“科技范”

    15:17

    技术热点

    SQL汉字转换为拼音的函数

    windows 7系统无法运行Photoshop CS3的解决方法

    巧用MySQL加密函数对Web网站敏感数据进行保护

    MySQL基础知识简介

    Windows7和WinXP下如何实现不输密码自动登录系统的设置方法介绍

    windows 7系统ip地址冲突怎么办?windows 7系统IP地址冲突问题的

      友情链接:
    • IT采购网
    • 科技号
    • 中国存储网
    • 存储网
    • 半导体联盟
    • 医疗软件网
    • 软件中国
    • ITbrand
    • 采购中国
    • CIO智库
    • 考研题库
    • 法务网
    • AI工具网
    • 电子芯片网
    • 安全库
    • 隐私保护
    • 版权申明
    • 联系我们
    IT技术网 版权所有 © 2020-2025,京ICP备14047533号-20,Power by OK设计网

    在上方输入关键词后,回车键 开始搜索。Esc键 取消该搜索窗口。