总目录:http://www.cnblogs.com/iloveas/p/3879125.html
1.2.9 用ColorTransform实现反色效果
本节的最后,我给大家来一个稍稍有点意思的效果——反色。这种颠覆性的变换,线性的ColorTransform也能做到?答案是肯定的!所谓的反色,就是白变黑,黑变白,浅变深,深变浅,它的计算公式也非常简单,用100%减去原值就能得到结果色。即
1 dst = 255 – src;
套到ColorTransform的计算公式中,就有:
1 red(dst) = red(src) * (-1) + 255。 2 green(dst) = green(src) * (-1) + 255 3 blue(dst) = blue(src) * (-1) + 255
换而言之,只要将offset都设为255,multiplier都设成-1即可(可能有的童鞋还没想过将multiplier设置为负数吧)。
1 _myColorTransform.redMultiplier = -1; 2 _myColorTransform.greenMultiplier =-1; 3 _myColorTransform.blueMultiplier = -1; 4 _myColorTransform.redOffset = 255; 5 _myColorTransform.greenOffset = 255; 6 _myColorTransform.blueOffset = 255;
可出来的效果跟预期的不一致。(图 1.19)
图 1.19 反色效果
经过将近两周的纠结之后,我终于找到了问题的症结所在——跟BlendMode发生冲突了。因为BlendMode.ADD也是像素运算,两者混合后的运算机制以及优先级规则尚有待作进一步的研究。
把BlendMode.ADD一句去掉之后,反色效果跃然屏上。(图 1.20)
图 1.20 修正后的反色效果