zoukankan      html  css  js  c++  java
  • [原创]ActionScript3游戏中的图像编程(连载十三)

    总目录: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) + 2552 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 修正后的反色效果

  • 相关阅读:
    ubuntu上virtualbox无法找到usb设备【解决】
    try or install Ubuntu on MeegoPad T01
    213. 打家劫舍 II
    198. 打家劫舍
    70. 爬楼梯
    62. 不同路径
    idea | gitee 码云
    数据库 | 远程连接centos7上数据库
    JSP && Servlet | 上传图片到数据库
    bootstrap | 模态框
  • 原文地址:https://www.cnblogs.com/iloveas/p/3888496.html
Copyright © 2011-2022 走看看