AS3 CookBook学习整理(六)

1. 在位图上应用滤镜

使用BitmapData类的applyFilter()

destBmp.applyFilter(sourceBitmapData, sourceRect, destPoint, filter);

sourceBitmapData -- 要使用的输入位图图像。源图像可以是另一个BitmapData对象,也可以引用当前BitmapData实例

sourceRect -- 定义要用作输入的源图像区域的矩形

destPoint -- 目标图像(当前BitmapData实例)中与源矩形的左上角对应的点

filter -- 用于执行过滤操作的滤镜对象

如果 BitmapData 对象和指定为 sourceBitmapData 参数的对象是同一对象,应用程序将使用该对象的临时副本来执行滤镜。为了获得最佳性能,请避免这种情况

可以直接定义Bitmap.filters属性,它不会直接接触BitmapData的像素数据,因为滤镜只应用在包装BitmapData的Bitmap上

package {   
    import flash.display.Bitmap;   
    import flash.display.BitmapData;   
    import flash.display.Sprite;   
    import flash.events.Event;   
    import flash.filters.BlurFilter;   
    import flash.geom.Point;   
  
    public class Sample0319 extends Sprite   
    {   
        private var image:Bitmap;   
        private var blurFilter:BlurFilter;   
        private var point:Point;   
           
        public function Sample0319()   
        {   
            image = new Bitmap();   
            image.bitmapData = new BitmapData(stage.stageWidth,stage.stageHeight,false,0x000000);   
            this.addChild(image);   
               
            blurFilter = new BlurFilter();   
            point = new Point();   
               
            this.addEventListener(Event.ENTER_FRAME,onEnterFrame);   
        }   
           
        private function onEnterFrame(target:Event):void   
        {   
            for(var i:uint=0;i<100;i++)   
            {   
                image.bitmapData.setPixel(mouseX + Math.random()*20 - 10,   
                              mouseY + Math.random()*20 - 10,   
                              0xFFFFFF);       
            }   
            image.bitmapData.applyFilter(image.bitmapData,image.bitmapData.rect,point,blurFilter);   
        }   
    }   
}

2. 位图的淡出

使用BitmapData类的pixelDissolve()方法

