萬盛學電腦網

 萬盛學電腦網 >> 圖文處理 >> Flash教程 >> FLASH AS教程:鼠標拖拽與旋轉MC

FLASH AS教程:鼠標拖拽與旋轉MC

   在網上看到某個游戲既要拖拽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;

  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);

  }

  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;

  }

  }

  }

copyright © 萬盛學電腦網 all rights reserved