我试图了解颜色在Android中是如何工作的。我有这个颜色设置为我的线性布局的背景,我得到了一个灰色的背景和一些透明度:
<gradient android:startColor="#b4555555" android:endColor="#b4555555"
android:angle="270.0" />
如果我删除最后两个字符(55),我得到一个纯色,失去透明度。我试图找到一个页面,在那里我可以看到一些关于这个的解释,但我找不到。
我试图了解颜色在Android中是如何工作的。我有这个颜色设置为我的线性布局的背景,我得到了一个灰色的背景和一些透明度:
<gradient android:startColor="#b4555555" android:endColor="#b4555555"
android:angle="270.0" />
如果我删除最后两个字符(55),我得到一个纯色,失去透明度。我试图找到一个页面,在那里我可以看到一些关于这个的解释,但我找不到。
当前回答
在Android上,颜色可以指定为RGB或ARGB。
http://en.wikipedia.org/wiki/ARGB
在RGB中,每种颜色(红、绿、蓝)都有两个字符,在ARGB中,alpha通道有两个额外的字符。
如果你有8个字符,它是ARGB,前两个字符指定alpha通道。如果你去掉前面的两个字符,它只是RGB(纯色,没有alpha/透明度)。如果你想在你的Java源代码中指定一种颜色,你必须使用:
int Color.argb (int alpha, int red, int green, int blue)
alpha Alpha component [0..255] of the color
red Red component [0..255] of the color
green Green component [0..255] of the color
blue Blue component [0..255] of the color
参考:argb
其他回答
十六进制代码中的颜色被写成 # aa rr gg bb #阿尔法红绿蓝
对于每一组(AA,RR,GG,BB)可能的值为: -> 00 ~ FF的十六进制格式,即十进制形式0 ~ 255
所以要改变颜色的Alpha/AA/透明度,你只需要改变十六进制字符串中的前两个十六进制字符,这是由AA组表示的
对于50% -> 255 x 0.50= 128(约/四舍五入) 和转换 128转十六进制 = 08年
所以绿色#00FF00和50% Alpha/透明度将是#0800FF00
8位十六进制颜色值表示ARGB (Alpha, Red, Green, Blue),而6位值仅假设100%不透明度(完全不透明)并仅定义RGB值。所以要使它完全不透明,你可以使用#FF555555,或者只是#555555。每个2位十六进制值是一个字节,表示0-255之间的值。
在Android上,颜色可以指定为RGB或ARGB。
http://en.wikipedia.org/wiki/ARGB
在RGB中,每种颜色(红、绿、蓝)都有两个字符,在ARGB中,alpha通道有两个额外的字符。
如果你有8个字符,它是ARGB,前两个字符指定alpha通道。如果你去掉前面的两个字符,它只是RGB(纯色,没有alpha/透明度)。如果你想在你的Java源代码中指定一种颜色,你必须使用:
int Color.argb (int alpha, int red, int green, int blue)
alpha Alpha component [0..255] of the color
red Red component [0..255] of the color
green Green component [0..255] of the color
blue Blue component [0..255] of the color
参考:argb
使用这个表(我更喜欢把它放在colors.xml中,以便快速搜索)
<!--Percent to hex conversion table-->
<!--% 0 1 2 3 4 5 6 7 8 9-->
<!--0 00 03 05 08 0A 0D 0F 12 14 17-->
<!--1 19 1C 1F 21 24 26 29 2B 2E 30-->
<!--2 33 36 38 3B 3D 40 42 45 47 4A-->
<!--3 4D 4F 52 54 57 59 5C 5E 61 63-->
<!--4 66 69 6B 6E 70 73 75 78 7A 7D-->
<!--5 80 82 85 87 8A 8C 8F 91 94 96-->
<!--6 99 9C 9E A1 A3 A6 A8 AB AD B0-->
<!--7 B3 B5 B8 BA BD BF C2 C4 C7 C9-->
<!--8 CC CF D1 D4 D6 D9 DB DE E0 E3-->
<!--9 E6 E8 EB ED F0 F2 F5 F7 FA FC-->
在新的chrome版本(可能67.0.3396.62),CSS十六进制颜色可以使用这个模型显示,
eg:
div{
background-color:#FF00FFcc;
}
Cc是不透明度,但旧chrome不支持该mod