如何解决使用xor将颜色与像素分开
| 我正在做普林斯顿挑战,在下一页http://www.cs.princeton.edu/courses/archive/fall10/cos126/assignments/lfsr.html遇到了我不明白的一行,线正好在管道的第一张图片下方。 对于每个像素(x,y),以(0,0),(0,1),(0,2),...的顺序提取颜色的红色,绿色和蓝色分量(每个分量为0到255之间的整数)。 然后,将红色分量与8个新生成的位进行异或。对绿色(使用另外8个新生成的位),最后对蓝色执行相同的操作。 使用“异或”运算的结果创建新颜色,并将像素设置为该颜色。 我不太确定3次异或运算后如何创建新的颜色,因为异或运算只会产生一个真值或假值。解决方法
不,您正在将8位颜色分量值与另一个8位值异或,如下所示:
1010 1010
xor 1111 0000
---- ----
0101 1010
当单个“ 1”在两个位上运算以产生另一个位时,对多位值执行该操作意味着依次对每个位执行该操作。
另请参阅此答案。
, 布尔(逻辑)运算中的异或只返回true或false,但是您也可以使用按位异或。在这种情况下,数字中的每个位(在这种情况下为8位值)都将被视为布尔值。这将导致8个新位为true或false,从而返回一个新的8位值。这三者的总和将为您带来rgb值。
, 我认为这是按位XOR,将颜色转换为二进制,然后对每个数字进行XOR以获得结果。例如00001111 XOR 11111111 = 11110000
,
因为异或运算只会产生true或false的值。
您的陈述不正确。例如:
1110 xor 1001 = 0111
有关更多信息,请参见:http://en.wikipedia.org/wiki/Bitwise_operation#XOR
,
我不太确定新的颜色怎么能
经过3次异或运算后创建,
因为异或运算只会
产生一个真或假值。
在这种情况下,异或会逐位操作。因此结果是1或0,但每一位。
1111 1111异或
1010 1010 =
0101 0101
, 该分配是指按位运算。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。