麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 辦公 > Flash > 正文

Flash AS3教程:Direction類和Dot類

2020-07-17 13:17:37
字體:
來源:轉載
供稿:網友
前面講述了Flash as3教程:OutDisplay類,本篇對Direction類的方法屬性和Dot的更新部分講解。
關于該例子的教程請關注第九篇筆記!
即將出Direction類與Dot類的實戰使用教程,本篇只對Direction類的方法屬性和Dot的更新部分講解

首先是
index.base.game.Direction類
作用:控制飛機游戲,坦克游戲,或者一些和方向有關的方向按鍵操作

構造函數:
public function Direction(_area:InteractiveObject,isSole:Boolean = false,_up:uint = 38,_down:uint = 40,_left:uint = 37,_right:uint = 39)
參數一:方向鍵的作用區域,如果_area當前不是焦點,那么是偵聽不到鍵盤事件的,一般這兒都是使用Stage做為作用區域
參數二:是否為單向事件觸發,如果為false,那么按了什么鍵就是什么,可以同時觸發上和左等兩個或者兩個以上的事件,反之以最后按的那個鍵為準
參數三,四,五,六:按鍵的鍵值,默認為38,40,37,39,分別是方向鍵的上下左右!

start方法:
public function start():void
開始捕獲事件,當觸發構造函數,將自動執行start方法

stop方法:
public function stop():void
停止捕獲事件

setKey方法:
public function setKey(num:uint,vars:uint):void
設置按鍵鍵值
參數一:方向鍵標識,請參考該類的常量屬性
參數二:按鍵鍵值

常量屬性:
public static const UP:uint = 0;
public static const DOWN:uint = 1;
public static const LEFT:uint = 2;
public static const RIGHT:uint = 3;
分別代表:上下左右的方向鍵標識

clear方法:
public function clear():void
清除所有方向記錄

area屬性:
public var area:InteractiveObject
返回作用區域

sole屬性:
public var sole:Boolean
返回是否單向操作

DirectionEvent.DO事件:
當有方向鍵是按下去的時候,則會發布事件,事件中含有up,down,left,right,4個屬性,分別表示哪幾個鍵是按下去的!

========== 氣 死 你 的 分 割 線 ==========

Dot類在前面的整理筆記中,曾經說過,這次是更新類的方法和屬性
增加了旋轉屬性,并且可以計算當前方向的某距離后的點

以下只對更新的方法和屬性進行講解:其他的請看老的整理筆記:

go方法:
public function go(num:Number,isChange:Boolean = false):Dot
參數一,表示面向旋轉方向前進多少的距離
參數二,表示是否也跟新該點基于num變化之后的點坐標

clear方法:
public function clear():void
清空綁定對象的引用

r 屬性:
public function set r(num:Number):void
public function get r():Number
旋轉屬性的設置,如果isListener值為真,則改變旋轉值會觸發R_CHANGE的事件

Direction類源代碼:

CODE:
package index.base.game{

import flash.events.EventDispatcher;
import flash.events.KeyboardEvent;
import flash.events.Event;
import flash.display.InteractiveObject;

import index.base.events.DirectionEvent;

public class Direction extends EventDispatcher{

//方向表示
public static const UP:uint = 0;
public static const DOWN:uint = 1;
public static const LEFT:uint = 2;
public static const RIGHT:uint = 3;

//作用區域
public var area:InteractiveObject;
//是否單向
public var sole:Boolean;

//上下左右鍵值
private const directionAr:Array = new Array(4);

//是否上下左右
private var _up:Boolean = false;
private var _down:Boolean = false;
private var _left:Boolean = false;
private var _right:Boolean = false;

public function Direction(_area:InteractiveObject,isSole:Boolean = false,_up:uint = 38,_down:uint = 40,_left:uint = 37,_right:uint = 39){
area = _area;
sole = isSole;
directionAr[UP] = _up;
directionAr[DOWN] = _down;
directionAr[LEFT] = _left;
directionAr[RIGHT] = _right;
start();
}

//開始獲取事件
public function start():void{
area.addEventListener(KeyboardEvent.KEY_DOWN,onKeyDown);
area.addEventListener(KeyboardEvent.KEY_UP,onKeyUp);
area.addEventListener(Event.ENTER_FRAME,onEnterFrame);
}

//事件幀頻繁觸發
private function onEnterFrame(e:Event):void{
var num:uint = Number(_up) Number(_down) Number(_left) Number(_right);
if(num == 0){
return;
}

var eve:DirectionEvent = new DirectionEvent(DirectionEvent.DO);
eve.up = _up;
eve.down = _down;
eve.left = _left;
eve.right = _right;
dispatchEvent(eve);
}

//停止獲取事件
public function stop():void{
area.removeEventListener(KeyboardEvent.KEY_DOWN,onKeyDown);
area.removeEventListener(KeyboardEvent.KEY_UP,onKeyUp);
area.removeEventListener(Event.ENTER_FRAME,onEnterFrame);
}

//鼠標按下去事件
private function onKeyDown(e:KeyboardEvent):void{
key(e.keyCode,true)
}

//鼠標彈上來事件
private function onKeyUp(e:KeyboardEvent):void{
key(e.keyCode,false)
}

//變化狀態
private function key(num:uint,isDown:Boolean):void{
switch(num){
case directionAr[UP]:
if(sole) clear();
_up = isDown;
break;
case directionAr[DOWN]:
if(sole) clear();
_down = isDown;
break;
case directionAr[LEFT]:
if(sole) clear();
_left = isDown;
break;
case directionAr[RIGHT]:
if(sole) clear();
_right = isDown;
break;
}
}

//設置按鈕
public function setKey(num:uint,vars:uint):void{
directionAr[num] = vars;
}

//清空按鍵
public function clear():void{
_up = _down = _left = _right = false;
}
}
}
Dot類源代碼:

