| 首页 | 新闻 | 网页 | 设计 | 色彩 | 原创 | 视觉 | 素材 | 动漫 | 酷站 | 策划 | 文案 | 访谈 | 运营 | 编程 | 数据库 | 服务器 | 下载 | 图库 | 
您的位置: 幽幽天空 > 网页 > 网页制作 > Flash教程 > ActionScript教程 > 文章正文 用户登录
载入中…
通过实例学习AS3.
通过实例学习AS3.
通过实例学习AS3.
通过实例学习AS3.
通过实例学习AS3.

通过实例学习AS3.0—案例一熟悉新的事件机制和addChild的运用           ★★★

通过实例学习AS3.0—案例一熟悉新的事件机制和addChild的运用

作者:lzyy 来源:蓝色理想 更新:2007-12-11 12:46:56 错误报告 我要投稿

案例1:熟悉新的事件机制和addChild的运用

说明:拖动小人到滑板上,然后拖动滑板,可以发现小人已经跟滑板粘在了一起。
演示http://www.live-my-life-with-yuyi.com/as3_cases/changing_parents/

代码

boarder_mc.addEventListener(MouseEvent.MOUSE_DOWN, drag);
boarder_mc.addEventListener(MouseEvent.MOUSE_UP, drop);
red_mc.addEventListener(MouseEvent.MOUSE_DOWN, drag);
red_mc.addEventListener(MouseEvent.MOUSE_UP, drop);
blue_mc.addEventListener(MouseEvent.MOUSE_DOWN, drag);
blue_mc.addEventListener(MouseEvent.MOUSE_UP, drop);

AS3采用了新的监听机制,而且注意到对每个mc的鼠标按下弹起都使用了相同的函数,这就需要在函数里判断事件的发生者,从而做出相应的处理。

function drag(event:MouseEvent):void
{
    if(event.target.name == "boarder_mc")
    {
        addChild(boarder_mc);
        event.target.startDrag(true);
        boarder_mc.x = mouseX;
        boarder_mc.y = mouseY;
    }
    else
    {
    event.target.startDrag();
    }
}

通过event.target.name来取得事件发生的对象名,AS3里没有了root,addChild相当于把某个mc搬到了舞台上,其实是TimeLine0.addChild(mc),同时保证该mc是在舞台的最顶层(AS3里没有了深度管理)。
通过event.target来获取事件发生的对象

接着来看drop函数

function drop(event:MouseEvent):void
{
    event.target.stopDrag();
    if(boarder_mc.hitTestObject(red_mc))
    {
        red_mc.addChild(boarder_mc);
        boarder_mc.x = 0;
        boarder_mc.y = 0;
    }
    else if(boarder_mc.hitTestObject(blue_mc))
    {
        blue_mc.addChild(boarder_mc);
        boarder_mc.x = 0;
        boarder_mc.y = 0;
    }
}

当鼠标弹起时,啥也不管,先停止拖动,如果小人和滑板有重合区域,则将小人放到滑板里,滑板就像一个container,boarder_mc成了red_mc的child,将boarder_mc的x坐标和y坐标清零是为了将小人放到滑板的正确位置。

如果小人已经成为了滑板的child,那么再次拖动滑板时,由于又执行了一次addChild(boarder_mc);所以滑板的父类又变成了舞台。

整个案例1的分析到此结束,涉及的知识点不多,主要是熟悉一下AS3的语法。

源文件下载

文章录入:skyuu    责任编辑:skyuu 
  • 上一篇文章:

  • 下一篇文章:
  • 【字体: 】【发表评论】【加入收藏】【告诉好友】【打印此文】【关闭窗口
    网友评论:(只显示最新10条。评论内容只代表网友观点,与本站立场无关!)
    发表评论:
    姓名:  评 分: 1分 2分 3分 4分 5分
     
  • 严禁发表危害国家安全、政治、黄色淫秽等内容的评论。
  • 用户需对自己在使用幽幽天空服务过程中的行为承担法律责任。
  • 本站管理员有权保留或删除评论内容。
  • 评论内容只代表机友个人观点,与本网站立场无关。