首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >理解菜单图标颜色的来源

理解菜单图标颜色的来源
EN

Stack Overflow用户
提问于 2019-09-30 18:22:10
回答 2查看 316关注 0票数 2

我目前正在搜索GoogleIO2019的源代码,有一件事我不知道它从何而来:汉堡包菜单图标的颜色。

以下是mobile\src\main\res\layout\fragment_codelabs.xml (源链接)预览的屏幕截图:

这是一个放大的汉堡包菜单图标,可以很容易地看到它至少不是黑色的:

图像源是@drawable/ic_menu

@drawable/ic_menu(mobile\src\main\res\drawable\ic_menu.xml) (源链接)的源代码是

代码语言:javascript
复制
<vector xmlns:android="http://schemas.android.com/apk/res/android"
    android:width="24dp"
    android:height="24dp"
    android:viewportWidth="24.0"
    android:viewportHeight="24.0"
    android:tint="?colorControlNormal">
    <path
        android:fillColor="#FF000000"
        android:pathData="M3,18h18v-2L3,16v2zM3,13h18v-2L3,11v2zM3,6v2h18L21,6L3,6z" />
</vector>

在这里,fillColor被指定为#FF000000,它是100 %的黑色和不透明的(alpha FF)。然而,汉堡包菜单图标并没有以黑色显示。那么,汉堡包菜单图标所显示的颜色在哪里呢?

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2019-09-30 20:41:13

我试图深入挖掘样式,很可能它来自活动主题的父主题之一的默认参数。我会试着展示一下我是怎么找到的。

  1. \mobile\src\main\AndroidManifest.xml文件中,所有活动都是从android:theme="@style/AppTheme"继承的。
  2. <style name="AppTheme" parent="Base.AppTheme" />
  3. <style name="Base.AppTheme" parent="Theme.MaterialComponents.DayNight.NoActionBar">
  4. <style name="Theme.MaterialComponents.DayNight.NoActionBar" parent="Theme.MaterialComponents.Light.NoActionBar"/>
  5. <style name="Theme.MaterialComponents.Light" parent="Base.Theme.MaterialComponents.Light"/>
  6. <style name="Base.Theme.MaterialComponents.Light" parent="Base.V14.Theme.MaterialComponents.Light"/>
  7. <style name="Base.V14.Theme.MaterialComponents.Light" parent="Base.V14.Theme.MaterialComponents.Light.Bridge">
  8. <style name="Base.V14.Theme.MaterialComponents.Light.Bridge" parent="Platform.MaterialComponents.Light">
  9. <style name="Platform.MaterialComponents.Light" parent="Theme.AppCompat.Light"/>
  10. <style name="Theme.AppCompat.Light" parent="Base.Theme.AppCompat.Light"/>
  11. <style name="Base.Theme.AppCompat.Light" parent="Base.V28.Theme.AppCompat.Light"/>
  12. <style name="Base.V28.Theme.AppCompat.Light" parent="Base.V26.Theme.AppCompat.Light">
  13. <style name="Base.V26.Theme.AppCompat.Light" parent="Base.V23.Theme.AppCompat.Light">
  14. <style name="Base.V23.Theme.AppCompat.Light" parent="Base.V22.Theme.AppCompat.Light">
  15. <style name="Base.V22.Theme.AppCompat.Light" parent="Base.V21.Theme.AppCompat.Light">
  16. <style name="Base.V21.Theme.AppCompat.Light" parent="Base.V7.Theme.AppCompat.Light">
  17. 在这里你可以看到,我们离<item name="android:colorControlNormal">?attr/colorControlNormal</item>很近,我们需要走得更远。
  18. <style name="Base.V7.Theme.AppCompat.Light" parent="Platform.AppCompat.Light">
  19. 这就是<item name="colorControlNormal">?android:attr/textColorSecondary</item> :)
  20. 但是,我们可以更进一步,直到我们到达<style name="Theme.Material.Light" parent="Theme.Light">
  21. <item name="textColorSecondary">@color/text_color_secondary</item>
  22. text_color_secondary.xml <selector xmlns:android="http://schemas.android.com/apk/res/android"> <item android:state_enabled="false" android:alpha="?attr/disabledAlpha" android:color="?attr/colorForeground"/> <item android:alpha="?attr/secondaryContentAlpha" android:color="?attr/colorForeground"/> </selector>
  23. <item name="colorForeground">@color/foreground_material_light</item>
  24. colors_material.xml中,它是<color name="foreground_material_light">@color/black</color>
  25. 阿尔法是<item name="secondary_content_alpha_material_light" format="float" type="dimen">0.54</item>

因此,简单地说:菜单图标的颜色是默认主题黑色alpha 0.54

票数 2
EN

Stack Overflow用户

发布于 2019-09-30 18:39:36

在下面的xml文件中,它们设置appbar的样式。

mobile\src\main\res\layout\fragment_codelabs.xml ((来源) )

代码语言:javascript
复制
    style="@style/Widget.IOSched.AppBar"

如果您打开移动/src/main/res/value/contentes.xml 来源,您可以发现这种样式的定义,在整个应用程序中通常使用通用的样式来保持一致性,而不是一次性的TextViewStyle/Size/Design。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/58173259

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档