seed = pixelDissolve(

sourceBitmapData:BitmapData, //要使用的源位图图像。源图像可以是另一个BitmapData对象,也可以是目标位图自身

sourceRect:Rectangle, //源位图区域的矩形(一般等于目标位图的大小)

destPoint:Point, //目标位图(当前BitmapData实例)中与源矩形的左上角对应的点

randomSeed:int = 0, //用于开始像素溶解的随机种子(第一次可随意定义)

numPixels:int = 0, //每次拷贝多少像素,默认值是源区域(宽度×高度)的1/30

fillColor:uint = 0 //一个ARGB颜色值,用于填充其原值等于目标值的像素(即目标位图淡出为该种颜色) ):int

* 该函数每次调用,都返回用于后续调用的新随机种子值

* 可以通过 已拷贝的像素总数 是否大于 位图宽度×位图高度,来判断是否拷贝完成

package {   
    import flash.display.Bitmap;   
    import flash.display.Loader;   
    import flash.display.LoaderInfo;   
    import flash.display.Sprite;   
    import flash.events.Event;   
    import flash.geom.Point;   
    import flash.net.URLRequest;   
  
    public class Sample0319 extends Sprite   
    {      
        private var imageSmall:Bitmap;   
        private var imageBig:Bitmap;   
        private var seed:uint;   
        private var pixelComplete:uint = 0;   
           
        public function Sample0319()   
        {   
            var loader:Loader = new Loader();   
            loader.load(new URLRequest("1.jpg"));   
            loader.contentLoaderInfo.addEventListener(Event.COMPLETE,onLoadSmallComplete);   
               
            loader = new Loader();   
            loader.load(new URLRequest("2.jpg"));   
            loader.contentLoaderInfo.addEventListener(Event.COMPLETE,onLoadBigComplete);   
           
            this.addEventListener(Event.ENTER_FRAME,onEnterFrame);   
        }   
           
        private function onLoadSmallComplete(event:Event):void   
        {   
            var tmp:LoaderInfo = event.target  as  LoaderInfo;   
            imageSmall = tmp.loader.content  as  Bitmap;   
            this.addChild(imageSmall);   
        }   
           
        private function onLoadBigComplete(event:Event):void   
        {   
            var tmp:LoaderInfo = event.target  as  LoaderInfo;   
            imageBig = tmp.loader.content  as  Bitmap;   
           //this.addChild(imageBig);  
           //imageBig.x = 200;    
        }   
           
        private function onEnterFrame(event:Event):void   
        {   
            if(imageSmall!=null && imageBig!=null)   
            {   
               //每次拷贝总像素的1%,如果是30帧播放的话,即1秒完成30%,全部完成要3秒左右    
                var numPixels:uint = imageSmall.bitmapData.width * imageSmall.bitmapData.height / 100;   
                   
                seed = imageSmall.bitmapData.pixelDissolve(   
                                                            imageBig.bitmapData,   
                                                            imageSmall.bitmapData.rect,   
                                                            new Point(),   
                                                            seed,   
                                                            numPixels);                                            
                pixelComplete += numPixels;   
                   
                if(pixelComplete > imageSmall.bitmapData.width * imageSmall.bitmapData.height)   
                {   
                    this.removeEventListener(Event.ENTER_FRAME,onEnterFrame);   
                }   
            }   
        }   
    }   
}

3. 滚动位图

使用BitmapData类的scroll(x,y)方法,将图像按一定量的(x,y)像素进行滚动。滚动区域之外的边缘区域保持不变

x -- 水平滚动量

y -- 垂直滚动量

package {   
    import flash.display.Bitmap;   
    import flash.display.BitmapData;   
    import flash.display.LoaderInfo;   
    import flash.display.Shape;   
    import flash.display.Sprite;   
    import flash.events.Event;   
  
    public class Sample0320 extends Sprite   
    {          
        private var image:Bitmap;   
           
        public function Sample0320()   
        {   
            var circle:Shape = new Shape();   
            circle.graphics.beginFill(0xFFFF00);   
            for(var i:int=20;i<200;i=i+20)   
            {   
                circle.graphics.drawCircle(i,i,10);   
            }   
            circle.graphics.endFill();   
           //this.addChild(circle);    
               
            image = new Bitmap();   
            image.bitmapData = new BitmapData(stage.stageWidth,stage.stageHeight,false,0x000000);   
            image.bitmapData.draw(circle);   
               
            this.addChild(image);   
               
            this.addEventListener(Event.ENTER_FRAME,onEnterFrame);   
        }   
           
        private function onEnterFrame(event:Event):void   
        {   
            if(image!=null)   
            {   
                image.bitmapData.scroll(-1,-1);   
            }      
        }   
    }   
}

4. 设置文本框的边框、背景与前景色

默认状态下,文本框的边框和背景都是禁用的。所以在设置之前需要先启用;前景色可直接设置。

边框 -- TextField.border = true; TextField.borderColor = 0xFF0000;

背景 -- TextField.background = true; TextField.backgroundColor = 0xFF0000;

前景色 -- TextField.textColor = 0xFF0000;

5. 设置文本框为可输入,不能选择及粘贴

设置TextField.type属性为TextFieldType.INPUT,可以将文本框定义为可输入。默认是TextFieldType.DYNAMIC(动态文本框,可以由ActionScript控制,但用户无法输入)

设置TextField.selectable = false,则文本字段中的文本不响应来自鼠标或键盘的选择命令,并且不能使用“复制”命令复制文本。默认为true

6. 设置文本框为密码输入框

设置TextField.displayAsPassword = true;

7. 限制文本输入

设置TextField.restrict,例如设置TextField.restrict = "abc",则只允许输入字符abc,以大写形式输入也会变成小写。

package {   
    import flash.display.Sprite;   
    import flash.text.TextField;   
    import flash.text.TextFieldType;   
  
    public class Sample0323 extends Sprite   
    {   
        public function Sample0323()   
        {   
            var text:TextField = new TextField();   
            text.type = TextFieldType.INPUT;   
            text.border = true;   
            text.borderColor = 0xFFFF00;   
            text.height = 20;   
               
            text.restrict = "a-z0-9";//允许a-z和0-9之间的字符    
           //text.restrict = "0-9^5"; //允许除了5以外的所有数字    
           //text.restrict = "^\u001A"; //不允许(Control-Z) 产生的字符(Unicode编码)    
           //text.restrict = "^\\-"; //特殊符号可通过(\\)进行转义    
               
            this.addChild(text);   
        }   
    }   
}

8. 限制文本框输入字符数

设置TextField.maxChars = 5,则为最大允许输入5个字符。如果设为null则表示不限制

9. 显示HTML格式文本

设置htmlText属性值为HTML内容

package {   
    import flash.display.Sprite;   
    import flash.text.TextField;   
    import flash.text.TextFieldType;   
  
    public class Sample0323 extends Sprite   
    {   
        public function Sample0323()   
        {   
            var text:TextField = new TextField();   
            text.type = TextFieldType.INPUT;   
            text.border = true;   
            text.borderColor = 0xFFFF00;   
            text.height = 20;   
               
            text.htmlText = "<a href='http://www.baidu.com/' target='_blank'><i><u>跳转到百度</u></i></a>";   
            text.appendText("增加的内容");   
                   
            this.addChild(text);   
        }   
    }   
}

10. 显示HTML文本时压缩空格

设置condenseWhite属性为true

package {   
    import flash.display.Sprite;   
    import flash.text.TextField;   
    import flash.text.TextFieldType;   
  
    public class Sample0323 extends Sprite   
    {   
        public function Sample0323()   
        {   
            var text:TextField = new TextField();   
            text.type = TextFieldType.INPUT;   
            text.border = true;   
            text.borderColor = 0xFFFF00;   
            text.height = 20;   
               
            text.condenseWhite = true;//必须在赋值前设置,否则无效    
            text.htmlText = "hello           world!";   
               
            this.addChild(text);   
        }   
    }   
}
posted @ 2010-07-15 15:09  CoderWayne  阅读(1181)  评论(0编辑  收藏  举报