博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
AS3.0实例学习 熟悉新的事件机制和addChild的运用
阅读量:4692 次
发布时间:2019-06-09

本文共 1483 字,大约阅读时间需要 4 分钟。

案例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的语法。 

转载于:https://www.cnblogs.com/top5/archive/2012/02/07/2342030.html

你可能感兴趣的文章
基于cropper.js的图片上传和裁剪
查看>>
PHP学习路线【参考】
查看>>
(转)CentOS6.5安装Darwin Streaming Server搭建RTSP流媒体服务器
查看>>
java 随机函数初试,输出一个32位的随机数
查看>>
六、雪花《苹果iOS实例编程入门教程》
查看>>
单页面应用(SPA)
查看>>
mahout 安装
查看>>
Application,Session和Cookie
查看>>
sql中的系统表sysobjects以及如何查看sql语句的执行时间
查看>>
Git的使用
查看>>
Redis Python开发指南
查看>>
4.如果给一个单位做相关的软件,你认为最重要的是需要得到谁的支持,为什么?...
查看>>
视图基本
查看>>
提高Java代码质量的Eclipse插件之Checkstyle的使用具体解释
查看>>
【莫比乌斯反演】——蒟蒻的理解
查看>>
ORM系列之二:EF(4) 约定、注释、Fluent API
查看>>
cnblogs latex公式
查看>>
js中的替换
查看>>
SKTextureAtlas类
查看>>
自己写的网页放在github里面
查看>>