zoukankan      html  css  js  c++  java
  • 滤镜的混合使用交通更信号灯

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    69
    70
    71
    72
    73
    74
    75
    76
    77
    78
    79
    80
    81
    82
    83
    84
    85
    86
    87
    88
    89
    90
    91
    92
    93
    94
    95
    96
    97
    98
    import flash.display.Shape;
    import flash.events.TimerEvent;
    import flash.filters.BitmapFilterQuality;
    import flash.filters.BitmapFilterType;
    import flash.filters.DropShadowFilter;
    import flash.filters.GlowFilter;
    import flash.filters.GradientBevelFilter;
    import flash.utils.Timer;
      
    var count:Number = 1;
    var distance:Number = 8;
    var angleInDegrees:Number = 225;// opposite of 45 degrees 
    var colors:Array = [0xFFFFCC, 0xFEFE78, 0x8F8E01];
    var alphas:Array = [1, 0, 1];
    var ratios:Array = [0, 128, 255];
    var blurX:Number = 8;
    var blurY:Number = 8;
    var strength:Number = 1;
    var quality:Number = BitmapFilterQuality.HIGH;
    var type:String = BitmapFilterType.INNER;
    var knockout:Boolean = false;
      
    // Draw the rectangle background for the traffic light. 
    var box:Shape = new Shape();
    box.graphics.lineStyle();
    box.graphics.beginFill(0xFEFE78);
    box.graphics.drawRect(100, 50, 90, 200);
    box.graphics.endFill();
      
    // Draw the 3 circles for the three lights. 
    var stopLight:Shape = new Shape();
    stopLight.graphics.lineStyle();
    stopLight.graphics.beginFill(0xFF0000);
    stopLight.graphics.drawCircle(145,90,25);
    stopLight.graphics.endFill();
      
    var cautionLight:Shape = new Shape();
    cautionLight.graphics.lineStyle();
    cautionLight.graphics.beginFill(0xFF9900);
    cautionLight.graphics.drawCircle(145,150,25);
    cautionLight.graphics.endFill();
      
    var goLight:Shape = new Shape();
    goLight.graphics.lineStyle();
    goLight.graphics.beginFill(0x00CC00);
    goLight.graphics.drawCircle(145,210,25);
    goLight.graphics.endFill();
      
    // Add the graphics to the display list. 
    addChild(box);
    addChild(stopLight);
    addChild(cautionLight);
    addChild(goLight);
      
    // Apply a gradient bevel to the traffic light rectangle. 
    var gradientBevel:GradientBevelFilter = new GradientBevelFilter(distance, angleInDegrees, colors, alphas, ratios, blurX, blurY, strength, quality, type, knockout);
    box.filters = [gradientBevel];
      
    // Create the inner shadow (for lights when off) and glow  
    // (for lights when on). 
    var innerShadow:DropShadowFilter = new DropShadowFilter(5, 45, 0, 0.5, 3, 3, 1, 1, true, false);
    var redGlow:GlowFilter = new GlowFilter(0xFF0000, 1, 30, 30, 1, 1, false, false);
    var yellowGlow:GlowFilter = new GlowFilter(0xFF9900, 1, 30, 30, 1, 1, false, false);
    var greenGlow:GlowFilter = new GlowFilter(0x00CC00, 1, 30, 30, 1, 1, false, false);
      
    // Set the starting state of the lights (green on, red/yellow off). 
    stopLight.filters = [innerShadow];
    cautionLight.filters = [innerShadow];
    goLight.filters = [greenGlow];
      
    // Swap the filters based on the count value. 
    function trafficControl(event:TimerEvent):void {
        if (count == 4) {
            count = 1;
        }
        switch (count) {
            case 1 :
                stopLight.filters = [innerShadow];
                cautionLight.filters = [yellowGlow];
                goLight.filters = [innerShadow];
                break;
            case 2 :
                stopLight.filters = [redGlow];
                cautionLight.filters = [innerShadow];
                goLight.filters = [innerShadow];
                break;
            case 3 :
                stopLight.filters = [innerShadow];
                cautionLight.filters = [innerShadow];
                goLight.filters = [greenGlow];
                break;
        }
        count++;
    }
    // Create a timer to swap the filters at a 3 second interval. 
    var timer:Timer = new Timer(3000, 9);
    timer.addEventListener(TimerEvent.TIMER, trafficControl);
    timer.start();




  • 相关阅读:
    单例模式
    js事件
    oracle_to_excel
    jquery_2
    jquery_1
    4.linux 复制,删除,重命名
    一个tomcat下部署多个springboot项目
    3.centos7 安装oracle
    桥接模式
    组合模式
  • 原文地址:https://www.cnblogs.com/babyhhcsy/p/2874968.html
Copyright © 2011-2022 走看看