CODE:
package index.base.geom{

import flash.events.EventDispatcher;
import flash.display.DisplayObject;

import index.base.events.DotEvent;

public class Dot extends EventDispatcher{

private var _x:Number;
private var _y:Number;
private var _r:Number;
private var dis:DisplayObject;

public var isListen:Boolean;

public function Dot(x_:Number = 0,y_:Number = 0,r_:Number = 0,_isListen:Boolean = false){
_x = x_;
_y = y_;
_r = r_;
isListen = _isListen;
}

//綁定DisplayObject
public function bind(_dis:DisplayObject,isInTime:Boolean = false):void{
dis = _dis;
updata();
if(isInTime) dis.addEventListener("enterFrame",enterFrameFun);
}

//幀頻繁事件
private function enterFrameFun(e:Object):void{
if(_x != dis.x) x = dis.x;
if(_y != dis.y) y = dis.y;
if(_r != dis.rotation) r = dis.rotation;
}

//更新xy數據
public function updata():void{
if(dis != null){
_x = dis.x;
_y = dis.y;
_r = dis.rotation;
}
}

//計算該點向R方向前進某距離后的點
public function go(num:Number,isChange:Boolean = false):Dot{
updata();
var yx:Number = Math.tan(_r * Math.PI / 180);
var tmpx:Number = num / Math.sqrt(Math.pow(yx,2) 1);
var tmpy:Number = tmpx * yx;
var n:int = Number(Math.abs(_r) <= 90) * 2 - 1;
var dot:Dot = new Dot(_x tmpx * n,_y tmpy * n,_r);
if(isChange){
x = dot.x;
y = dot.y;
}
return dot;
}

//計算該點與另外一點的距離
public function from(_dot:Dot,isQuadrant:Boolean = false):Number{
updata();
var num:Number = Math.sqrt(Math.pow(_dot.x - _x,2) Math.pow(_dot.y - _y,2));
if(!isQuadrant) num = Math.abs(num);
return num;
}

//計算該點與另外一點所形成的線段與水平線的夾角,按順時間計算
public function angle(_dot:Dot,isRadian:Boolean = false):Number{
updata();
var numx:Number = _dot.x - _x;
var numy:Number = _dot.y - _y;
var num:Number = Math.atan(numy/numx);
if(!isRadian) num = num * 180 / Math.PI;
return num;
}

//返回當前點處在另外一點的哪個象限中 或 返回另外一點處在當前點的哪個象限中
public function quadrant(_dot:Dot,isMaster:Boolean = true):int{
updata();
if(_x == _dot.x || _y == _dot.y){
return 0;
}

var num:int;
var p1:Boolean = (_x - _dot.x) > 0;
var p2:Boolean = (_y - _dot.y) > 0;
num = isMaster ? (p1 ? (p2 ? 2 : 3) : (p2 ? 1 : 4)) : (p1 ? (p2 ? 4 : 1) : (p2 ? 3 : 2));

return num;
}

//返回該點距0點的距離
public function get length():Number{
updata();
var num:Number = Math.sqrt(Math.pow(_x,2) Math.pow(_y,2));
return num;
}

//清除顯示對象
public function clear():void{
dis = null;
}

//改變旋轉值
public function set r(num:Number):void{
_r = num;
if(dis != null) dis.rotation = num;
if(isListen) dispatchEvent(new DotEvent(DotEvent.R_CHANGE,true));
}

//改變旋轉值
public function get r():Number{
updata();
return _r;
}

//改變X坐標
public function set x(num:Number):void{
_x = num;
if(dis != null) dis.x = num;
if(isListen) dispatchEvent(new DotEvent(DotEvent.X_CHANGE,true));
}

//設置X坐標
public function get x():Number{
updata();
return _x;
}

//改變Y坐標
public function set y(num:Number):void{
_y = num;
if(dis != null) dis.y = num;
if(isListen) dispatchEvent(new DotEvent(DotEvent.Y_CHANGE,true));
}

//設置Y坐標
public function get y():Number{
updata();
return _y;
}
}
}

上一頁12 下一頁 閱讀全文
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: a级在线| 中文区永久区 | 2021狠狠操| 福利在线免费视频 | 在线成人免费观看 | 国产精品视频中文字幕 | 久久精品免费国产 | 久久久久久久免费看 | 欧美性猛交一区二区三区精品 | 国产精品www| 午夜视频免费播放 | 亚洲网站一区 | 中国黄色一级生活片 | 精精国产xxxx视频在线野外 | 久久精品操| 日韩av片在线播放 | 久久精品国产99久久久古代 | 日韩视频1 | 久久精品亚洲精品国产欧美kt∨ | 国产精品久久久久影院老司 | 精品久久久久久成人av | 久久免费毛片 | 国产一区二区三区高清 | av成人免费观看 | 国产午夜亚洲精品午夜鲁丝片 | 国产一区二区久久精品 | 激情宗合网 | 最污网站 | 成人毛片免费视频 | 特级黄毛片 | 亚洲一区二区三区精品在线观看 | 久草成人在线 | 日本在线视频一区二区三区 | 成人做爽爽爽爽免费国产软件 | 视频一区二区国产 | 999久久国产| 欧美精品一区二区久久久 | 美女在线视频一区二区 | 久草手机视频在线观看 | 久久精品国产一区二区 | 又黄又爽又色无遮挡免费 |