我想了解下面的代码,其中b
是给定的整数,image
是图像。
据我所知,如果给定点i,j的RGB值大于b,则将该像素设置为白色,否则设置为黑色。所以会将图像转换为黑白图像。
然而我迷失了什么(& 0xff)实际上,我猜它是一种二元转换?
if ((image.getRGB(i, j) & 0xff) > b) {
image.setRGB(i, j, 0xffffff) ;
} else {
image.setRGB(i, j, 0x000000);
}
答案 0 :(得分:42)
这是一个所谓的面具。问题是,您将RGB值全部放在一个整数中,每个组件都有一个字节。类似于0xAARRGGBB(alpha,red,green,blue)。通过按位执行并使用0xFF,您只保留最后一部分,即蓝色。对于其他频道,您可以使用:
int alpha = (rgb >>> 24) & 0xFF;
int red = (rgb >>> 16) & 0xFF;
int green = (rgb >>> 8) & 0xFF;
int blue = (rgb >>> 0) & 0xFF;
在alpha情况下,您可以跳过& 0xFF
,因为它不会执行任何操作;同样在蓝色情况下移位0。
答案 1 :(得分:12)
在
& 0xFF
正在获取其中一个颜色成分(红色或蓝色,我忘了哪个)。
如果未执行颜色掩码,请考虑RGB(0,127,0)和阈值63. getRGB(...)调用将返回
(0 * 256 * 256) + (127 * 256) + 0 = 32512
这显然超过了阈值63.但目的是忽略其他两个颜色通道。位掩码只得到最低的8位,为零。
在
> b
正在检查颜色是否比特定阈值亮,'b'。
如果超过阈值,则使用
将像素设为白色image.setRGB(i,j,0xffffff)
...否则使用
将其涂成黑色image.setRGB(i,j,0x000000)
因此,它是基于单个颜色通道上的简单逐像素阈值转换为黑白。
答案 2 :(得分:5)
颜色表示
RGB值是一个整数,因此它在内存中用4个字节(或等价的32位)表示。
示例:
00000001 00000010 00000011 00000100
每个字节代表颜色的一个组成部分:
0xff和0xffffff符号
0xff表示十六进制值FF,它等于整数255.其二进制表示为:
00000000 00000000 00000000 11111111
类似地,0xffffff表示为:
00000000 11111111 11111111 11111111
它对应于白色(红色,绿色和蓝色等于255)。
<强>&安培;操作强>
二元运算符和“&amp;”应用于两个整数i1和i2(i1和i2)。它返回一个整数,其所有位等于0,除了i1和i2中等于1的整数。 例如,如果我们申请&amp;在我的第一个例子和0xff上,我们得到:
00000000 00000000 00000000 00000100
因此,(&amp; 0xff)只能保留最后一个字节的值(即颜色的蓝色分量的值)。
// If the blue component of image.getRGB(i, j) is greater than b
if ((image.getRGB(i, j) & 0xff) > b) {
// Set the image to white
image.setRGB(i, j, 0xffffff) ;
} else {
// Set the image to black
image.setRGB(i, j, 0x000000);
}
答案 3 :(得分:4)
可能是因为有一些转换到ARGB或从ARGB转换。 This is a really good blog post关于为什么要对颜色进行逐位操作。
答案 4 :(得分:0)
& 0xff
是按位AND
(image.getRGB(i,j)&0xff)
获取getRGB
> b
部分返回的rgb编码int的蓝色值,检查它是否大于某个阈值