使用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     ,        该分配是指按位运算。