颜色透明度转换技术文档(Android/Compose)

颜色透明度转换技术文档(Android/Compose)

1. 核心转换原理

透明度在十六进制中由 00(全透明)到 FF(不透明)表示。将百分比转换为十六进制的公式如下:

计算步骤:

  1. 百分比转小数:40%→0.440\% \rightarrow 0.440%→0.4
  2. 乘以 255:255×0.4=102255 \times 0.4 = 102255×0.4=102
  3. 转十六进制:102102102 的十六进制是 66

结果: #D9D9D9 的 40% 透明度版本即在色值对应位置加上 66。

2. 常见透明度速查表

开发时建议直接引用以下常用值,无需重复计算:

透明度百分比 十六进制 (Hex) 对应 Float (Compose)
100% FF 1.0f
80% CC 0.8f
75% BF 0.75f
50% 80 0.5f
40% 66 0.4f
20% 33 0.2f
10% 1A 0.1f
0% 00 0.0f

3. 平台差异与排列顺序

🟢 Android XML (colors.xml)

严格采用 #AARRGGBB 格式(Alpha 在最前)。

  • 写法:<color name="gray_40">#66D9D9D9</color>

🔵 Compose Color 对象

直接使用十六进制整数时,顺序也是 0xAARRGGBB。

  • 错误写法:Color(0xD9D9D966) ❌ (系统会将 D9 识别为透明度)
  • 正确写法:Color(0x66D9D9D9)

4. 最佳实践:Compose "保命"写法

为了避免因记忆 ARGB 或 RGBA 顺序出错,或者在从 Figma(通常 Alpha 在后)拷贝色值时翻车,强烈建议使用 .copy() 方法:

kotlin 复制代码
// 这种写法永远不会错,且可读性最高
val myColor = Color(0xFFD9D9D9).copy(alpha = 0.4f)

为什么推荐这种写法?

  1. 语义清晰:一眼就能看出基础色是 D9D9D9,透明度是 0.4。
  2. 减少计算:不需要去查表找 40% 对应的十六进制是 66。
  3. 动态友好:方便在代码中根据逻辑动态调整透明度(例如:color.copy(alpha = if(isPressed) 0.5f else 1.0f))。

5. 注意事项

  • 不写满 8 位会怎样? 在 Compose 中写 Color(0xD9D9D9) 会被视为 0x00D9D9D9,即全透明,导致 UI 隐形。
  • Figma 拷贝:Figma 导出的十六进制通常是 RRGGBBAA(透明度在后),直接粘贴到代码中必须手动将后两位移到最前面,或使用 .copy() 重新定义。
相关推荐
巴黎没有摩天轮Li2 小时前
Android JVMTI 接入流程
android
2501_915909063 小时前
iOS 抓包不越狱,代理抓包 和 数据线直连抓包两种实现方式
android·ios·小程序·https·uni-app·iphone·webview
城东米粉儿3 小时前
Android VCL 和 NAL笔记
android
常利兵3 小时前
从0到1,解锁Android WebView混合开发新姿势
android·华为·harmonyos
背包客(wyq)4 小时前
基于Android手机的语音数据采集系统(语音数据自动上传至电脑端)
android·网络
不止二进制4 小时前
从 0 到 1 理解 LinearLayout:Android 布局入门实战
android
不止二进制4 小时前
Android |FrameLayout 帧布局实战 ——NeonLamp 霓虹灯效果详解
android
stevenzqzq4 小时前
Kotlin 进阶指南:中缀函数 (Infix Function)
android·kotlin·compose