Flash AS学习:mx.utils包之Delegate类应用

  关于Delegate类,可以在Flash的安装目录中找到。Delegate顾名思义就是代理,呵呵不是顾名思义,应该是翻译,哈哈。这个类就是要代理,呵呵,那么如何代理呢?这里有一个例子:
1、 创建一个新的Fla文档,然后在第一帧的脚本中定义一个函数:
function showHeart()
{
trace("I Love U ,my Little Leaf");
}2、 然后创建一个MC,在这个MC的第一帧创建一个函数,并使用代理调用,这是代码:
function showAgain ()

{

trace ("This is show Again Function");

trace ("this=" + this);

this.showHeart ();

//使用代理的静态方法

var fam:Function = mx.utils.Delegate.create (_root, showAgain);

//就好象创建了一个函数指针,然后调用,

fam ();接着你会发现它的输出是:
This is show Again Function

this=_level0

I Love U ,my Little Leaf注意:不要忘记把MC拖到主时间轴,呵呵,我刚才忘记了,顺便提一下
从这个例子,可以看出:Delagate在做什么了,它好像是创建了一个函数指针,但同时它有改变了函数的上下问。但是它只是把fam 所引用的函数改变上下文,实际的showAgain函数并没有改变上下文。不信可以再调用showAgain看看。在MC第一帧中最后再加一句调用:
showAgain ();看一下输出:
This is show Again Function

this=_level0

I Love U ,my Little Leaf

This is show Again Function

this=_level0.instance1其不同点是:
前者:this=_level0 后者this=_level0.instance1。 this引用不一样。
前者:I Love U ,my Little Leaf 后者:空(没有打印即没有调用)
很明显,想一想,问题就很清楚了。
但是,这里的疑问是,Delegate是怎么做的呢?那么先看看,Delegate还有哪些方法:
function Delegate(f:Function) :这是构造函数,传入一个函数。
createDelegate(obj:Object):Function :传入一个Object返回一个函数。
这样看来。也可以使用实例化的方法来使用Delegate,刚才用的那个方法是静态方法!
再修改MC第一帧中的代码:
function showAgain ()

{

trace ("This is show Again Function");

trace ("this=" + this);

this.showHeart ();

this.a_txt.text = "KKK";

}

//var fam:Function = mx.utils.Delegate.create (_root, showAgain);

//fam ();

//showAgain ();

var mydgt:mx.utils.Delegate = new mx.utils.Delegate (showAgain);

var fam:Function = mydgt.createDelegate (_root);

fam ();输出结果:
This is show Again Function

this=_level0

I Love U ,my Little Leaf和第一次几乎没有什么变化,这应该是Delegate类应用吧,呵呵比较肤浅,就是这样拉。哈哈。不过不能不联想到,我上次发的关于Function类的文章,可以确定,Delegate类和Function类的两个方法(call, apply)一定有一定的关联的。下篇讨论哦!

时间: 2024-09-22 23:31:34

Flash AS学习:mx.utils包之Delegate类应用的相关文章

Flash从零开始学习创建单选按钮

核心提示:Flash从零开始学习创建单选按钮教程. 我们将使用画图工具和ActionScript 3.0中的时间轴,鼠标事件做一个好看的单选按钮. 最终预览 我们先看一下最终作品: 第一步:概述 一个单选按钮或选项按钮是一个图形用户界面元素,允许用户只选择一个预定义的选项集的类型. 在这个教程中,我们将创建一个传统的单选按钮. 第二步:设置Flash 打开Flash创建一个新文档,舞台大小设为320*190,颜色为#181818 ,帧频为 24fps. 第三步:界面 这是我们将要使用的界面:一个

Flash怎样学习鼠绘

  "Flash动画鼠绘入门班"第一课教材--认识鼠绘 序言 针对网络学员以初学电脑作图为多的特点,为使学员了解认识鼠绘的慨念.学习的目的及有关方法,为培养学习鼠绘的兴趣,树立信心,为继续深入学习鼠绘奠定基础而举办本期鼠绘入门班.因此本期鼠绘班不同于以往的鼠绘教材.它的宗旨就是领你入门. 第一课的主要内容: 1.闲话鼠绘 2.怎么样学习鼠绘 3.认识软件 一.闲话鼠绘 1.首先认识一下鼠绘: (1)鼠绘的概念:在电脑上用鼠标控制相关软件绘制的画; (2)鼠绘与纸画的不同之处:鼠绘的可修

Flash/Flex学习笔记(5):捕获摄像头(续)--在线抓屏并保存到客户端本地

必须有摄像头上面的演示才能正常播放. 思路 使用摄像头以及在线抓屏在上一节Flash/Flex学习笔记(2)捕获摄像头 里已经讲过了就不重复粘贴了至于在客户端保存文件Flash里用起来也很简单:直接调用 FileReference 即可另外为了减少图片大小还可能借助AS3.0的扩展库项目地址http://code.google.com/p/as3corelib/把bmp格式的位置转换成jpeg再保存   扩展 结合本文的方法再配合Flash/Flex学习笔记(4)如何打开网页及Get/Post数

Flash/Flex学习笔记(53):利用FMS快速创建一个文本聊天室

先来看客户端fla的构成: 第一帧:登录界面 第一帧的代码: import flash.events.MouseEvent; import com.adobe.utils.StringUtil; import utils.Alert; stop(); var userName:String=""; Alert.init(stage); btnLogin.addEventListener(MouseEvent.CLICK,btnLoginClick); function btnLogin

Flash/Flex学习笔记(37):不用系统组件(纯AS3)的视频播放器--只有8.82K

以前为了赶项目,利用系统组件制作过一款视频播放器(见Flash/Flex学习笔记(6):制作基于xml数据源的flv视频播放器),但是系统组件实在是太大了,最终生成的swf居然有103K,随着AS3的深入学习,昨天又弄了一个只用AS3的播放器,最终只有8.82K,呵呵,这肥减得那是相当厉害. 用到了上一篇(Flash/Flex学习笔记(35):自己动手实现一个滑块控件(JimmySilder))里自己写的的滑块控件,主要代码如下(关键是NetConnection与NetStream对象的使用):

Flash/Flex学习笔记(57):实用技巧

布朗运动: varnumDots:uint=50; varfriction:Number=0.9; vardots:Array; varlife:uint=0; functioninit(){ graphics.lineStyle(0,0xffffff,.5); dots=newArray(); for(vari:uint=0;i<numDots;i++){ vardot:Ball=newBall(2,0x00ff00); dot.x=Math.random()*stage.stageWidth

Flash/Flex学习笔记(46):正向运动学

所谓"正向运动学"通俗点讲就是把几个连接部件的一端固定起来,另一个端可以自由(向前/向外)运动.比如人的行走,单个下肢可以理解为脚连接小腿,小腿连接大腿,大腿连接腰.行走的过程,相当于二条腿相对固定于腰部,大腿运动驱动小腿,小腿又驱动脚,从而带动整个连接系统的一系列运动. 先来一个基本的关节类Segment:(就是一个圆角矩形+二个小圆圈) package { import flash.display.Sprite; import flash.geom.Point; public cl

Flash/Flex学习笔记(24):粒子效果

粒子爆炸: 仍然要用到以前的小球类,不过稍加改造 package { import flash.display.Sprite; //小球 类 public class Ball extends Sprite { public var radius:uint;//半径 public var color:uint;//颜色 public var vx:Number=0;//x轴速度 public var vy:Number=0;//y轴速度 public function Ball(r:Number

Flash/Flex学习笔记(25):摩擦力与屏幕环绕

摩擦力: 假如一个物体在某个方向上沿直线运行,摩擦力会使该方向上的速度越来越小,直到停止. 上图示意了该过程,物体以moveAngle角度正向运动,最终的速度speed矢量为vx矢量与vy矢量的矢量和,在每个单位时间内的位移即Speed矢量的大小,分解到x,y轴后,即为vx与vy:加入摩擦力后,speed矢量每单位时间将减少Friction值,也就是视觉上的越来越慢. var ball:Ball = new Ball(10); ball.x = stage.stageWidth/2; ball.