flash教程鼠标拖拽与旋转MC

2015-01-19 10:32 232 1 收藏

今天小编给大家分享一个比较有意思的Flash小技巧,只要稍微懂点Flash小知识,就能学会哦,很多人为Flash这个东西比较复杂。其实不是的,只要肯学习,肯用心看教程,机会学到别人不知道的东西~

【 tulaoshi.com - flash 】

  在网上看到某个游戏既要拖拽mc又要旋转mc,拖拽用鼠标事件实现,而旋转需要用shift+鼠标click事件。总觉得太麻烦了。故而希望自己能找到一种只用鼠标就能同时实现拖拽与旋转功能的方法。

 

  结果发现MOUSE_DOWN+MOUSE_UP竟然相当于一次CLICK事件。即每次释放鼠标左键,停止拖拽时,mc会旋转一次,而这个显然不是预期的效果。

  于是,开始明白了,那个程序员为什么要添加shift键的侦听了。

  可是,不用shift键就不能实现这种功能吗?我开始考虑如何区分MOUSE_DOWN+MOUSE_UP与CLICK.。

  方法一:设置时间间隔。时间不太好把握,pass掉。

  方法二:用鼠标的相对位置。倘若mc未移动则视为click事件。正解!

  package{

   import flash.display .*;

   import flash.geom .Point;

(本文来源于图老师网站,更多请访问http://www.tulaoshi.com/flash/)

   import flash.events.*;

   public class main extends Sprite{

    private var mc:MC;

    private var clickOffset:Point;

    private var mouseLoc:Point;

    public function main(){

   mc=new MC();

   addChild(mc);

   mc.x=200;

   mc.y=200;

   mc.addEventListener(MouseEvent.CLICK ,rot);

   mc.addEventListener(MouseEvent.MOUSE_DOWN,startdrag);

   mc.addEventListener(Event.ENTER_FRAME. ,drag);

   stage.addEventListener(MouseEvent.MOUSE_UP,stopdrag);

    }

    private function startdrag(e:MouseEvent ){

   mouseLoc=new Point(e.stageX,e.stageY);

   clickOffset=new Point(e.stageX-mc.x,e.stageY-mc.y);

(本文来源于图老师网站,更多请访问http://www.tulaoshi.com/flash/)

    }

    private function drag(e:Event){

   if(clickOffset==null) return;

   mc.x=mouseX-clickOffset.x;

   mc.y=mouseY-clickOffset.y;

    }

    private function stopdrag(e:MouseEvent ){

   clickOffset=null;

    }

    private function rot(e:MouseEvent){

   if(!mouseLoc.equals(new Point(e.stageX,e.stageY)))return;

    mc.rotation+=30;

    }

   }

  }

来源:http://www.tulaoshi.com/n/20150119/130499.html

延伸阅读
标签: 电脑入门
鼠标拖拽失灵解决办法:快速按两下ESC
标签: flash教程
本文由 中国 清风掠影 原创,转载请保留此信息! 明亮的屋子忽然暗了下来,原来是停电了,这时第一件事就是拿出一根蜡烛,点上~~~ 需要源文件的朋友请到这里下载:http://bbs.jcwcn.com/viewthread.php?tid=80528 一、打开FLASH,新建一个影片剪辑元件,命名为“火柴”,绘制一根火柴(如图1),在41帧插入关键帧,在动作...
标签: 电脑应用
本例讲解了使用AS代码制作鼠标跟随效果,让火苗跟着你的鼠标呈现出美丽的图形吧! 效果演示: 现在开始制作: 新建flash文档,背景色为黑色,其它默认。首先来画火苗:新建图形元件,取名为:“火苗”,用椭园工具无填充,画一椭园,如图: 然后...
标签: FLASH flash教程
1、 600) {this.resized=true; this.width=600;}" border=0> (图老师整理)2、 600) {this.resized=true; this.width=600;}" border=0> 3、 600) {this.resized=true; this.width=600;}" border=0> 4、 600) {this.resized=true; this.width=600;}" border=0> 5、 600) {this.resized=true; this.width=600;}" border=0...
效果欣赏 1、建新文档,默认(550X400), 2、准备二张图片,把图片导入库 3、新建图层2,在库里把2张图片分别拖进图层1、图层2的第1帧。改名:图层1改为背景层。 4、打开背景层,把图片调整与舞台同样大小(550X400),打开对齐面版:用箭头工具点图片(使图片在选中状态), 单击对齐面板里的相...

经验教程

994

收藏

76
微博分享 QQ分享 QQ空间 手机页面 收藏网站 回到头部