Section 1
//BaseStage (BaseClass.BaseStage)
package BaseClass {
import flash.events.*;
import Element.*;
import flash.display.*;
import caurina.transitions.*;
import UserdefinedClass.*;
import flash.geom.*;
import Box2D.Common.Math.*;
import Box2D.Dynamics.*;
import flash.utils.*;
import Box2D.Collision.*;
public class BaseStage extends MovieClip {
public var main:Main;
public var world;
public var lowerpoint:Point;
public var upperpoint:Point;
public var game:Sprite;
public var grounding:Sprite;
public var road:Sprite;
public var car:Sprite;
public var cargo:Sprite;
public var frontroad:Sprite;
public var hit:Sprite;
public var back:Sprite;
public var standby:Sprite;
public var light:Sprite;
public var yan:Sprite;
public var burst:Sprite;
public var debug:Sprite;
public var SRC_W:Number;// = 700
public var pausebool:Boolean;// = false
public var score:int;// = 0
public var lv:int;
public var gametime:MyTime;
public var camera:Camera;
public var cameraPoint:Point;
public var Roadfriction:Number;// = 5
public var Roaddensity:Number;// = 0
public var Roadrestitution:Number;// = 0
public var stagenum:int;
public var roadarr:Array;
public var backarr:Array;
public var mincargo:int;
public var money:int;// = 0
public var itemCount:int;// = 0
public var itemMaxCount:int;
public var totallen:Number;// = 0
public var currentlylen:Number;// = 0
public var carryArr:Array;
public var itemspArr:Array;
public var itemLen:Number;// = 320
public var endMccount:int;// = 0
public var carlive:Boolean;// = true
public var chimneycount:int;// = 0
public var end:MovieClip;
public var endpoint:MovieClip;
public var stopmc:MovieClip;
public var backgroundmc:MovieClip;
public var groundmc:MovieClip;
public var inititemmc:MovieClip;
public var hitrun:MovieClip;
public var endMc:MovieClip;
public var itemname:Array;
public var itemproperty:Array;
public var startLink:MovieClip;
public var endLink:MovieClip;
public var itemGroup:Array;
public var canopen:Boolean;// = false
public var spmc:int;// = 0
public var trainMc;
public var isup:Boolean;// = false
public var countup:int;// = 0
public var speedvar:int;// = 0
public var FPS:int;// = 30
public var yancount:int;// = 0
public var smokecount:int;// = 0
public var wucount:int;// = 0
public var runcount:int;// = 0
public var runplay:Boolean;// = false
public var speedup:Boolean;// = false
public var carxy:Array;
public var canlight:Boolean;// = false
public var cargospArr;
public function BaseStage(mainobj:Object){
lowerpoint = new Point(-2000, -2000);
upperpoint = new Point(2000, 2000);
cameraPoint = new Point(300, 300);
carryArr = new Array();
itemspArr = new Array();
itemname = new Array("Item1", "Item2", "Item3", "Item4", "Item5", "Item6", "Item7", "Item8", "Item9", "Item10");
itemproperty = new Array([1, 0.1, 0], [0.5, 0.1, 0], [0.2, 0.1, 0], [2, 0.1, 0], [1, 0.1, 0], [1, 0.1, 0], [0.5, 0.1, 0], [0.2, 0.1, 0], [2, 0.1, 0], [1, 0.1, 0], [0.2, 0.1, 0], [0.5, 0.1, 0], [0.2, 0.1, 0], [1, 0.1, 0], [0.5, 0.1, 0]);
itemGroup = new Array();
carxy = new Array();
cargospArr = new Array(0, 0, 0, 0, 0);
super();
main = (mainobj as Main);
initgame();
}
public function initSound(){
SoundControl.destorySdground();
}
public function initgame(){
SoundControl.stopallsound();
game = new Sprite();
road = new Sprite();
car = new Sprite();
back = new Sprite();
cargo = new Sprite();
frontroad = new Sprite();
standby = new Sprite();
yan = new Sprite();
burst = new Sprite();
grounding = new Sprite();
light = new Sprite();
debug = new Sprite();
addChild(grounding);
addChild(back);
addChild(game);
game.addChild(road);
game.addChild(cargo);
game.addChild(car);
game.addChild(burst);
game.addChild(yan);
game.addChild(frontroad);
game.addChild(debug);
addChild(light);
addChild(standby);
initworld();
initSound();
rewritedata();
loaddata();
initui();
camera = Camera.getInstance(game);
camera.easing = true;
camera.lockWay = Camera.LOCKWAY_X;
inititem();
main.stage.focus = this;
playbgm();
endMc = new EndMc();
initbackground();
}
public function initbackground():void{
if (((((((!((lv == 2))) && (!((lv == 3))))) && (!((lv == 7))))) && (!((lv == 8))))){
groundmc = new BBack();
backgroundmc = new Background();
} else {
groundmc = new BBack1();
backgroundmc = new Background1();
};
grounding.addChild(groundmc);
back.addChild(backgroundmc);
}
public function playbgm(){
var tempNun:int = MyMath.randRange(1);
Main.BGMGroup[tempNun].playsound(1000000);
}
public function inititem():void{
world.world.SetContactFilter(new MyContactFilter());
world.world.SetContactListener(new MyContactListener());
MyContactListener.basestage = this;
bulidroad(0, 0, road, roadarr);
setcarxy();
trainMc = new BaseCar(this, (main.seltrain - 1), car, carxy[0], carxy[1]);
newCar();
backgroundupdate();
camera.lookAt(trainMc.carMc, cameraPoint, Camera.LOCKWAY_NORMAL);
main.setpowerbar(speedvar);
}
public function setcarxy():void{
}
public function timetobuild(){
if (itemMaxCount == 0){
return;
};
if (itemCount == 0){
itemMaxCount--;
builditem();
itemCount = 10;
};
itemCount--;
}
public function builditem(e:TimerEvent=null){
var p:Point = MyMath.LtoG(cargo, inititemmc);
newitem((lv - 1), p.x, p.y);
}
public function newitem(num:int, ix:Number, iy:Number){
var itemclass:* = getDefinitionByName(itemname[num]);
var itemmc:MovieClip = (new (itemclass) as MovieClip);
itemmc.no = num;
itemmc.x = ix;
itemmc.y = iy;
itemmc.live = true;
if (((!((num == 8))) && (!((num == 14))))){
world.addToWorld((itemmc.x / 30), (itemmc.y / 30), itemmc.rotation, itemproperty[num][0], itemproperty[num][1], itemproperty[num][2], itemmc, false, "item");
} else {
world.makeBodyByYuanInside((itemmc.x / 30), (itemmc.y / 30), itemmc, itemproperty[num][1], itemproperty[num][0], itemproperty[num][2], false, "item");
};
itemGroup.push(itemmc);
cargo.addChild(itemmc);
}
public function newCar(){
}
public function rewritedata(){
}
public function loaddata():void{
lv = main.initgamenum;
roadarr = new Array();
backarr = new Array();
roadarr = MyData.getInstance().gamedataground[(lv - 1)].gameroad;
backarr = MyData.getInstance().gamedataground[(lv - 1)].frontroad;
gametime = new MyTime(setTime);
itemMaxCount = MyData.getInstance().cargoNUM[(lv - 1)];
}
public function initui(){
var tempmax:int = MyData.getInstance().gamedataground[(lv - 1)].JYTcargo[0];
mincargo = tempmax;
main.setTime(gametime.count);
}
public function startlistener(){
addEventListener(Event.ENTER_FRAME, updata);
addEventListener(Event.ENTER_FRAME, onkeyfun);
main.stage.addEventListener(KeyboardEvent.KEY_UP, onspaceup);
gametime.starttime();
}
public function initworld(){
world = Box2dFactory.getInstance();
var aabb:b2AABB = new b2AABB();
aabb.lowerBound.Set(lowerpoint.x, lowerpoint.y);
aabb.upperBound.Set(upperpoint.x, upperpoint.y);
world.createWorld(new b2Vec2(0, 30), aabb);
}
public function updata(e:Event){
timetobuild();
Box2dFactory.getInstance().updata();
backgroundupdate();
camera.lookAt(trainMc.carMc, cameraPoint, Camera.LOCKWAY_NORMAL);
updatalight();
workaddspeedbar();
workcrisp();
main.setpoint(curpoint());
moveitem();
workitemClr();
workendpoint();
workdie();
}
public function workdie():void{
var angle:Number;
if (MyData.die){
angle = trainMc.carMc.rotation;
if ((((angle < -140)) && ((angle > -180)))){
fail();
} else {
if ((((angle > 140)) && ((angle < 180)))){
fail();
} else {
MyData.die = false;
};
};
};
}
public function workitemClr():void{
if (lv < 6){
return;
};
var len:int = itemGroup.length;
var vy:Number = 0;
var tempArr:Array = new Array();
var i:int;
while (i < len) {
if ((((((itemGroup[i].no == 5)) || ((itemGroup[i].no == 7)))) || ((itemGroup[i].no == 9)))){
if (!itemGroup[i].live){
tempArr.push(itemGroup[i]);
} else {
vy = (itemGroup[i].bd as b2Body).GetLinearVelocity().y;
if (itemGroup[i].count == null){
itemGroup[i].count = 0;
};
if (Math.abs(vy) > 8){
itemGroup[i].gotoAndStop(3);
itemGroup[i].count++;
} else {
itemGroup[i].gotoAndStop(1);
itemGroup[i].count = 0;
};
if (itemGroup[i].count > 45){
itemGroup[i].live = false;
itemGroup[i].gotoAndPlay("die");
};
};
};
i++;
};
len = tempArr.length;
i = 0;
while (i < len) {
if (tempArr[i].currentFrame == tempArr[i].totalFrames){
if ((tempArr[i].bd as b2Body)){
Box2dFactory.getInstance().world.DestroyBody(tempArr[i].bd);
tempArr[i].bd = null;
};
};
i++;
};
}
public function workendpoint(){
if (trainMc.carMc.hitTestObject(endpoint)){
win();
};
}
public function setEndMc(num:int){
var tempnum:Number = (3 * main.stage.frameRate);
var tempframe:int = ((num / tempnum) * 6);
endMc.gotoAndStop((tempframe + 1));
if (num == tempnum){
removeEventListener(Event.ENTER_FRAME, updata);
removeEventListener(Event.ENTER_FRAME, onkeyfun);
win();
};
}
public function updatalight():void{
var P:Point;
if (canlight){
P = MyMath.LtoG(standby, trainMc.carMc);
light.x = P.x;
light.y = P.y;
light.rotation = trainMc.carMc.rotation;
};
}
public function moveitem(){
var tempMc:MovieClip;
var tempbody:b2Body;
var len:int = itemGroup.length;
var i:int;
while (i < len) {
tempMc = (itemGroup[i] as MovieClip);
if (tempMc.hitTestObject(hitrun)){
tempbody = (tempMc.bd as b2Body);
tempbody.m_linearVelocity.x = 7;
};
i++;
};
}
public function curpoint():Number{
return (int(((-(game.x) / totallen) * 100)));
}
public function workcrisp():void{
}
public function judgecargo():Boolean{
return (((recargonum() < MyData.getInstance().gamedataground[(lv - 1)].JYTcargo[0])) ? false : true);
}
public function workaddspeedbar(){
if (!isup){
countup++;
if (countup == FPS){
countup = 0;
addspeedupbar(trainMc.addspeed);
};
} else {
countup = 0;
};
}
public function addspeedupbar(Num:int):void{
if ((speedvar + Num) <= 101){
speedvar = (speedvar + Num);
} else {
speedvar = 101;
};
main.setpowerbar(speedvar);
}
public function recargonum():int{
var tempcount:int;
var len:int = itemGroup.length;
var i:int;
while (i < len) {
if (itemGroup[i].hitTestObject(trainMc.cargohitmc)){
tempcount++;
};
i++;
};
return (tempcount);
}
public function showyan(mc:MovieClip){
var P:Point;
if (trainMc.superadd > 1){
P = MyMath.LtoG(yan, mc);
onnewyan(P.x, (P.y + (mc.height * 0.5)));
};
}
public function onnewyan(tx:Number, ty:Number){
var tempyan:MovieClip = new ST();
tempyan.x = tx;
tempyan.y = ty;
yan.addChild(tempyan);
}
public function fail(){
carlive = false;
main.stage.removeEventListener(KeyboardEvent.KEY_UP, onspaceup);
removeEventListener(Event.ENTER_FRAME, onkeyfun);
gametime.pausetime();
delayrun(3, main.showGameover);
main.stage.frameRate = 10;
}
public function die(x:Number, y:Number){
if (carlive){
carlive = false;
newEffect(x, y);
main.stage.removeEventListener(KeyboardEvent.KEY_UP, onspaceup);
removeEventListener(Event.ENTER_FRAME, onkeyfun);
gametime.pausetime();
delayrun(3, main.showGameover);
main.stage.frameRate = 10;
};
}
public function newEffect(tx:Number, ty:Number){
Main.hitsd.playsound(1);
var tempmc:MovieClip = new Effect();
tempmc.x = tx;
tempmc.y = ty;
yan.addChild(tempmc);
var p:Point = MyMath.LtoG(trainMc.carMc, tempmc);
tempmc.x = p.x;
tempmc.y = p.y;
trainMc.carMc.addChild(tempmc);
}
public function delayrun(time:int, fun:Function){
Tweener.addTween(this, {delay:time, onComplete:fun});
}
public function onkeyfun(e:Event):void{
Input.keydownrunfun(Input.LEFT, trainMc.moveR);
Input.keydownrunfun(Input.RIGHT, trainMc.moveL);
Input.keydownrunfun(Input.DOWN, motolrun);
Input.keydownrunfun(Input.UP, motorrun);
Input.keydownrunfun(Input.Z, isspeedup);
Input.keydownrunfun(Input.SHIFT, workitemsp);
if (((!(Input.key[Input.DOWN])) && (!(Input.key[Input.UP])))){
trainMc.release();
};
if (!Input.key[Input.Z]){
isup = false;
trainMc.common();
};
if (!Input.key[Input.UP]){
stoprun();
};
}
public function workitemsp(){
var newitemsp:Function = function (mc:MovieClip, num:int){
mc.live = true;
var tempP:Point = MyMath.LtoG(cargo, mc);
mc.x = tempP.x;
mc.y = tempP.y;
if (num > 14){
world.addToWorld((mc.x / 30), (mc.y / 30), mc.rotation, itemproperty[0][0], itemproperty[0][1], itemproperty[0][2], mc, false, "item");
} else {
if ((((num == 8)) || ((num == 14)))){
world.makeBodyByYuanInside((mc.x / 30), (mc.y / 30), mc, itemproperty[num][1], itemproperty[num][0], itemproperty[num][2], false, "item");
} else {
world.addToWorld((mc.x / 30), (mc.y / 30), mc.rotation, itemproperty[num][0], itemproperty[num][1], itemproperty[num][2], mc, false, "item");
};
};
cargo.addChild(mc);
var tempyan:MovieClip = new ST();
tempyan.x = mc.x;
tempyan.y = mc.y;
yan.addChild(tempyan);
itemGroup.push(mc);
};
var doitemx:Function = function (_carx:Number, _itemx:Number):Boolean{
if ((_carx + itemLen) < _itemx){
return (false);
};
if ((_carx - itemLen) > _itemx){
return (false);
};
return (true);
};
var len:int = itemspArr.length;
if (!len){
return;
};
var carx:Number = MyMath.LtoG(cargo, trainMc.carMc).x;
var itemx:Number = 0;
var i:int;
while (i < len) {
itemx = MyMath.LtoG(cargo, itemspArr[i]).x;
if (doitemx(carx, itemx)){
if (!itemspArr[i].drop){
itemspArr[i].drop = true;
newitemsp(itemspArr[i], itemspArr[i].no);
};
};
i = (i + 1);
};
}
public function onspaceup(e:KeyboardEvent){
if (e.keyCode == 32){
changecarry();
};
}
public function changecarry():void{
var templen:int = carryArr.length;
var i:int;
while (i < templen) {
carryArr[i].changeway();
i++;
};
}
public function isspeedup(){
isup = true;
if (speedvar > 0){
speedup = true;
trainMc.accelerate();
main.setpowerbar(speedvar);
speedvar--;
showsmoke();
} else {
trainMc.common();
};
}
public function newsmoke(){
}
public function showchimney(){
chimneycount++;
if (chimneycount < 10){
return;
};
var tempmc:MovieClip = new YTY();
tempmc.scaleX = (tempmc.scaleY = 0.5);
var p:Point = MyMath.LtoG(yan, trainMc.makeyan);
tempmc.x = p.x;
tempmc.y = p.y;
yan.addChild(tempmc);
chimneycount = 0;
}
public function showsmoke(){
smokecount++;
if (smokecount == 3){
smokecount = 0;
newsmoke();
};
}
public function wu(){
if (main.seltrain == 1){
};
}
public function run(){
}
public function stoprun(){
runplay = false;
}
public function motolrun(){
trainMc.lunMoveL();
}
public function motorrun(){
trainMc.lunMoveR();
}
public function backgroundupdate():void{
back.x = ((game.x / 20) - 100);
back.y = ((game.y / 40) - 100);
}
public function win():void{
stopgame();
money = mathmoney();
workopenLv();
if (spmc){
main.showReel(spmc);
delayrun(6, showwin);
return;
};
showwin();
}
public function showwin(){
main.showWin(gametime.count, money, cargospArr);
}
public function workopenLv():void{
if (lv == 1){
if (canopen){
MyData.getInstance().stageunlock[3] = 1;
};
if (MyData.getInstance().caritem[1]){
MyData.getInstance().stageunlock[1] = 1;
};
};
if (lv == 2){
if (canopen){
MyData.getInstance().stageunlock[2] = 1;
};
};
if (lv == 3){
if (canopen){
MyData.getInstance().stageunlock[6] = 1;
};
};
if (lv == 4){
if (canopen){
MyData.getInstance().stageunlock[4] = 1;
};
};
if (lv == 5){
if (canopen){
MyData.getInstance().stageunlock[5] = 1;
};
};
if (lv == 6){
if (canopen){
MyData.getInstance().stageunlock[8] = 1;
};
};
if (lv == 7){
if (canopen){
MyData.getInstance().stageunlock[7] = 1;
};
};
if ((((lv == 9)) || ((lv == 8)))){
if (((MyData.getInstance().succeed[7]) || (MyData.getInstance().succeed[(7 + 10)]))){
if (((MyData.getInstance().succeed[8]) || (MyData.getInstance().succeed[(8 + 10)]))){
MyData.getInstance().stageunlock[9] = 1;
};
};
};
main.savestage();
}
public function mathhightscore(T:int, C:int):int{
var tempS:int;
var price:int = MyData.getInstance().cargo[(lv - 1)];
var MS:int = (price * C);
var tempT:int = MyData.getInstance().gamedataground[(lv - 1)].JYTtime[1];
var TS:int;
if (T < tempT){
TS = ((tempT - T) * 100);
} else {
TS = 0;
};
tempS = (MS + TS);
return (tempS);
}
public function mathmoney():int{
var M:int = workcargoprice();
var Num:int = recargonum();
var tempM:int = resucceed(Num, gametime.count);
M = (M + (tempM * 200));
return (M);
}
public function workcargoprice():int{
var price:int;
var len:int = itemGroup.length;
var i:int;
while (i < len) {
if (!itemGroup[i].live){
} else {
if (itemGroup[i].hitTestObject(trainMc.cargohitmc)){
price = (price + MyData.getInstance().itemprice[itemGroup[i].no]);
if ((((itemGroup[i].no > 9)) && ((itemGroup[i].no <= 14)))){
var _local4 = cargospArr;
var _local5 = (itemGroup[i].no - 10);
var _local6 = (_local4[_local5] + 1);
_local4[_local5] = _local6;
} else {
if ((((itemGroup[i].no > 14)) && ((itemGroup[i].no < 19)))){
MyData.getInstance().cardata[(itemGroup[i].no - 14)] = 1;
spmc = (itemGroup[i].no - 13);
} else {
if (itemGroup[i].no == 19){
MyData.getInstance().caritem[0] = 1;
} else {
if (itemGroup[i].no == 20){
MyData.getInstance().caritem[1] = 1;
};
};
};
};
main.saveCardata();
};
};
i++;
};
return (price);
}
public function resucceed(N:int, T:int):int{
var renum:int;
if (!MyData.getInstance().succeed[(lv - 1)]){
if (T <= MyData.getInstance().gamedataground[(lv - 1)].JYTtime[0]){
MyData.getInstance().succeed[(lv - 1)] = true;
main.savesucceed();
renum++;
};
};
if (!MyData.getInstance().succeed[((lv - 1) + 10)]){
if (N >= MyData.getInstance().gamedataground[(lv - 1)].JYTcargo[0]){
MyData.getInstance().succeed[((lv - 1) + 10)] = true;
main.savesucceed();
renum++;
};
};
if (renum > 0){
canopen = true;
};
return (renum);
}
public function endsucplaywin(){
Clr.removeAllChildren(standby);
completegame();
}
public function completegame(){
}
public function playsuc(sucarr:Array){
}
public function pausegame(){
if (pausebool){
restartgame();
} else {
stopgame();
};
if (pausebool){
pausebool = false;
} else {
pausebool = true;
};
}
public function stopgame(){
main.stage.removeEventListener(KeyboardEvent.KEY_UP, onspaceup);
removeEventListener(Event.ENTER_FRAME, updata);
removeEventListener(Event.ENTER_FRAME, onkeyfun);
gametime.pausetime();
}
public function restartgame(){
main.stage.addEventListener(KeyboardEvent.KEY_UP, onspaceup);
addEventListener(Event.ENTER_FRAME, updata);
addEventListener(Event.ENTER_FRAME, onkeyfun);
gametime.restart();
}
public function setTime(){
main.setTime(gametime.count);
}
public function gameover(){
stopgame();
main.showGameover();
}
public function bulidroad(x:Number, y:Number, container:Sprite, roads:Array):Number{
var lastLu:MovieClip;
var g:Point;
var lu:MovieClip;
var backmc:MovieClip;
var tempmc:MovieClip;
var Tempmc:MovieClip;
var luclass:*;
var backclass:*;
var t:Sprite;
var templen:int;
var j:int;
var tempARR:Array;
var itemdropmc:MovieClip;
var lastWidth:Number = 0;
var map:MovieClip = new MovieClip();
var tempNum:Number = 0;
var i:int;
while (i < roads.length) {
luclass = getDefinitionByName(roads[i].toString());
backclass = getDefinitionByName(backarr[i].toString());
lu = (new (luclass) as MovieClip);
backmc = (new (backclass) as MovieClip);
if (lastLu){
t = (lastLu.getChildByName("tail") as MovieClip);
lu.x = (lastLu.x + t.x);
lu.y = (lastLu.y + t.y);
} else {
lu.x = x;
lu.y = y;
};
backmc.x = lu.x;
backmc.y = lu.y;
map.addChild(lu);
DisplaytoBitMap.BigBitMapChange(lu.road);
DisplaytoBitMap.BigBitMapChange(lu.back);
DisplaytoBitMap.BigBitMapChange(backmc);
frontroad.addChild(backmc);
lastWidth = (lastWidth + lu.width);
lastLu = lu;
Box2dFactory.getInstance().addToWorld((lu.x / 30), (lu.y / 30), lu.rotation, Roadfriction, Roaddensity, Roadrestitution, lu, false, "road");
templen = MyData.getInstance().gamedataground[(lv - 1)].carry[i].length;
j = 0;
while (j < templen) {
carryArr.push(new BaseCarry(this, lu, MyData.getInstance().gamedataground[(lv - 1)].carry[i][j][0], MyData.getInstance().gamedataground[(lv - 1)].carry[i][j][1]));
j++;
};
templen = MyData.getInstance().gamedataground[(lv - 1)].bridge[i].length;
j = 0;
while (j < templen) {
new BaseBridge(this, lu, MyData.getInstance().gamedataground[(lv - 1)].bridge[i][j][0], MyData.getInstance().gamedataground[(lv - 1)].bridge[i][j][1]);
j++;
};
tempARR = new Array();
tempARR = MyData.getInstance().gamedataground[(lv - 1)].itemdrop[i];
templen = tempARR.length;
j = 0;
while (j < templen) {
trace(i, tempARR[j][0], tempARR[j][1], "........");
itemdropmc = (lu.getChildByName(tempARR[j][0]) as MovieClip);
itemdropmc.no = tempARR[j][1];
itemdropmc.drop = false;
itemdropmc.live = true;
if (tempARR[j][1] < 15){
itemspArr.push(itemdropmc);
} else {
if (tempARR[j][1] < 19){
if (MyData.getInstance().cardata[(tempARR[j][1] - 14)] == 0){
itemspArr.push(itemdropmc);
} else {
if (itemdropmc.parent){
itemdropmc.parent.removeChild(itemdropmc);
};
};
} else {
if (tempARR[j][1] == 19){
if (MyData.getInstance().caritem[0] == 0){
itemspArr.push(itemdropmc);
} else {
if (itemdropmc.parent){
itemdropmc.parent.removeChild(itemdropmc);
};
};
} else {
if (tempARR[j][1] == 20){
if (MyData.getInstance().caritem[1] == 0){
itemspArr.push(itemdropmc);
} else {
if (itemdropmc.parent){
itemdropmc.parent.removeChild(itemdropmc);
};
};
};
};
};
};
j++;
};
if (i == 0){
inititemmc = (lu.getChildByName("newitem") as MovieClip);
hitrun = (lu.getChildByName("run") as MovieClip);
Tempmc = (lu.getChildByName("pushitem") as MovieClip);
g = MyMath.LtoG(lu, Tempmc);
Tempmc.x = g.x;
Tempmc.y = g.y;
Box2dFactory.getInstance().addToWorld((Tempmc.x / 30), (Tempmc.y / 30), Tempmc.rotation, 0, Roaddensity, Roadrestitution, Tempmc, false, "push");
tempmc = (lu.getChildByName("build") as MovieClip);
g = MyMath.LtoG(frontroad, tempmc);
tempmc.x = g.x;
tempmc.y = g.y;
frontroad.addChild(tempmc);
};
if (i == (roads.length - 1)){
endpoint = (lu.getChildByName("endpoint") as MovieClip);
g = MyMath.LtoG(container, endpoint);
endpoint.x = g.x;
endpoint.y = g.y;
container.addChild(endpoint);
};
trace(i);
i++;
};
totallen = (endpoint.x - endpoint.width);
container.addChild(map);
return (lastWidth);
}
public function addbagarr(mc:MovieClip){
}
public function destory(){
main.removeNew();
main.stage.frameRate = 30;
main.stage.removeEventListener(KeyboardEvent.KEY_UP, onspaceup);
stopgame();
Box2dFactory.getInstance().clear();
camera.clear();
gametime.removetime();
Clr.removeAllChildren(back);
Clr.removeAllChildren(yan);
Clr.removeAllChildren(burst);
Clr.removeAllChildren(road);
Clr.removeAllChildren(cargo);
Clr.removeAllChildren(car);
Clr.removeAllChildren(frontroad);
Clr.removeAllChildren(game);
Clr.removeAllChildren(standby);
Clr.removeAllChildren(main.Cue);
Clr.removeAllChildren(grounding);
Clr.removeAllChildren(light);
Clr.removeAllChildren(this);
Tweener.removeAllTweens();
SoundControl.stopallsound();
}
}
}//package BaseClass
Section 2
//b2CircleDef (Box2D.Collision.Shapes.b2CircleDef)
package Box2D.Collision.Shapes {
import Box2D.Common.Math.*;
public class b2CircleDef extends b2ShapeDef {
public var localPosition:b2Vec2;
public var radius:Number;
public function b2CircleDef(){
localPosition = new b2Vec2(0, 0);
super();
type = b2Shape.e_circleShape;
radius = 1;
}
}
}//package Box2D.Collision.Shapes
Section 3
//b2CircleShape (Box2D.Collision.Shapes.b2CircleShape)
package Box2D.Collision.Shapes {
import Box2D.Common.Math.*;
import Box2D.Dynamics.*;
import Box2D.Collision.*;
import Box2D.Common.*;
public class b2CircleShape extends b2Shape {
public var m_localPosition:b2Vec2;
public var m_radius:Number;
public function b2CircleShape(def:b2ShapeDef){
m_localPosition = new b2Vec2();
super(def);
var circleDef:b2CircleDef = (def as b2CircleDef);
m_type = e_circleShape;
m_localPosition.SetV(circleDef.localPosition);
m_radius = circleDef.radius;
}
override public function TestPoint(transform:b2XForm, p:b2Vec2):Boolean{
var tMat:b2Mat22 = transform.R;
var dX:Number = (transform.position.x + ((tMat.col1.x * m_localPosition.x) + (tMat.col2.x * m_localPosition.y)));
var dY:Number = (transform.position.y + ((tMat.col1.y * m_localPosition.x) + (tMat.col2.y * m_localPosition.y)));
dX = (p.x - dX);
dY = (p.y - dY);
return ((((dX * dX) + (dY * dY)) <= (m_radius * m_radius)));
}
override public function TestSegment(transform:b2XForm, lambda:Array, normal:b2Vec2, segment:b2Segment, maxLambda:Number):Boolean{
var sY:Number;
var tMat:b2Mat22 = transform.R;
var positionX:Number = (transform.position.x + ((tMat.col1.x * m_localPosition.x) + (tMat.col2.x * m_localPosition.y)));
var positionY:Number = (transform.position.y + ((tMat.col1.y * m_localPosition.x) + (tMat.col2.y * m_localPosition.y)));
var sX:Number = (segment.p1.x - positionX);
sY = (segment.p1.y - positionY);
var b:Number = (((sX * sX) + (sY * sY)) - (m_radius * m_radius));
if (b < 0){
return (false);
};
var rX:Number = (segment.p2.x - segment.p1.x);
var rY:Number = (segment.p2.y - segment.p1.y);
var c:Number = ((sX * rX) + (sY * rY));
var rr:Number = ((rX * rX) + (rY * rY));
var sigma:Number = ((c * c) - (rr * b));
if ((((sigma < 0)) || ((rr < Number.MIN_VALUE)))){
return (false);
};
var a:Number = -((c + Math.sqrt(sigma)));
if ((((0 <= a)) && ((a <= (maxLambda * rr))))){
a = (a / rr);
lambda[0] = a;
normal.x = (sX + (a * rX));
normal.y = (sY + (a * rY));
normal.Normalize();
return (true);
};
return (false);
}
override public function ComputeAABB(aabb:b2AABB, transform:b2XForm):void{
var tMat:b2Mat22 = transform.R;
var pX:Number = (transform.position.x + ((tMat.col1.x * m_localPosition.x) + (tMat.col2.x * m_localPosition.y)));
var pY:Number = (transform.position.y + ((tMat.col1.y * m_localPosition.x) + (tMat.col2.y * m_localPosition.y)));
aabb.lowerBound.Set((pX - m_radius), (pY - m_radius));
aabb.upperBound.Set((pX + m_radius), (pY + m_radius));
}
override public function ComputeSweptAABB(aabb:b2AABB, transform1:b2XForm, transform2:b2XForm):void{
var tMat:b2Mat22;
tMat = transform1.R;
var p1X:Number = (transform1.position.x + ((tMat.col1.x * m_localPosition.x) + (tMat.col2.x * m_localPosition.y)));
var p1Y:Number = (transform1.position.y + ((tMat.col1.y * m_localPosition.x) + (tMat.col2.y * m_localPosition.y)));
tMat = transform2.R;
var p2X:Number = (transform2.position.x + ((tMat.col1.x * m_localPosition.x) + (tMat.col2.x * m_localPosition.y)));
var p2Y:Number = (transform2.position.y + ((tMat.col1.y * m_localPosition.x) + (tMat.col2.y * m_localPosition.y)));
aabb.lowerBound.Set((((p1X < p2X)) ? p1X : p2X - m_radius), (((p1Y < p2Y)) ? p1Y : p2Y - m_radius));
aabb.upperBound.Set((((p1X > p2X)) ? p1X : p2X + m_radius), (((p1Y > p2Y)) ? p1Y : p2Y + m_radius));
}
override public function ComputeMass(massData:b2MassData):void{
massData.mass = (((m_density * b2Settings.b2_pi) * m_radius) * m_radius);
massData.center.SetV(m_localPosition);
massData.I = (massData.mass * (((0.5 * m_radius) * m_radius) + ((m_localPosition.x * m_localPosition.x) + (m_localPosition.y * m_localPosition.y))));
}
public function GetLocalPosition():b2Vec2{
return (m_localPosition);
}
public function GetRadius():Number{
return (m_radius);
}
override public function UpdateSweepRadius(center:b2Vec2):void{
var dX:Number = (m_localPosition.x - center.x);
var dY:Number = (m_localPosition.y - center.y);
dX = Math.sqrt(((dX * dX) + (dY * dY)));
m_sweepRadius = ((dX + m_radius) - b2Settings.b2_toiSlop);
}
}
}//package Box2D.Collision.Shapes
Section 4
//b2FilterData (Box2D.Collision.Shapes.b2FilterData)
package Box2D.Collision.Shapes {
public class b2FilterData {
public var categoryBits:uint;// = 1
public var maskBits:uint;// = 0xFFFF
public var groupIndex:int;// = 0
public function Copy():b2FilterData{
var copy:b2FilterData = new b2FilterData();
copy.categoryBits = categoryBits;
copy.maskBits = maskBits;
copy.groupIndex = groupIndex;
return (copy);
}
}
}//package Box2D.Collision.Shapes
Section 5
//b2MassData (Box2D.Collision.Shapes.b2MassData)
package Box2D.Collision.Shapes {
import Box2D.Common.Math.*;
public class b2MassData {
public var mass:Number;// = 0
public var center:b2Vec2;
public var I:Number;// = 0
public function b2MassData(){
center = new b2Vec2(0, 0);
super();
}
}
}//package Box2D.Collision.Shapes
Section 6
//b2PolygonDef (Box2D.Collision.Shapes.b2PolygonDef)
package Box2D.Collision.Shapes {
import Box2D.Common.Math.*;
import Box2D.Common.*;
public class b2PolygonDef extends b2ShapeDef {
public var vertices:Array;
public var vertexCount:int;
private static var s_mat:b2Mat22 = new b2Mat22();
public function b2PolygonDef(){
vertices = new Array(b2Settings.b2_maxPolygonVertices);
super();
type = b2Shape.e_polygonShape;
vertexCount = 0;
var i:int;
while (i < b2Settings.b2_maxPolygonVertices) {
vertices[i] = new b2Vec2();
i++;
};
}
public function SetAsBox(hx:Number, hy:Number):void{
vertexCount = 4;
vertices[0].Set(-(hx), -(hy));
vertices[1].Set(hx, -(hy));
vertices[2].Set(hx, hy);
vertices[3].Set(-(hx), hy);
}
public function SetAsOrientedBox(hx:Number, hy:Number, center:b2Vec2=null, angle:Number=0):void{
var xfPosition:b2Vec2;
var xfR:b2Mat22;
var i:int;
vertexCount = 4;
vertices[0].Set(-(hx), -(hy));
vertices[1].Set(hx, -(hy));
vertices[2].Set(hx, hy);
vertices[3].Set(-(hx), hy);
if (center){
xfPosition = center;
xfR = s_mat;
xfR.Set(angle);
i = 0;
while (i < vertexCount) {
center = vertices[i];
hx = (xfPosition.x + ((xfR.col1.x * center.x) + (xfR.col2.x * center.y)));
center.y = (xfPosition.y + ((xfR.col1.y * center.x) + (xfR.col2.y * center.y)));
center.x = hx;
i++;
};
};
}
}
}//package Box2D.Collision.Shapes
Section 7
//b2PolygonShape (Box2D.Collision.Shapes.b2PolygonShape)
package Box2D.Collision.Shapes {
import Box2D.Common.Math.*;
import Box2D.Dynamics.*;
import Box2D.Collision.*;
import Box2D.Common.*;
public class b2PolygonShape extends b2Shape {
private var s_supportVec:b2Vec2;
public var m_centroid:b2Vec2;
public var m_obb:b2OBB;
public var m_vertices:Array;
public var m_normals:Array;
public var m_coreVertices:Array;
public var m_vertexCount:int;
private static var s_computeMat:b2Mat22 = new b2Mat22();
private static var s_sweptAABB1:b2AABB = new b2AABB();
private static var s_sweptAABB2:b2AABB = new b2AABB();
public function b2PolygonShape(def:b2ShapeDef){
var i:int;
var edgeX:Number;
var edgeY:Number;
var len:Number;
var n1X:Number;
var n1Y:Number;
var n2X:Number;
var n2Y:Number;
var vX:Number;
var vY:Number;
var dX:Number;
var dY:Number;
var det:Number;
s_supportVec = new b2Vec2();
m_obb = new b2OBB();
m_vertices = new Array(b2Settings.b2_maxPolygonVertices);
m_normals = new Array(b2Settings.b2_maxPolygonVertices);
m_coreVertices = new Array(b2Settings.b2_maxPolygonVertices);
super(def);
m_type = e_polygonShape;
var poly:b2PolygonDef = (def as b2PolygonDef);
m_vertexCount = poly.vertexCount;
var i1:int = i;
var i2:int = i;
i = 0;
while (i < m_vertexCount) {
m_vertices[i] = poly.vertices[i].Copy();
i++;
};
i = 0;
while (i < m_vertexCount) {
i1 = i;
i2 = (((i + 1) < m_vertexCount)) ? (i + 1) : 0;
edgeX = (m_vertices[i2].x - m_vertices[i1].x);
edgeY = (m_vertices[i2].y - m_vertices[i1].y);
len = Math.sqrt(((edgeX * edgeX) + (edgeY * edgeY)));
m_normals[i] = new b2Vec2((edgeY / len), (-(edgeX) / len));
i++;
};
m_centroid = ComputeCentroid(poly.vertices, poly.vertexCount);
ComputeOBB(m_obb, m_vertices, m_vertexCount);
i = 0;
while (i < m_vertexCount) {
i1 = (((i - 1) >= 0)) ? (i - 1) : (m_vertexCount - 1);
i2 = i;
n1X = m_normals[i1].x;
n1Y = m_normals[i1].y;
n2X = m_normals[i2].x;
n2Y = m_normals[i2].y;
vX = (m_vertices[i].x - m_centroid.x);
vY = (m_vertices[i].y - m_centroid.y);
dX = (((n1X * vX) + (n1Y * vY)) - b2Settings.b2_toiSlop);
dY = (((n2X * vX) + (n2Y * vY)) - b2Settings.b2_toiSlop);
det = (1 / ((n1X * n2Y) - (n1Y * n2X)));
m_coreVertices[i] = new b2Vec2(((det * ((n2Y * dX) - (n1Y * dY))) + m_centroid.x), ((det * ((n1X * dY) - (n2X * dX))) + m_centroid.y));
i++;
};
}
override public function TestPoint(xf:b2XForm, p:b2Vec2):Boolean{
var tVec:b2Vec2;
var dot:Number;
var tMat:b2Mat22 = xf.R;
var tX:Number = (p.x - xf.position.x);
var tY:Number = (p.y - xf.position.y);
var pLocalX:Number = ((tX * tMat.col1.x) + (tY * tMat.col1.y));
var pLocalY:Number = ((tX * tMat.col2.x) + (tY * tMat.col2.y));
var i:int;
while (i < m_vertexCount) {
tVec = m_vertices[i];
tX = (pLocalX - tVec.x);
tY = (pLocalY - tVec.y);
tVec = m_normals[i];
dot = ((tVec.x * tX) + (tVec.y * tY));
if (dot > 0){
return (false);
};
i++;
};
return (true);
}
override public function TestSegment(xf:b2XForm, lambda:Array, normal:b2Vec2, segment:b2Segment, maxLambda:Number):Boolean{
var tX:Number;
var tY:Number;
var tMat:b2Mat22;
var tVec:b2Vec2;
var numerator:Number;
var denominator:Number;
var lower:Number = 0;
var upper:Number = maxLambda;
tX = (segment.p1.x - xf.position.x);
tY = (segment.p1.y - xf.position.y);
tMat = xf.R;
var p1X:Number = ((tX * tMat.col1.x) + (tY * tMat.col1.y));
var p1Y:Number = ((tX * tMat.col2.x) + (tY * tMat.col2.y));
tX = (segment.p2.x - xf.position.x);
tY = (segment.p2.y - xf.position.y);
tMat = xf.R;
var p2X:Number = ((tX * tMat.col1.x) + (tY * tMat.col1.y));
var p2Y:Number = ((tX * tMat.col2.x) + (tY * tMat.col2.y));
var dX:Number = (p2X - p1X);
var dY:Number = (p2Y - p1Y);
var index = -1;
var i:int;
while (i < m_vertexCount) {
tVec = m_vertices[i];
tX = (tVec.x - p1X);
tY = (tVec.y - p1Y);
tVec = m_normals[i];
numerator = ((tVec.x * tX) + (tVec.y * tY));
denominator = ((tVec.x * dX) + (tVec.y * dY));
if ((((denominator < 0)) && ((numerator < (lower * denominator))))){
lower = (numerator / denominator);
index = i;
} else {
if ((((denominator > 0)) && ((numerator < (upper * denominator))))){
upper = (numerator / denominator);
};
};
if (upper < lower){
return (false);
};
i++;
};
if (index >= 0){
lambda[0] = lower;
tMat = xf.R;
tVec = m_normals[index];
normal.x = ((tMat.col1.x * tVec.x) + (tMat.col2.x * tVec.y));
normal.y = ((tMat.col1.y * tVec.x) + (tMat.col2.y * tVec.y));
return (true);
};
return (false);
}
override public function ComputeAABB(aabb:b2AABB, xf:b2XForm):void{
var tMat:b2Mat22;
var tVec:b2Vec2;
var R:b2Mat22 = s_computeMat;
tMat = xf.R;
tVec = m_obb.R.col1;
R.col1.x = ((tMat.col1.x * tVec.x) + (tMat.col2.x * tVec.y));
R.col1.y = ((tMat.col1.y * tVec.x) + (tMat.col2.y * tVec.y));
tVec = m_obb.R.col2;
R.col2.x = ((tMat.col1.x * tVec.x) + (tMat.col2.x * tVec.y));
R.col2.y = ((tMat.col1.y * tVec.x) + (tMat.col2.y * tVec.y));
R.Abs();
var absR:b2Mat22 = R;
tVec = m_obb.extents;
var hX:Number = ((absR.col1.x * tVec.x) + (absR.col2.x * tVec.y));
var hY:Number = ((absR.col1.y * tVec.x) + (absR.col2.y * tVec.y));
tMat = xf.R;
tVec = m_obb.center;
var positionX:Number = (xf.position.x + ((tMat.col1.x * tVec.x) + (tMat.col2.x * tVec.y)));
var positionY:Number = (xf.position.y + ((tMat.col1.y * tVec.x) + (tMat.col2.y * tVec.y)));
aabb.lowerBound.Set((positionX - hX), (positionY - hY));
aabb.upperBound.Set((positionX + hX), (positionY + hY));
}
override public function ComputeSweptAABB(aabb:b2AABB, transform1:b2XForm, transform2:b2XForm):void{
var aabb1:b2AABB = s_sweptAABB1;
var aabb2:b2AABB = s_sweptAABB2;
ComputeAABB(aabb1, transform1);
ComputeAABB(aabb2, transform2);
aabb.lowerBound.Set(((aabb1.lowerBound.x < aabb2.lowerBound.x)) ? aabb1.lowerBound.x : aabb2.lowerBound.x, ((aabb1.lowerBound.y < aabb2.lowerBound.y)) ? aabb1.lowerBound.y : aabb2.lowerBound.y);
aabb.upperBound.Set(((aabb1.upperBound.x > aabb2.upperBound.x)) ? aabb1.upperBound.x : aabb2.upperBound.x, ((aabb1.upperBound.y > aabb2.upperBound.y)) ? aabb1.upperBound.y : aabb2.upperBound.y);
}
override public function ComputeMass(massData:b2MassData):void{
var p2:b2Vec2;
var p3:b2Vec2;
var e1X:Number;
var e1Y:Number;
var e2X:Number;
var e2Y:Number;
var D:Number;
var triangleArea:Number;
var px:Number;
var py:Number;
var ex1:Number;
var ey1:Number;
var ex2:Number;
var ey2:Number;
var intx2:Number;
var inty2:Number;
var centerX:Number = 0;
var centerY:Number = 0;
var area:Number = 0;
var I:Number = 0;
var p1X:Number = 0;
var p1Y:Number = 0;
var k_inv3:Number = (1 / 3);
var i:int;
while (i < m_vertexCount) {
p2 = m_vertices[i];
p3 = (((i + 1) < m_vertexCount)) ? m_vertices[int((i + 1))] : m_vertices[0];
e1X = (p2.x - p1X);
e1Y = (p2.y - p1Y);
e2X = (p3.x - p1X);
e2Y = (p3.y - p1Y);
D = ((e1X * e2Y) - (e1Y * e2X));
triangleArea = (0.5 * D);
area = (area + triangleArea);
centerX = (centerX + ((triangleArea * k_inv3) * ((p1X + p2.x) + p3.x)));
centerY = (centerY + ((triangleArea * k_inv3) * ((p1Y + p2.y) + p3.y)));
px = p1X;
py = p1Y;
ex1 = e1X;
ey1 = e1Y;
ex2 = e2X;
ey2 = e2Y;
intx2 = ((k_inv3 * ((0.25 * (((ex1 * ex1) + (ex2 * ex1)) + (ex2 * ex2))) + ((px * ex1) + (px * ex2)))) + ((0.5 * px) * px));
inty2 = ((k_inv3 * ((0.25 * (((ey1 * ey1) + (ey2 * ey1)) + (ey2 * ey2))) + ((py * ey1) + (py * ey2)))) + ((0.5 * py) * py));
I = (I + (D * (intx2 + inty2)));
i++;
};
massData.mass = (m_density * area);
centerX = (centerX * (1 / area));
centerY = (centerY * (1 / area));
massData.center.Set(centerX, centerY);
massData.I = (m_density * I);
}
public function GetOBB():b2OBB{
return (m_obb);
}
public function GetCentroid():b2Vec2{
return (m_centroid);
}
public function GetVertexCount():int{
return (m_vertexCount);
}
public function GetVertices():Array{
return (m_vertices);
}
public function GetCoreVertices():Array{
return (m_coreVertices);
}
public function GetNormals():Array{
return (m_normals);
}
public function GetFirstVertex(xf:b2XForm):b2Vec2{
return (b2Math.b2MulX(xf, m_coreVertices[0]));
}
public function Centroid(xf:b2XForm):b2Vec2{
return (b2Math.b2MulX(xf, m_centroid));
}
public function Support(xf:b2XForm, dX:Number, dY:Number):b2Vec2{
var tVec:b2Vec2;
var tMat:b2Mat22;
var value:Number;
tMat = xf.R;
var dLocalX:Number = ((dX * tMat.col1.x) + (dY * tMat.col1.y));
var dLocalY:Number = ((dX * tMat.col2.x) + (dY * tMat.col2.y));
var bestIndex:int;
tVec = m_coreVertices[0];
var bestValue:Number = ((tVec.x * dLocalX) + (tVec.y * dLocalY));
var i = 1;
while (i < m_vertexCount) {
tVec = m_coreVertices[i];
value = ((tVec.x * dLocalX) + (tVec.y * dLocalY));
if (value > bestValue){
bestIndex = i;
bestValue = value;
};
i++;
};
tMat = xf.R;
tVec = m_coreVertices[bestIndex];
s_supportVec.x = (xf.position.x + ((tMat.col1.x * tVec.x) + (tMat.col2.x * tVec.y)));
s_supportVec.y = (xf.position.y + ((tMat.col1.y * tVec.x) + (tMat.col2.y * tVec.y)));
return (s_supportVec);
}
override public function UpdateSweepRadius(center:b2Vec2):void{
var tVec:b2Vec2;
var dX:Number;
var dY:Number;
m_sweepRadius = 0;
var i:int;
while (i < m_vertexCount) {
tVec = m_coreVertices[i];
dX = (tVec.x - center.x);
dY = (tVec.y - center.y);
dX = Math.sqrt(((dX * dX) + (dY * dY)));
if (dX > m_sweepRadius){
m_sweepRadius = dX;
};
i++;
};
}
public static function ComputeCentroid(vs:Array, count:int):b2Vec2{
var c:b2Vec2;
var inv3:Number;
var p2:b2Vec2;
var p3:b2Vec2;
var e1X:Number;
var e1Y:Number;
var e2X:Number;
var e2Y:Number;
var D:Number;
var triangleArea:Number;
c = new b2Vec2();
var area:Number = 0;
var p1X:Number = 0;
var p1Y:Number = 0;
inv3 = (1 / 3);
var i:int;
while (i < count) {
p2 = vs[i];
p3 = (((i + 1) < count)) ? vs[int((i + 1))] : vs[0];
e1X = (p2.x - p1X);
e1Y = (p2.y - p1Y);
e2X = (p3.x - p1X);
e2Y = (p3.y - p1Y);
D = ((e1X * e2Y) - (e1Y * e2X));
triangleArea = (0.5 * D);
area = (area + triangleArea);
c.x = (c.x + ((triangleArea * inv3) * ((p1X + p2.x) + p3.x)));
c.y = (c.y + ((triangleArea * inv3) * ((p1Y + p2.y) + p3.y)));
i++;
};
c.x = (c.x * (1 / area));
c.y = (c.y * (1 / area));
return (c);
}
public static function ComputeOBB(obb:b2OBB, vs:Array, count:int):void{
var i:int;
var root:b2Vec2;
var uxX:Number;
var uxY:Number;
var length:Number;
var uyX:Number;
var uyY:Number;
var lowerX:Number;
var lowerY:Number;
var upperX:Number;
var upperY:Number;
var j:int;
var area:Number;
var dX:Number;
var dY:Number;
var rX:Number;
var rY:Number;
var centerX:Number;
var centerY:Number;
var tMat:b2Mat22;
var p:Array = new Array((b2Settings.b2_maxPolygonVertices + 1));
i = 0;
while (i < count) {
p[i] = vs[i];
i++;
};
p[count] = p[0];
var minArea:Number = Number.MAX_VALUE;
i = 1;
while (i <= count) {
root = p[int((i - 1))];
uxX = (p[i].x - root.x);
uxY = (p[i].y - root.y);
length = Math.sqrt(((uxX * uxX) + (uxY * uxY)));
uxX = (uxX / length);
uxY = (uxY / length);
uyX = -(uxY);
uyY = uxX;
lowerX = Number.MAX_VALUE;
lowerY = Number.MAX_VALUE;
upperX = -(Number.MAX_VALUE);
upperY = -(Number.MAX_VALUE);
j = 0;
while (j < count) {
dX = (p[j].x - root.x);
dY = (p[j].y - root.y);
rX = ((uxX * dX) + (uxY * dY));
rY = ((uyX * dX) + (uyY * dY));
if (rX < lowerX){
lowerX = rX;
};
if (rY < lowerY){
lowerY = rY;
};
if (rX > upperX){
upperX = rX;
};
if (rY > upperY){
upperY = rY;
};
j++;
};
area = ((upperX - lowerX) * (upperY - lowerY));
if (area < (0.95 * minArea)){
minArea = area;
obb.R.col1.x = uxX;
obb.R.col1.y = uxY;
obb.R.col2.x = uyX;
obb.R.col2.y = uyY;
centerX = (0.5 * (lowerX + upperX));
centerY = (0.5 * (lowerY + upperY));
tMat = obb.R;
obb.center.x = (root.x + ((tMat.col1.x * centerX) + (tMat.col2.x * centerY)));
obb.center.y = (root.y + ((tMat.col1.y * centerX) + (tMat.col2.y * centerY)));
obb.extents.x = (0.5 * (upperX - lowerX));
obb.extents.y = (0.5 * (upperY - lowerY));
};
i++;
};
}
}
}//package Box2D.Collision.Shapes
Section 8
//b2Shape (Box2D.Collision.Shapes.b2Shape)
package Box2D.Collision.Shapes {
import Box2D.Common.Math.*;
import Box2D.Dynamics.*;
import Box2D.Collision.*;
public class b2Shape {
public var m_type:int;
public var m_next:b2Shape;
public var m_body:b2Body;
public var m_sweepRadius:Number;
public var m_density:Number;
public var m_friction:Number;
public var m_restitution:Number;
public var m_proxyId:uint;
public var m_filter:b2FilterData;
public var m_isSensor:Boolean;
public var m_userData;
public static const e_unknownShape:int = -1;
public static const e_circleShape:int = 0;
public static const e_polygonShape:int = 1;
public static const e_shapeTypeCount:int = 2;
private static var s_proxyAABB:b2AABB = new b2AABB();
private static var s_syncAABB:b2AABB = new b2AABB();
private static var s_resetAABB:b2AABB = new b2AABB();
public function b2Shape(def:b2ShapeDef){
super();
m_userData = def.userData;
m_friction = def.friction;
m_restitution = def.restitution;
m_density = def.density;
m_body = null;
m_sweepRadius = 0;
m_next = null;
m_proxyId = b2Pair.b2_nullProxy;
m_filter = def.filter.Copy();
m_isSensor = def.isSensor;
}
public function GetType():int{
return (m_type);
}
public function IsSensor():Boolean{
return (m_isSensor);
}
public function SetFilterData(filter:b2FilterData):void{
m_filter = filter.Copy();
}
public function GetFilterData():b2FilterData{
return (m_filter.Copy());
}
public function GetBody():b2Body{
return (m_body);
}
public function GetNext():b2Shape{
return (m_next);
}
public function GetUserData(){
return (m_userData);
}
public function SetUserData(data):void{
m_userData = data;
}
public function TestPoint(xf:b2XForm, p:b2Vec2):Boolean{
return (false);
}
public function TestSegment(xf:b2XForm, lambda:Array, normal:b2Vec2, segment:b2Segment, maxLambda:Number):Boolean{
return (false);
}
public function ComputeAABB(aabb:b2AABB, xf:b2XForm):void{
}
public function ComputeSweptAABB(aabb:b2AABB, xf1:b2XForm, xf2:b2XForm):void{
}
public function ComputeMass(massData:b2MassData):void{
}
public function GetSweepRadius():Number{
return (m_sweepRadius);
}
public function GetFriction():Number{
return (m_friction);
}
public function GetRestitution():Number{
return (m_restitution);
}
public function CreateProxy(broadPhase:b2BroadPhase, transform:b2XForm):void{
var aabb:b2AABB = s_proxyAABB;
ComputeAABB(aabb, transform);
var inRange:Boolean = broadPhase.InRange(aabb);
if (inRange){
m_proxyId = broadPhase.CreateProxy(aabb, this);
} else {
m_proxyId = b2Pair.b2_nullProxy;
};
}
public function DestroyProxy(broadPhase:b2BroadPhase):void{
if (m_proxyId != b2Pair.b2_nullProxy){
broadPhase.DestroyProxy(m_proxyId);
m_proxyId = b2Pair.b2_nullProxy;
};
}
public function Synchronize(broadPhase:b2BroadPhase, transform1:b2XForm, transform2:b2XForm):Boolean{
if (m_proxyId == b2Pair.b2_nullProxy){
return (false);
};
var aabb:b2AABB = s_syncAABB;
ComputeSweptAABB(aabb, transform1, transform2);
if (broadPhase.InRange(aabb)){
broadPhase.MoveProxy(m_proxyId, aabb);
return (true);
};
return (false);
}
public function RefilterProxy(broadPhase:b2BroadPhase, transform:b2XForm):void{
if (m_proxyId == b2Pair.b2_nullProxy){
return;
};
broadPhase.DestroyProxy(m_proxyId);
var aabb:b2AABB = s_resetAABB;
ComputeAABB(aabb, transform);
var inRange:Boolean = broadPhase.InRange(aabb);
if (inRange){
m_proxyId = broadPhase.CreateProxy(aabb, this);
} else {
m_proxyId = b2Pair.b2_nullProxy;
};
}
public function UpdateSweepRadius(center:b2Vec2):void{
}
public static function Create(def:b2ShapeDef, allocator):b2Shape{
switch (def.type){
case e_circleShape:
return (new b2CircleShape(def));
case e_polygonShape:
return (new b2PolygonShape(def));
default:
return (null);
};
}
public static function Destroy(shape:b2Shape, allocator):void{
}
}
}//package Box2D.Collision.Shapes
Section 9
//b2ShapeDef (Box2D.Collision.Shapes.b2ShapeDef)
package Box2D.Collision.Shapes {
public class b2ShapeDef {
public var type:int;// = -1
public var userData;// = null
public var friction:Number;// = 0.2
public var restitution:Number;// = 0
public var density:Number;// = 0
public var isSensor:Boolean;// = false
public var filter:b2FilterData;
public function b2ShapeDef(){
filter = new b2FilterData();
super();
}
}
}//package Box2D.Collision.Shapes
Section 10
//b2AABB (Box2D.Collision.b2AABB)
package Box2D.Collision {
import Box2D.Common.Math.*;
public class b2AABB {
public var lowerBound:b2Vec2;
public var upperBound:b2Vec2;
public function b2AABB(){
lowerBound = new b2Vec2();
upperBound = new b2Vec2();
super();
}
public function IsValid():Boolean{
var dX:Number = (upperBound.x - lowerBound.x);
var dY:Number = (upperBound.y - lowerBound.y);
var valid:Boolean = (((dX >= 0)) && ((dY >= 0)));
valid = ((((valid) && (lowerBound.IsValid()))) && (upperBound.IsValid()));
return (valid);
}
}
}//package Box2D.Collision
Section 11
//b2Bound (Box2D.Collision.b2Bound)
package Box2D.Collision {
public class b2Bound {
public var value:uint;
public var proxyId:uint;
public var stabbingCount:uint;
public function IsLower():Boolean{
return (((value & 1) == 0));
}
public function IsUpper():Boolean{
return (((value & 1) == 1));
}
public function Swap(b:b2Bound):void{
var tempValue:uint = value;
var tempProxyId:uint = proxyId;
var tempStabbingCount:uint = stabbingCount;
value = b.value;
proxyId = b.proxyId;
stabbingCount = b.stabbingCount;
b.value = tempValue;
b.proxyId = tempProxyId;
b.stabbingCount = tempStabbingCount;
}
}
}//package Box2D.Collision
Section 12
//b2BoundValues (Box2D.Collision.b2BoundValues)
package Box2D.Collision {
public class b2BoundValues {
public var lowerValues:Array;
public var upperValues:Array;
public function b2BoundValues(){
lowerValues = [0, 0];
upperValues = [0, 0];
super();
}
}
}//package Box2D.Collision
Section 13
//b2BroadPhase (Box2D.Collision.b2BroadPhase)
package Box2D.Collision {
import Box2D.Common.Math.*;
import Box2D.Common.*;
public class b2BroadPhase {
public var m_pairManager:b2PairManager;
public var m_proxyPool:Array;
public var m_freeProxy:uint;
public var m_bounds:Array;
public var m_queryResults:Array;
public var m_queryResultCount:int;
public var m_worldAABB:b2AABB;
public var m_quantizationFactor:b2Vec2;
public var m_proxyCount:int;
public var m_timeStamp:uint;
public static const b2_invalid:uint = b2Settings.USHRT_MAX;
public static const b2_nullEdge:uint = b2Settings.USHRT_MAX;
public static var s_validate:Boolean = false;
public function b2BroadPhase(worldAABB:b2AABB, callback:b2PairCallback){
var i:int;
var dY:Number;
var tProxy:b2Proxy;
var j:int;
m_pairManager = new b2PairManager();
m_proxyPool = new Array(b2Settings.b2_maxPairs);
m_bounds = new Array((2 * b2Settings.b2_maxProxies));
m_queryResults = new Array(b2Settings.b2_maxProxies);
m_quantizationFactor = new b2Vec2();
super();
m_pairManager.Initialize(this, callback);
m_worldAABB = worldAABB;
m_proxyCount = 0;
i = 0;
while (i < b2Settings.b2_maxProxies) {
m_queryResults[i] = 0;
i++;
};
m_bounds = new Array(2);
i = 0;
while (i < 2) {
m_bounds[i] = new Array((2 * b2Settings.b2_maxProxies));
j = 0;
while (j < (2 * b2Settings.b2_maxProxies)) {
m_bounds[i][j] = new b2Bound();
j++;
};
i++;
};
var dX:Number = (worldAABB.upperBound.x - worldAABB.lowerBound.x);
dY = (worldAABB.upperBound.y - worldAABB.lowerBound.y);
m_quantizationFactor.x = (b2Settings.USHRT_MAX / dX);
m_quantizationFactor.y = (b2Settings.USHRT_MAX / dY);
i = 0;
while (i < (b2Settings.b2_maxProxies - 1)) {
tProxy = new b2Proxy();
m_proxyPool[i] = tProxy;
tProxy.SetNext((i + 1));
tProxy.timeStamp = 0;
tProxy.overlapCount = b2_invalid;
tProxy.userData = null;
i++;
};
tProxy = new b2Proxy();
m_proxyPool[int((b2Settings.b2_maxProxies - 1))] = tProxy;
tProxy.SetNext(b2Pair.b2_nullProxy);
tProxy.timeStamp = 0;
tProxy.overlapCount = b2_invalid;
tProxy.userData = null;
m_freeProxy = 0;
m_timeStamp = 1;
m_queryResultCount = 0;
}
public function InRange(aabb:b2AABB):Boolean{
var dX:Number;
var dY:Number;
var d2X:Number;
var d2Y:Number;
dX = aabb.lowerBound.x;
dY = aabb.lowerBound.y;
dX = (dX - m_worldAABB.upperBound.x);
dY = (dY - m_worldAABB.upperBound.y);
d2X = m_worldAABB.lowerBound.x;
d2Y = m_worldAABB.lowerBound.y;
d2X = (d2X - aabb.upperBound.x);
d2Y = (d2Y - aabb.upperBound.y);
dX = b2Math.b2Max(dX, d2X);
dY = b2Math.b2Max(dY, d2Y);
return ((b2Math.b2Max(dX, dY) < 0));
}
public function GetProxy(proxyId:int):b2Proxy{
var proxy:b2Proxy = m_proxyPool[proxyId];
if ((((proxyId == b2Pair.b2_nullProxy)) || ((proxy.IsValid() == false)))){
return (null);
};
return (proxy);
}
public function CreateProxy(aabb:b2AABB, userData):uint{
var index:uint;
var proxy:b2Proxy;
var bounds:Array;
var lowerIndex:uint;
var upperIndex:uint;
var lowerIndexOut:Array;
var upperIndexOut:Array;
var tArr:Array;
var j:int;
var tEnd:int;
var tBound1:b2Bound;
var tBound2:b2Bound;
var tBoundAS3:b2Bound;
var tIndex:int;
var proxy2:b2Proxy;
var proxyId:uint = m_freeProxy;
proxy = m_proxyPool[proxyId];
m_freeProxy = proxy.GetNext();
proxy.overlapCount = 0;
proxy.userData = userData;
var boundCount:uint = (2 * m_proxyCount);
var lowerValues:Array = new Array();
var upperValues:Array = new Array();
ComputeBounds(lowerValues, upperValues, aabb);
var axis:int;
while (axis < 2) {
bounds = m_bounds[axis];
lowerIndexOut = [lowerIndex];
upperIndexOut = [upperIndex];
Query(lowerIndexOut, upperIndexOut, lowerValues[axis], upperValues[axis], bounds, boundCount, axis);
lowerIndex = lowerIndexOut[0];
upperIndex = upperIndexOut[0];
tArr = new Array();
tEnd = (boundCount - upperIndex);
j = 0;
while (j < tEnd) {
tArr[j] = new b2Bound();
tBound1 = tArr[j];
tBound2 = bounds[int((upperIndex + j))];
tBound1.value = tBound2.value;
tBound1.proxyId = tBound2.proxyId;
tBound1.stabbingCount = tBound2.stabbingCount;
j++;
};
tEnd = tArr.length;
tIndex = (upperIndex + 2);
j = 0;
while (j < tEnd) {
tBound2 = tArr[j];
tBound1 = bounds[int((tIndex + j))];
tBound1.value = tBound2.value;
tBound1.proxyId = tBound2.proxyId;
tBound1.stabbingCount = tBound2.stabbingCount;
j++;
};
tArr = new Array();
tEnd = (upperIndex - lowerIndex);
j = 0;
while (j < tEnd) {
tArr[j] = new b2Bound();
tBound1 = tArr[j];
tBound2 = bounds[int((lowerIndex + j))];
tBound1.value = tBound2.value;
tBound1.proxyId = tBound2.proxyId;
tBound1.stabbingCount = tBound2.stabbingCount;
j++;
};
tEnd = tArr.length;
tIndex = (lowerIndex + 1);
j = 0;
while (j < tEnd) {
tBound2 = tArr[j];
tBound1 = bounds[int((tIndex + j))];
tBound1.value = tBound2.value;
tBound1.proxyId = tBound2.proxyId;
tBound1.stabbingCount = tBound2.stabbingCount;
j++;
};
upperIndex++;
tBound1 = bounds[lowerIndex];
tBound2 = bounds[upperIndex];
tBound1.value = lowerValues[axis];
tBound1.proxyId = proxyId;
tBound2.value = upperValues[axis];
tBound2.proxyId = proxyId;
tBoundAS3 = bounds[int((lowerIndex - 1))];
tBound1.stabbingCount = ((lowerIndex == 0)) ? 0 : tBoundAS3.stabbingCount;
tBoundAS3 = bounds[int((upperIndex - 1))];
tBound2.stabbingCount = tBoundAS3.stabbingCount;
index = lowerIndex;
while (index < upperIndex) {
tBoundAS3 = bounds[index];
tBoundAS3.stabbingCount++;
index++;
};
index = lowerIndex;
while (index < (boundCount + 2)) {
tBound1 = bounds[index];
proxy2 = m_proxyPool[tBound1.proxyId];
if (tBound1.IsLower()){
proxy2.lowerBounds[axis] = index;
} else {
proxy2.upperBounds[axis] = index;
};
index++;
};
axis++;
};
m_proxyCount++;
var i:int;
while (i < m_queryResultCount) {
m_pairManager.AddBufferedPair(proxyId, m_queryResults[i]);
i++;
};
m_pairManager.Commit();
m_queryResultCount = 0;
IncrementTimeStamp();
return (proxyId);
}
public function DestroyProxy(proxyId:uint):void{
var tBound1:b2Bound;
var tBound2:b2Bound;
var bounds:Array;
var lowerIndex:uint;
var upperIndex:uint;
var lowerValue:uint;
var upperValue:uint;
var tArr:Array;
var j:int;
var tEnd:int;
var tIndex:int;
var index:uint;
var index2:int;
var proxy2:b2Proxy;
var proxy:b2Proxy = m_proxyPool[proxyId];
var boundCount:int = (2 * m_proxyCount);
var axis:int;
while (axis < 2) {
bounds = m_bounds[axis];
lowerIndex = proxy.lowerBounds[axis];
upperIndex = proxy.upperBounds[axis];
tBound1 = bounds[lowerIndex];
lowerValue = tBound1.value;
tBound2 = bounds[upperIndex];
upperValue = tBound2.value;
tArr = new Array();
tEnd = ((upperIndex - lowerIndex) - 1);
j = 0;
while (j < tEnd) {
tArr[j] = new b2Bound();
tBound1 = tArr[j];
tBound2 = bounds[int(((lowerIndex + 1) + j))];
tBound1.value = tBound2.value;
tBound1.proxyId = tBound2.proxyId;
tBound1.stabbingCount = tBound2.stabbingCount;
j++;
};
tEnd = tArr.length;
tIndex = lowerIndex;
j = 0;
while (j < tEnd) {
tBound2 = tArr[j];
tBound1 = bounds[int((tIndex + j))];
tBound1.value = tBound2.value;
tBound1.proxyId = tBound2.proxyId;
tBound1.stabbingCount = tBound2.stabbingCount;
j++;
};
tArr = new Array();
tEnd = ((boundCount - upperIndex) - 1);
j = 0;
while (j < tEnd) {
tArr[j] = new b2Bound();
tBound1 = tArr[j];
tBound2 = bounds[int(((upperIndex + 1) + j))];
tBound1.value = tBound2.value;
tBound1.proxyId = tBound2.proxyId;
tBound1.stabbingCount = tBound2.stabbingCount;
j++;
};
tEnd = tArr.length;
tIndex = (upperIndex - 1);
j = 0;
while (j < tEnd) {
tBound2 = tArr[j];
tBound1 = bounds[int((tIndex + j))];
tBound1.value = tBound2.value;
tBound1.proxyId = tBound2.proxyId;
tBound1.stabbingCount = tBound2.stabbingCount;
j++;
};
tEnd = (boundCount - 2);
index = lowerIndex;
while (index < tEnd) {
tBound1 = bounds[index];
proxy2 = m_proxyPool[tBound1.proxyId];
if (tBound1.IsLower()){
proxy2.lowerBounds[axis] = index;
} else {
proxy2.upperBounds[axis] = index;
};
index++;
};
tEnd = (upperIndex - 1);
index2 = lowerIndex;
while (index2 < tEnd) {
tBound1 = bounds[index2];
tBound1.stabbingCount--;
index2++;
};
Query([0], [0], lowerValue, upperValue, bounds, (boundCount - 2), axis);
axis++;
};
var i:int;
while (i < m_queryResultCount) {
m_pairManager.RemoveBufferedPair(proxyId, m_queryResults[i]);
i++;
};
m_pairManager.Commit();
m_queryResultCount = 0;
IncrementTimeStamp();
proxy.userData = null;
proxy.overlapCount = b2_invalid;
proxy.lowerBounds[0] = b2_invalid;
proxy.lowerBounds[1] = b2_invalid;
proxy.upperBounds[0] = b2_invalid;
proxy.upperBounds[1] = b2_invalid;
proxy.SetNext(m_freeProxy);
m_freeProxy = proxyId;
m_proxyCount--;
}
public function MoveProxy(proxyId:uint, aabb:b2AABB):void{
var as3arr:Array;
var as3int:int;
var axis:uint;
var index:uint;
var bound:b2Bound;
var prevBound:b2Bound;
var nextBound:b2Bound;
var nextProxyId:uint;
var nextProxy:b2Proxy;
var bounds:Array;
var lowerIndex:uint;
var upperIndex:uint;
var lowerValue:uint;
var upperValue:uint;
var deltaLower:int;
var deltaUpper:int;
var prevProxyId:uint;
var prevProxy:b2Proxy;
if ((((proxyId == b2Pair.b2_nullProxy)) || ((b2Settings.b2_maxProxies <= proxyId)))){
return;
};
if (aabb.IsValid() == false){
return;
};
var boundCount:uint = (2 * m_proxyCount);
var proxy:b2Proxy = m_proxyPool[proxyId];
var newValues:b2BoundValues = new b2BoundValues();
ComputeBounds(newValues.lowerValues, newValues.upperValues, aabb);
var oldValues:b2BoundValues = new b2BoundValues();
axis = 0;
while (axis < 2) {
bound = m_bounds[axis][proxy.lowerBounds[axis]];
oldValues.lowerValues[axis] = bound.value;
bound = m_bounds[axis][proxy.upperBounds[axis]];
oldValues.upperValues[axis] = bound.value;
axis++;
};
axis = 0;
while (axis < 2) {
bounds = m_bounds[axis];
lowerIndex = proxy.lowerBounds[axis];
upperIndex = proxy.upperBounds[axis];
lowerValue = newValues.lowerValues[axis];
upperValue = newValues.upperValues[axis];
bound = bounds[lowerIndex];
deltaLower = (lowerValue - bound.value);
bound.value = lowerValue;
bound = bounds[upperIndex];
deltaUpper = (upperValue - bound.value);
bound.value = upperValue;
if (deltaLower < 0){
index = lowerIndex;
while ((((index > 0)) && ((lowerValue < (bounds[int((index - 1))] as b2Bound).value)))) {
bound = bounds[index];
prevBound = bounds[int((index - 1))];
prevProxyId = prevBound.proxyId;
prevProxy = m_proxyPool[prevBound.proxyId];
prevBound.stabbingCount++;
if (prevBound.IsUpper() == true){
if (TestOverlap(newValues, prevProxy)){
m_pairManager.AddBufferedPair(proxyId, prevProxyId);
};
as3arr = prevProxy.upperBounds;
as3int = as3arr[axis];
as3int++;
as3arr[axis] = as3int;
bound.stabbingCount++;
} else {
as3arr = prevProxy.lowerBounds;
as3int = as3arr[axis];
as3int++;
as3arr[axis] = as3int;
bound.stabbingCount--;
};
as3arr = proxy.lowerBounds;
as3int = as3arr[axis];
as3int--;
as3arr[axis] = as3int;
bound.Swap(prevBound);
index--;
};
};
if (deltaUpper > 0){
index = upperIndex;
while ((((index < (boundCount - 1))) && (((bounds[int((index + 1))] as b2Bound).value <= upperValue)))) {
bound = bounds[index];
nextBound = bounds[int((index + 1))];
nextProxyId = nextBound.proxyId;
nextProxy = m_proxyPool[nextProxyId];
nextBound.stabbingCount++;
if (nextBound.IsLower() == true){
if (TestOverlap(newValues, nextProxy)){
m_pairManager.AddBufferedPair(proxyId, nextProxyId);
};
as3arr = nextProxy.lowerBounds;
as3int = as3arr[axis];
as3int--;
as3arr[axis] = as3int;
bound.stabbingCount++;
} else {
as3arr = nextProxy.upperBounds;
as3int = as3arr[axis];
as3int--;
as3arr[axis] = as3int;
bound.stabbingCount--;
};
as3arr = proxy.upperBounds;
as3int = as3arr[axis];
as3int++;
as3arr[axis] = as3int;
bound.Swap(nextBound);
index++;
};
};
if (deltaLower > 0){
index = lowerIndex;
while ((((index < (boundCount - 1))) && (((bounds[int((index + 1))] as b2Bound).value <= lowerValue)))) {
bound = bounds[index];
nextBound = bounds[int((index + 1))];
nextProxyId = nextBound.proxyId;
nextProxy = m_proxyPool[nextProxyId];
nextBound.stabbingCount--;
if (nextBound.IsUpper()){
if (TestOverlap(oldValues, nextProxy)){
m_pairManager.RemoveBufferedPair(proxyId, nextProxyId);
};
as3arr = nextProxy.upperBounds;
as3int = as3arr[axis];
as3int--;
as3arr[axis] = as3int;
bound.stabbingCount--;
} else {
as3arr = nextProxy.lowerBounds;
as3int = as3arr[axis];
as3int--;
as3arr[axis] = as3int;
bound.stabbingCount++;
};
as3arr = proxy.lowerBounds;
as3int = as3arr[axis];
as3int++;
as3arr[axis] = as3int;
bound.Swap(nextBound);
index++;
};
};
if (deltaUpper < 0){
index = upperIndex;
while ((((index > 0)) && ((upperValue < (bounds[int((index - 1))] as b2Bound).value)))) {
bound = bounds[index];
prevBound = bounds[int((index - 1))];
prevProxyId = prevBound.proxyId;
prevProxy = m_proxyPool[prevProxyId];
prevBound.stabbingCount--;
if (prevBound.IsLower() == true){
if (TestOverlap(oldValues, prevProxy)){
m_pairManager.RemoveBufferedPair(proxyId, prevProxyId);
};
as3arr = prevProxy.lowerBounds;
as3int = as3arr[axis];
as3int++;
as3arr[axis] = as3int;
bound.stabbingCount--;
} else {
as3arr = prevProxy.upperBounds;
as3int = as3arr[axis];
as3int++;
as3arr[axis] = as3int;
bound.stabbingCount++;
};
as3arr = proxy.upperBounds;
as3int = as3arr[axis];
as3int--;
as3arr[axis] = as3int;
bound.Swap(prevBound);
index--;
};
};
axis++;
};
}
public function Commit():void{
m_pairManager.Commit();
}
public function QueryAABB(aabb:b2AABB, userData, maxCount:int):int{
var lowerIndex:uint;
var upperIndex:uint;
var proxy:b2Proxy;
var lowerValues:Array = new Array();
var upperValues:Array = new Array();
ComputeBounds(lowerValues, upperValues, aabb);
var lowerIndexOut:Array = [lowerIndex];
var upperIndexOut:Array = [upperIndex];
Query(lowerIndexOut, upperIndexOut, lowerValues[0], upperValues[0], m_bounds[0], (2 * m_proxyCount), 0);
Query(lowerIndexOut, upperIndexOut, lowerValues[1], upperValues[1], m_bounds[1], (2 * m_proxyCount), 1);
var count:int;
var i:int;
while ((((i < m_queryResultCount)) && ((count < maxCount)))) {
proxy = m_proxyPool[m_queryResults[i]];
userData[i] = proxy.userData;
i++;
count++;
};
m_queryResultCount = 0;
IncrementTimeStamp();
return (count);
}
public function Validate():void{
var pair:b2Pair;
var proxy1:b2Proxy;
var proxy2:b2Proxy;
var overlap:Boolean;
var bounds:b2Bound;
var boundCount:uint;
var stabbingCount:uint;
var i:uint;
var bound:b2Bound;
var axis:int;
while (axis < 2) {
bounds = m_bounds[axis];
boundCount = (2 * m_proxyCount);
stabbingCount = 0;
i = 0;
while (i < boundCount) {
bound = bounds[i];
if (bound.IsLower() == true){
stabbingCount++;
} else {
stabbingCount--;
};
i++;
};
axis++;
};
}
private function ComputeBounds(lowerValues:Array, upperValues:Array, aabb:b2AABB):void{
var minVertexX:Number = aabb.lowerBound.x;
var minVertexY:Number = aabb.lowerBound.y;
minVertexX = b2Math.b2Min(minVertexX, m_worldAABB.upperBound.x);
minVertexY = b2Math.b2Min(minVertexY, m_worldAABB.upperBound.y);
minVertexX = b2Math.b2Max(minVertexX, m_worldAABB.lowerBound.x);
minVertexY = b2Math.b2Max(minVertexY, m_worldAABB.lowerBound.y);
var maxVertexX:Number = aabb.upperBound.x;
var maxVertexY:Number = aabb.upperBound.y;
maxVertexX = b2Math.b2Min(maxVertexX, m_worldAABB.upperBound.x);
maxVertexY = b2Math.b2Min(maxVertexY, m_worldAABB.upperBound.y);
maxVertexX = b2Math.b2Max(maxVertexX, m_worldAABB.lowerBound.x);
maxVertexY = b2Math.b2Max(maxVertexY, m_worldAABB.lowerBound.y);
lowerValues[0] = (uint((m_quantizationFactor.x * (minVertexX - m_worldAABB.lowerBound.x))) & (b2Settings.USHRT_MAX - 1));
upperValues[0] = ((uint((m_quantizationFactor.x * (maxVertexX - m_worldAABB.lowerBound.x))) & 0xFFFF) | 1);
lowerValues[1] = (uint((m_quantizationFactor.y * (minVertexY - m_worldAABB.lowerBound.y))) & (b2Settings.USHRT_MAX - 1));
upperValues[1] = ((uint((m_quantizationFactor.y * (maxVertexY - m_worldAABB.lowerBound.y))) & 0xFFFF) | 1);
}
private function TestOverlapValidate(p1:b2Proxy, p2:b2Proxy):Boolean{
var bounds:Array;
var bound1:b2Bound;
var bound2:b2Bound;
var axis:int;
while (axis < 2) {
bounds = m_bounds[axis];
bound1 = bounds[p1.lowerBounds[axis]];
bound2 = bounds[p2.upperBounds[axis]];
if (bound1.value > bound2.value){
return (false);
};
bound1 = bounds[p1.upperBounds[axis]];
bound2 = bounds[p2.lowerBounds[axis]];
if (bound1.value < bound2.value){
return (false);
};
axis++;
};
return (true);
}
public function TestOverlap(b:b2BoundValues, p:b2Proxy):Boolean{
var bounds:Array;
var bound:b2Bound;
var axis:int;
while (axis < 2) {
bounds = m_bounds[axis];
bound = bounds[p.upperBounds[axis]];
if (b.lowerValues[axis] > bound.value){
return (false);
};
bound = bounds[p.lowerBounds[axis]];
if (b.upperValues[axis] < bound.value){
return (false);
};
axis++;
};
return (true);
}
private function Query(lowerQueryOut:Array, upperQueryOut:Array, lowerValue:uint, upperValue:uint, bounds:Array, boundCount:uint, axis:int):void{
var bound:b2Bound;
var i:int;
var s:int;
var proxy:b2Proxy;
var lowerQuery:uint = BinarySearch(bounds, boundCount, lowerValue);
var upperQuery:uint = BinarySearch(bounds, boundCount, upperValue);
var j:uint = lowerQuery;
while (j < upperQuery) {
bound = bounds[j];
if (bound.IsLower()){
IncrementOverlapCount(bound.proxyId);
};
j++;
};
if (lowerQuery > 0){
i = (lowerQuery - 1);
bound = bounds[i];
s = bound.stabbingCount;
while (s) {
bound = bounds[i];
if (bound.IsLower()){
proxy = m_proxyPool[bound.proxyId];
if (lowerQuery <= proxy.upperBounds[axis]){
IncrementOverlapCount(bound.proxyId);
s--;
};
};
i--;
};
};
lowerQueryOut[0] = lowerQuery;
upperQueryOut[0] = upperQuery;
}
private function IncrementOverlapCount(proxyId:uint):void{
var proxy:b2Proxy = m_proxyPool[proxyId];
if (proxy.timeStamp < m_timeStamp){
proxy.timeStamp = m_timeStamp;
proxy.overlapCount = 1;
} else {
proxy.overlapCount = 2;
m_queryResults[m_queryResultCount] = proxyId;
m_queryResultCount++;
};
}
private function IncrementTimeStamp():void{
var i:uint;
if (m_timeStamp == b2Settings.USHRT_MAX){
i = 0;
while (i < b2Settings.b2_maxProxies) {
(m_proxyPool[i] as b2Proxy).timeStamp = 0;
i++;
};
m_timeStamp = 1;
} else {
m_timeStamp++;
};
}
public static function BinarySearch(bounds:Array, count:int, value:uint):uint{
var mid:int;
var bound:b2Bound;
var low:int;
var high:int = (count - 1);
while (low <= high) {
mid = ((low + high) / 2);
bound = bounds[mid];
if (bound.value > value){
high = (mid - 1);
} else {
if (bound.value < value){
low = (mid + 1);
} else {
return (uint(mid));
};
};
};
return (uint(low));
}
}
}//package Box2D.Collision
Section 14
//b2BufferedPair (Box2D.Collision.b2BufferedPair)
package Box2D.Collision {
public class b2BufferedPair {
public var proxyId1:uint;
public var proxyId2:uint;
}
}//package Box2D.Collision
Section 15
//b2Collision (Box2D.Collision.b2Collision)
package Box2D.Collision {
import Box2D.Collision.Shapes.*;
import Box2D.Common.Math.*;
import Box2D.Common.*;
public class b2Collision {
public static const b2_nullFeature:uint = 0xFF;
private static var b2CollidePolyTempVec:b2Vec2 = new b2Vec2();
public static function ClipSegmentToLine(vOut:Array, vIn:Array, normal:b2Vec2, offset:Number):int{
var cv:ClipVertex;
var numOut:int;
var vIn0:b2Vec2;
var vIn1:b2Vec2;
var distance0:Number;
var interp:Number;
var tVec:b2Vec2;
var cv2:ClipVertex;
numOut = 0;
cv = vIn[0];
vIn0 = cv.v;
cv = vIn[1];
vIn1 = cv.v;
distance0 = (b2Math.b2Dot(normal, vIn0) - offset);
var distance1:Number = (b2Math.b2Dot(normal, vIn1) - offset);
if (distance0 <= 0){
var _temp1 = numOut;
numOut = (numOut + 1);
var _local14 = _temp1;
vOut[_local14] = vIn[0];
};
if (distance1 <= 0){
var _temp2 = numOut;
numOut = (numOut + 1);
_local14 = _temp2;
vOut[_local14] = vIn[1];
};
if ((distance0 * distance1) < 0){
interp = (distance0 / (distance0 - distance1));
cv = vOut[numOut];
tVec = cv.v;
tVec.x = (vIn0.x + (interp * (vIn1.x - vIn0.x)));
tVec.y = (vIn0.y + (interp * (vIn1.y - vIn0.y)));
cv = vOut[numOut];
if (distance0 > 0){
cv2 = vIn[0];
cv.id = cv2.id;
} else {
cv2 = vIn[1];
cv.id = cv2.id;
};
numOut++;
};
return (numOut);
}
public static function EdgeSeparation(poly1:b2PolygonShape, xf1:b2XForm, edge1:int, poly2:b2PolygonShape, xf2:b2XForm):Number{
var tMat:b2Mat22;
var tVec:b2Vec2;
var dot:Number;
var count1:int = poly1.m_vertexCount;
var vertices1:Array = poly1.m_vertices;
var normals1:Array = poly1.m_normals;
var count2:int = poly2.m_vertexCount;
var vertices2:Array = poly2.m_vertices;
tMat = xf1.R;
tVec = normals1[edge1];
var normal1WorldX:Number = ((tMat.col1.x * tVec.x) + (tMat.col2.x * tVec.y));
var normal1WorldY:Number = ((tMat.col1.y * tVec.x) + (tMat.col2.y * tVec.y));
tMat = xf2.R;
var normal1X:Number = ((tMat.col1.x * normal1WorldX) + (tMat.col1.y * normal1WorldY));
var normal1Y:Number = ((tMat.col2.x * normal1WorldX) + (tMat.col2.y * normal1WorldY));
var index:int;
var minDot:Number = Number.MAX_VALUE;
var i:int;
while (i < count2) {
tVec = vertices2[i];
dot = ((tVec.x * normal1X) + (tVec.y * normal1Y));
if (dot < minDot){
minDot = dot;
index = i;
};
i++;
};
tVec = vertices1[edge1];
tMat = xf1.R;
var v1X:Number = (xf1.position.x + ((tMat.col1.x * tVec.x) + (tMat.col2.x * tVec.y)));
var v1Y:Number = (xf1.position.y + ((tMat.col1.y * tVec.x) + (tMat.col2.y * tVec.y)));
tVec = vertices2[index];
tMat = xf2.R;
var v2X:Number = (xf2.position.x + ((tMat.col1.x * tVec.x) + (tMat.col2.x * tVec.y)));
var v2Y:Number = (xf2.position.y + ((tMat.col1.y * tVec.x) + (tMat.col2.y * tVec.y)));
v2X = (v2X - v1X);
v2Y = (v2Y - v1Y);
var separation:Number = ((v2X * normal1WorldX) + (v2Y * normal1WorldY));
return (separation);
}
public static function FindMaxSeparation(edgeIndex:Array, poly1:b2PolygonShape, xf1:b2XForm, poly2:b2PolygonShape, xf2:b2XForm):Number{
var tVec:b2Vec2;
var tMat:b2Mat22;
var bestEdge:int;
var bestSeparation:Number;
var increment:int;
var dot:Number;
var count1:int = poly1.m_vertexCount;
var normals1:Array = poly1.m_normals;
tMat = xf2.R;
tVec = poly2.m_centroid;
var dX:Number = (xf2.position.x + ((tMat.col1.x * tVec.x) + (tMat.col2.x * tVec.y)));
var dY:Number = (xf2.position.y + ((tMat.col1.y * tVec.x) + (tMat.col2.y * tVec.y)));
tMat = xf1.R;
tVec = poly1.m_centroid;
dX = (dX - (xf1.position.x + ((tMat.col1.x * tVec.x) + (tMat.col2.x * tVec.y))));
dY = (dY - (xf1.position.y + ((tMat.col1.y * tVec.x) + (tMat.col2.y * tVec.y))));
var dLocal1X:Number = ((dX * xf1.R.col1.x) + (dY * xf1.R.col1.y));
var dLocal1Y:Number = ((dX * xf1.R.col2.x) + (dY * xf1.R.col2.y));
var edge:int;
var maxDot:Number = -(Number.MAX_VALUE);
var i:int;
while (i < count1) {
tVec = normals1[i];
dot = ((tVec.x * dLocal1X) + (tVec.y * dLocal1Y));
if (dot > maxDot){
maxDot = dot;
edge = i;
};
i++;
};
var s:Number = EdgeSeparation(poly1, xf1, edge, poly2, xf2);
if (s > 0){
return (s);
};
var prevEdge:int = (((edge - 1) >= 0)) ? (edge - 1) : (count1 - 1);
var sPrev:Number = EdgeSeparation(poly1, xf1, prevEdge, poly2, xf2);
if (sPrev > 0){
return (sPrev);
};
var nextEdge:int = (((edge + 1) < count1)) ? (edge + 1) : 0;
var sNext:Number = EdgeSeparation(poly1, xf1, nextEdge, poly2, xf2);
if (sNext > 0){
return (sNext);
};
if ((((sPrev > s)) && ((sPrev > sNext)))){
increment = -1;
bestEdge = prevEdge;
bestSeparation = sPrev;
} else {
if (sNext > s){
increment = 1;
bestEdge = nextEdge;
bestSeparation = sNext;
} else {
edgeIndex[0] = edge;
return (s);
};
};
while (true) {
if (increment == -1){
edge = (((bestEdge - 1) >= 0)) ? (bestEdge - 1) : (count1 - 1);
} else {
edge = (((bestEdge + 1) < count1)) ? (bestEdge + 1) : 0;
};
s = EdgeSeparation(poly1, xf1, edge, poly2, xf2);
if (s > 0){
return (s);
};
if (s > bestSeparation){
bestEdge = edge;
bestSeparation = s;
} else {
break;
};
};
edgeIndex[0] = bestEdge;
return (bestSeparation);
}
public static function FindIncidentEdge(c:Array, poly1:b2PolygonShape, xf1:b2XForm, edge1:int, poly2:b2PolygonShape, xf2:b2XForm):void{
var tMat:b2Mat22;
var tVec:b2Vec2;
var tClip:ClipVertex;
var dot:Number;
var count1:int = poly1.m_vertexCount;
var normals1:Array = poly1.m_normals;
var count2:int = poly2.m_vertexCount;
var vertices2:Array = poly2.m_vertices;
var normals2:Array = poly2.m_normals;
tMat = xf1.R;
tVec = normals1[edge1];
var normal1X:Number = ((tMat.col1.x * tVec.x) + (tMat.col2.x * tVec.y));
var normal1Y:Number = ((tMat.col1.y * tVec.x) + (tMat.col2.y * tVec.y));
tMat = xf2.R;
var tX:Number = ((tMat.col1.x * normal1X) + (tMat.col1.y * normal1Y));
normal1Y = ((tMat.col2.x * normal1X) + (tMat.col2.y * normal1Y));
normal1X = tX;
var index:int;
var minDot:Number = Number.MAX_VALUE;
var i:int;
while (i < count2) {
tVec = normals2[i];
dot = ((normal1X * tVec.x) + (normal1Y * tVec.y));
if (dot < minDot){
minDot = dot;
index = i;
};
i++;
};
var i1:int = index;
var i2:int = (((i1 + 1) < count2)) ? (i1 + 1) : 0;
tClip = c[0];
tVec = vertices2[i1];
tMat = xf2.R;
tClip.v.x = (xf2.position.x + ((tMat.col1.x * tVec.x) + (tMat.col2.x * tVec.y)));
tClip.v.y = (xf2.position.y + ((tMat.col1.y * tVec.x) + (tMat.col2.y * tVec.y)));
tClip.id.features.referenceEdge = edge1;
tClip.id.features.incidentEdge = i1;
tClip.id.features.incidentVertex = 0;
tClip = c[1];
tVec = vertices2[i2];
tMat = xf2.R;
tClip.v.x = (xf2.position.x + ((tMat.col1.x * tVec.x) + (tMat.col2.x * tVec.y)));
tClip.v.y = (xf2.position.y + ((tMat.col1.y * tVec.x) + (tMat.col2.y * tVec.y)));
tClip.id.features.referenceEdge = edge1;
tClip.id.features.incidentEdge = i2;
tClip.id.features.incidentVertex = 1;
}
public static function b2CollidePolygons(manifold:b2Manifold, polyA:b2PolygonShape, xfA:b2XForm, polyB:b2PolygonShape, xfB:b2XForm):void{
var cv:ClipVertex;
var poly1:b2PolygonShape;
var poly2:b2PolygonShape;
var edge1:int;
var flip:uint;
var np:int;
var v12:b2Vec2;
var separation:Number;
var cp:b2ManifoldPoint;
manifold.pointCount = 0;
var edgeA:int;
var edgeAO:Array = [edgeA];
var separationA:Number = FindMaxSeparation(edgeAO, polyA, xfA, polyB, xfB);
edgeA = edgeAO[0];
if (separationA > 0){
return;
};
var edgeB:int;
var edgeBO:Array = [edgeB];
var separationB:Number = FindMaxSeparation(edgeBO, polyB, xfB, polyA, xfA);
edgeB = edgeBO[0];
if (separationB > 0){
return;
};
var xf1:b2XForm = new b2XForm();
var xf2:b2XForm = new b2XForm();
var k_relativeTol:Number = 0.98;
var k_absoluteTol:Number = 0.001;
if (separationB > ((k_relativeTol * separationA) + k_absoluteTol)){
poly1 = polyB;
poly2 = polyA;
xf1.Set(xfB);
xf2.Set(xfA);
edge1 = edgeB;
flip = 1;
} else {
poly1 = polyA;
poly2 = polyB;
xf1.Set(xfA);
xf2.Set(xfB);
edge1 = edgeA;
flip = 0;
};
var incidentEdge:Array = [new ClipVertex(), new ClipVertex()];
FindIncidentEdge(incidentEdge, poly1, xf1, edge1, poly2, xf2);
var count1:int = poly1.m_vertexCount;
var vertices1:Array = poly1.m_vertices;
var tVec:b2Vec2 = vertices1[edge1];
var v11:b2Vec2 = tVec.Copy();
if ((edge1 + 1) < count1){
tVec = vertices1[int((edge1 + 1))];
v12 = tVec.Copy();
} else {
tVec = vertices1[0];
v12 = tVec.Copy();
};
var dv:b2Vec2 = b2Math.SubtractVV(v12, v11);
var sideNormal:b2Vec2 = b2Math.b2MulMV(xf1.R, b2Math.SubtractVV(v12, v11));
sideNormal.Normalize();
var frontNormal:b2Vec2 = b2Math.b2CrossVF(sideNormal, 1);
v11 = b2Math.b2MulX(xf1, v11);
v12 = b2Math.b2MulX(xf1, v12);
var frontOffset:Number = b2Math.b2Dot(frontNormal, v11);
var sideOffset1:Number = -(b2Math.b2Dot(sideNormal, v11));
var sideOffset2:Number = b2Math.b2Dot(sideNormal, v12);
var clipPoints1:Array = [new ClipVertex(), new ClipVertex()];
var clipPoints2:Array = [new ClipVertex(), new ClipVertex()];
np = ClipSegmentToLine(clipPoints1, incidentEdge, sideNormal.Negative(), sideOffset1);
if (np < 2){
return;
};
np = ClipSegmentToLine(clipPoints2, clipPoints1, sideNormal, sideOffset2);
if (np < 2){
return;
};
manifold.normal = (flip) ? frontNormal.Negative() : frontNormal.Copy();
var pointCount:int;
var i:int;
while (i < b2Settings.b2_maxManifoldPoints) {
cv = clipPoints2[i];
separation = (b2Math.b2Dot(frontNormal, cv.v) - frontOffset);
if (separation <= 0){
cp = manifold.points[pointCount];
cp.separation = separation;
cp.localPoint1 = b2Math.b2MulXT(xfA, cv.v);
cp.localPoint2 = b2Math.b2MulXT(xfB, cv.v);
cp.id.key = cv.id._key;
cp.id.features.flip = flip;
pointCount++;
};
i++;
};
manifold.pointCount = pointCount;
}
public static function b2CollideCircles(manifold:b2Manifold, circle1:b2CircleShape, xf1:b2XForm, circle2:b2CircleShape, xf2:b2XForm):void{
var tMat:b2Mat22;
var tVec:b2Vec2;
var separation:Number;
var dist:Number;
var a:Number;
manifold.pointCount = 0;
tMat = xf1.R;
tVec = circle1.m_localPosition;
var p1X:Number = (xf1.position.x + ((tMat.col1.x * tVec.x) + (tMat.col2.x * tVec.y)));
var p1Y:Number = (xf1.position.y + ((tMat.col1.y * tVec.x) + (tMat.col2.y * tVec.y)));
tMat = xf2.R;
tVec = circle2.m_localPosition;
var p2X:Number = (xf2.position.x + ((tMat.col1.x * tVec.x) + (tMat.col2.x * tVec.y)));
var p2Y:Number = (xf2.position.y + ((tMat.col1.y * tVec.x) + (tMat.col2.y * tVec.y)));
var dX:Number = (p2X - p1X);
var dY:Number = (p2Y - p1Y);
var distSqr:Number = ((dX * dX) + (dY * dY));
var r1:Number = circle1.m_radius;
var r2:Number = circle2.m_radius;
var radiusSum:Number = (r1 + r2);
if (distSqr > (radiusSum * radiusSum)){
return;
};
if (distSqr < Number.MIN_VALUE){
separation = -(radiusSum);
manifold.normal.Set(0, 1);
} else {
dist = Math.sqrt(distSqr);
separation = (dist - radiusSum);
a = (1 / dist);
manifold.normal.x = (a * dX);
manifold.normal.y = (a * dY);
};
manifold.pointCount = 1;
var tPoint:b2ManifoldPoint = manifold.points[0];
tPoint.id.key = 0;
tPoint.separation = separation;
p1X = (p1X + (r1 * manifold.normal.x));
p1Y = (p1Y + (r1 * manifold.normal.y));
p2X = (p2X - (r2 * manifold.normal.x));
p2Y = (p2Y - (r2 * manifold.normal.y));
var pX:Number = (0.5 * (p1X + p2X));
var pY:Number = (0.5 * (p1Y + p2Y));
var tX:Number = (pX - xf1.position.x);
var tY:Number = (pY - xf1.position.y);
tPoint.localPoint1.x = ((tX * xf1.R.col1.x) + (tY * xf1.R.col1.y));
tPoint.localPoint1.y = ((tX * xf1.R.col2.x) + (tY * xf1.R.col2.y));
tX = (pX - xf2.position.x);
tY = (pY - xf2.position.y);
tPoint.localPoint2.x = ((tX * xf2.R.col1.x) + (tY * xf2.R.col1.y));
tPoint.localPoint2.y = ((tX * xf2.R.col2.x) + (tY * xf2.R.col2.y));
}
public static function b2CollidePolygonAndCircle(manifold:b2Manifold, polygon:b2PolygonShape, xf1:b2XForm, circle:b2CircleShape, xf2:b2XForm):void{
var tPoint:b2ManifoldPoint;
var dX:Number;
var dY:Number;
var positionX:Number;
var positionY:Number;
var tVec:b2Vec2;
var tMat:b2Mat22;
var dist:Number;
var pX:Number;
var pY:Number;
var s:Number;
manifold.pointCount = 0;
tMat = xf2.R;
tVec = circle.m_localPosition;
var cX:Number = (xf2.position.x + ((tMat.col1.x * tVec.x) + (tMat.col2.x * tVec.y)));
var cY:Number = (xf2.position.y + ((tMat.col1.y * tVec.x) + (tMat.col2.y * tVec.y)));
dX = (cX - xf1.position.x);
dY = (cY - xf1.position.y);
tMat = xf1.R;
var cLocalX:Number = ((dX * tMat.col1.x) + (dY * tMat.col1.y));
var cLocalY:Number = ((dX * tMat.col2.x) + (dY * tMat.col2.y));
var normalIndex:int;
var separation:Number = -(Number.MAX_VALUE);
var radius:Number = circle.m_radius;
var vertexCount:int = polygon.m_vertexCount;
var vertices:Array = polygon.m_vertices;
var normals:Array = polygon.m_normals;
var i:int;
while (i < vertexCount) {
tVec = vertices[i];
dX = (cLocalX - tVec.x);
dY = (cLocalY - tVec.y);
tVec = normals[i];
s = ((tVec.x * dX) + (tVec.y * dY));
if (s > radius){
return;
};
if (s > separation){
separation = s;
normalIndex = i;
};
i++;
};
if (separation < Number.MIN_VALUE){
manifold.pointCount = 1;
tVec = normals[normalIndex];
tMat = xf1.R;
manifold.normal.x = ((tMat.col1.x * tVec.x) + (tMat.col2.x * tVec.y));
manifold.normal.y = ((tMat.col1.y * tVec.x) + (tMat.col2.y * tVec.y));
tPoint = manifold.points[0];
tPoint.id.features.incidentEdge = normalIndex;
tPoint.id.features.incidentVertex = b2_nullFeature;
tPoint.id.features.referenceEdge = 0;
tPoint.id.features.flip = 0;
positionX = (cX - (radius * manifold.normal.x));
positionY = (cY - (radius * manifold.normal.y));
dX = (positionX - xf1.position.x);
dY = (positionY - xf1.position.y);
tMat = xf1.R;
tPoint.localPoint1.x = ((dX * tMat.col1.x) + (dY * tMat.col1.y));
tPoint.localPoint1.y = ((dX * tMat.col2.x) + (dY * tMat.col2.y));
dX = (positionX - xf2.position.x);
dY = (positionY - xf2.position.y);
tMat = xf2.R;
tPoint.localPoint2.x = ((dX * tMat.col1.x) + (dY * tMat.col1.y));
tPoint.localPoint2.y = ((dX * tMat.col2.x) + (dY * tMat.col2.y));
tPoint.separation = (separation - radius);
return;
};
var vertIndex1:int = normalIndex;
var vertIndex2:int = (((vertIndex1 + 1) < vertexCount)) ? (vertIndex1 + 1) : 0;
tVec = vertices[vertIndex1];
var tVec2:b2Vec2 = vertices[vertIndex2];
var eX:Number = (tVec2.x - tVec.x);
var eY:Number = (tVec2.y - tVec.y);
var length:Number = Math.sqrt(((eX * eX) + (eY * eY)));
eX = (eX / length);
eY = (eY / length);
dX = (cLocalX - tVec.x);
dY = (cLocalY - tVec.y);
var u:Number = ((dX * eX) + (dY * eY));
tPoint = manifold.points[0];
if (u <= 0){
pX = tVec.x;
pY = tVec.y;
tPoint.id.features.incidentEdge = b2_nullFeature;
tPoint.id.features.incidentVertex = vertIndex1;
} else {
if (u >= length){
pX = tVec2.x;
pY = tVec2.y;
tPoint.id.features.incidentEdge = b2_nullFeature;
tPoint.id.features.incidentVertex = vertIndex2;
} else {
pX = ((eX * u) + tVec.x);
pY = ((eY * u) + tVec.y);
tPoint.id.features.incidentEdge = normalIndex;
tPoint.id.features.incidentVertex = b2_nullFeature;
};
};
dX = (cLocalX - pX);
dY = (cLocalY - pY);
dist = Math.sqrt(((dX * dX) + (dY * dY)));
dX = (dX / dist);
dY = (dY / dist);
if (dist > radius){
return;
};
manifold.pointCount = 1;
tMat = xf1.R;
manifold.normal.x = ((tMat.col1.x * dX) + (tMat.col2.x * dY));
manifold.normal.y = ((tMat.col1.y * dX) + (tMat.col2.y * dY));
positionX = (cX - (radius * manifold.normal.x));
positionY = (cY - (radius * manifold.normal.y));
dX = (positionX - xf1.position.x);
dY = (positionY - xf1.position.y);
tMat = xf1.R;
tPoint.localPoint1.x = ((dX * tMat.col1.x) + (dY * tMat.col1.y));
tPoint.localPoint1.y = ((dX * tMat.col2.x) + (dY * tMat.col2.y));
dX = (positionX - xf2.position.x);
dY = (positionY - xf2.position.y);
tMat = xf2.R;
tPoint.localPoint2.x = ((dX * tMat.col1.x) + (dY * tMat.col1.y));
tPoint.localPoint2.y = ((dX * tMat.col2.x) + (dY * tMat.col2.y));
tPoint.separation = (dist - radius);
tPoint.id.features.referenceEdge = 0;
tPoint.id.features.flip = 0;
}
public static function b2TestOverlap(a:b2AABB, b:b2AABB):Boolean{
var t1:b2Vec2 = b.lowerBound;
var t2:b2Vec2 = a.upperBound;
var d1X:Number = (t1.x - t2.x);
var d1Y:Number = (t1.y - t2.y);
t1 = a.lowerBound;
t2 = b.upperBound;
var d2X:Number = (t1.x - t2.x);
var d2Y:Number = (t1.y - t2.y);
if ((((d1X > 0)) || ((d1Y > 0)))){
return (false);
};
if ((((d2X > 0)) || ((d2Y > 0)))){
return (false);
};
return (true);
}
}
}//package Box2D.Collision
Section 16
//b2ContactID (Box2D.Collision.b2ContactID)
package Box2D.Collision {
public class b2ContactID {
public var features:Features;
public var _key:uint;
public function b2ContactID(){
features = new Features();
super();
features._m_id = this;
}
public function Set(id:b2ContactID):void{
key = id._key;
}
public function Copy():b2ContactID{
var id:b2ContactID = new b2ContactID();
id.key = key;
return (id);
}
public function get key():uint{
return (_key);
}
public function set key(value:uint):void{
_key = value;
features._referenceEdge = (_key & 0xFF);
features._incidentEdge = (((_key & 0xFF00) >> 8) & 0xFF);
features._incidentVertex = (((_key & 0xFF0000) >> 16) & 0xFF);
features._flip = (((_key & 4278190080) >> 24) & 0xFF);
}
}
}//package Box2D.Collision
Section 17
//b2ContactPoint (Box2D.Collision.b2ContactPoint)
package Box2D.Collision {
import Box2D.Collision.Shapes.*;
import Box2D.Common.Math.*;
public class b2ContactPoint {
public var shape1:b2Shape;
public var shape2:b2Shape;
public var position:b2Vec2;
public var velocity:b2Vec2;
public var normal:b2Vec2;
public var separation:Number;
public var friction:Number;
public var restitution:Number;
public var id:b2ContactID;
public function b2ContactPoint(){
position = new b2Vec2();
velocity = new b2Vec2();
normal = new b2Vec2();
id = new b2ContactID();
super();
}
}
}//package Box2D.Collision
Section 18
//b2Distance (Box2D.Collision.b2Distance)
package Box2D.Collision {
import Box2D.Collision.Shapes.*;
import Box2D.Common.Math.*;
import Box2D.Common.*;
public class b2Distance {
private static var s_p1s:Array = [new b2Vec2(), new b2Vec2(), new b2Vec2()];
private static var s_p2s:Array = [new b2Vec2(), new b2Vec2(), new b2Vec2()];
private static var s_points:Array = [new b2Vec2(), new b2Vec2(), new b2Vec2()];
private static var gPoint:b2Point = new b2Point();
public static var g_GJK_Iterations:int = 0;
public static function ProcessTwo(x1:b2Vec2, x2:b2Vec2, p1s:Array, p2s:Array, points:Array):int{
var p1s_1:b2Vec2;
var p2s_0:b2Vec2;
var p2s_1:b2Vec2;
var lambda:Number;
var points_0:b2Vec2 = points[0];
var points_1:b2Vec2 = points[1];
var p1s_0:b2Vec2 = p1s[0];
p1s_1 = p1s[1];
p2s_0 = p2s[0];
p2s_1 = p2s[1];
var rX:Number = -(points_1.x);
var rY:Number = -(points_1.y);
var dX:Number = (points_0.x - points_1.x);
var dY:Number = (points_0.y - points_1.y);
var length:Number = Math.sqrt(((dX * dX) + (dY * dY)));
dX = (dX / length);
dY = (dY / length);
lambda = ((rX * dX) + (rY * dY));
if ((((lambda <= 0)) || ((length < Number.MIN_VALUE)))){
x1.SetV(p1s_1);
x2.SetV(p2s_1);
p1s_0.SetV(p1s_1);
p2s_0.SetV(p2s_1);
points_0.SetV(points_1);
return (1);
};
lambda = (lambda / length);
x1.x = (p1s_1.x + (lambda * (p1s_0.x - p1s_1.x)));
x1.y = (p1s_1.y + (lambda * (p1s_0.y - p1s_1.y)));
x2.x = (p2s_1.x + (lambda * (p2s_0.x - p2s_1.x)));
x2.y = (p2s_1.y + (lambda * (p2s_0.y - p2s_1.y)));
return (2);
}
public static function ProcessThree(x1:b2Vec2, x2:b2Vec2, p1s:Array, p2s:Array, points:Array):int{
var points_0:b2Vec2;
var points_1:b2Vec2;
var points_2:b2Vec2;
var p1s_0:b2Vec2;
var p1s_1:b2Vec2;
var p1s_2:b2Vec2;
var p2s_0:b2Vec2;
var p2s_1:b2Vec2;
var lambda:Number;
points_0 = points[0];
points_1 = points[1];
points_2 = points[2];
p1s_0 = p1s[0];
p1s_1 = p1s[1];
p1s_2 = p1s[2];
p2s_0 = p2s[0];
p2s_1 = p2s[1];
var p2s_2:b2Vec2 = p2s[2];
var aX:Number = points_0.x;
var aY:Number = points_0.y;
var bX:Number = points_1.x;
var bY:Number = points_1.y;
var cX:Number = points_2.x;
var cY:Number = points_2.y;
var abX:Number = (bX - aX);
var abY:Number = (bY - aY);
var acX:Number = (cX - aX);
var acY:Number = (cY - aY);
var bcX:Number = (cX - bX);
var bcY:Number = (cY - bY);
var sn:Number = -(((aX * abX) + (aY * abY)));
var sd:Number = ((bX * abX) + (bY * abY));
var tn:Number = -(((aX * acX) + (aY * acY)));
var td:Number = ((cX * acX) + (cY * acY));
var un:Number = -(((bX * bcX) + (bY * bcY)));
var ud:Number = ((cX * bcX) + (cY * bcY));
if ((((td <= 0)) && ((ud <= 0)))){
x1.SetV(p1s_2);
x2.SetV(p2s_2);
p1s_0.SetV(p1s_2);
p2s_0.SetV(p2s_2);
points_0.SetV(points_2);
return (1);
};
var n:Number = ((abX * acY) - (abY * acX));
var vc:Number = (n * ((aX * bY) - (aY * bX)));
var va:Number = (n * ((bX * cY) - (bY * cX)));
if ((((((((va <= 0)) && ((un >= 0)))) && ((ud >= 0)))) && (((un + ud) > 0)))){
lambda = (un / (un + ud));
x1.x = (p1s_1.x + (lambda * (p1s_2.x - p1s_1.x)));
x1.y = (p1s_1.y + (lambda * (p1s_2.y - p1s_1.y)));
x2.x = (p2s_1.x + (lambda * (p2s_2.x - p2s_1.x)));
x2.y = (p2s_1.y + (lambda * (p2s_2.y - p2s_1.y)));
p1s_0.SetV(p1s_2);
p2s_0.SetV(p2s_2);
points_0.SetV(points_2);
return (2);
};
var vb:Number = (n * ((cX * aY) - (cY * aX)));
if ((((((((vb <= 0)) && ((tn >= 0)))) && ((td >= 0)))) && (((tn + td) > 0)))){
lambda = (tn / (tn + td));
x1.x = (p1s_0.x + (lambda * (p1s_2.x - p1s_0.x)));
x1.y = (p1s_0.y + (lambda * (p1s_2.y - p1s_0.y)));
x2.x = (p2s_0.x + (lambda * (p2s_2.x - p2s_0.x)));
x2.y = (p2s_0.y + (lambda * (p2s_2.y - p2s_0.y)));
p1s_1.SetV(p1s_2);
p2s_1.SetV(p2s_2);
points_1.SetV(points_2);
return (2);
};
var denom:Number = ((va + vb) + vc);
denom = (1 / denom);
var u:Number = (va * denom);
var v:Number = (vb * denom);
var w:Number = ((1 - u) - v);
x1.x = (((u * p1s_0.x) + (v * p1s_1.x)) + (w * p1s_2.x));
x1.y = (((u * p1s_0.y) + (v * p1s_1.y)) + (w * p1s_2.y));
x2.x = (((u * p2s_0.x) + (v * p2s_1.x)) + (w * p2s_2.x));
x2.y = (((u * p2s_0.y) + (v * p2s_1.y)) + (w * p2s_2.y));
return (3);
}
public static function InPoints(w:b2Vec2, points:Array, pointCount:int):Boolean{
var points_i:b2Vec2;
var dX:Number;
var dY:Number;
var mX:Number;
var mY:Number;
var k_tolerance:Number = (100 * Number.MIN_VALUE);
var i:int;
while (i < pointCount) {
points_i = points[i];
dX = Math.abs((w.x - points_i.x));
dY = Math.abs((w.y - points_i.y));
mX = Math.max(Math.abs(w.x), Math.abs(points_i.x));
mY = Math.max(Math.abs(w.y), Math.abs(points_i.y));
if ((((dX < (k_tolerance * (mX + 1)))) && ((dY < (k_tolerance * (mY + 1)))))){
return (true);
};
i++;
};
return (false);
}
public static function DistanceGeneric(x1:b2Vec2, x2:b2Vec2, shape1, xf1:b2XForm, shape2, xf2:b2XForm):Number{
var tVec:b2Vec2;
var vX:Number;
var vY:Number;
var w1:b2Vec2;
var w2:b2Vec2;
var wX:Number;
var wY:Number;
var vw:Number;
var maxSqr:Number;
var i:int;
var p1s:Array = s_p1s;
var p2s:Array = s_p2s;
var points:Array = s_points;
var pointCount:int;
x1.SetV(shape1.GetFirstVertex(xf1));
x2.SetV(shape2.GetFirstVertex(xf2));
var vSqr:Number = 0;
var maxIterations = 20;
var iter:int;
while (iter < maxIterations) {
vX = (x2.x - x1.x);
vY = (x2.y - x1.y);
w1 = shape1.Support(xf1, vX, vY);
w2 = shape2.Support(xf2, -(vX), -(vY));
vSqr = ((vX * vX) + (vY * vY));
wX = (w2.x - w1.x);
wY = (w2.y - w1.y);
vw = ((vX * wX) + (vY * wY));
if ((vSqr - vw) <= (0.01 * vSqr)){
if (pointCount == 0){
x1.SetV(w1);
x2.SetV(w2);
};
g_GJK_Iterations = iter;
return (Math.sqrt(vSqr));
};
switch (pointCount){
case 0:
tVec = p1s[0];
tVec.SetV(w1);
tVec = p2s[0];
tVec.SetV(w2);
tVec = points[0];
tVec.x = wX;
tVec.y = wY;
x1.SetV(p1s[0]);
x2.SetV(p2s[0]);
pointCount++;
break;
case 1:
tVec = p1s[1];
tVec.SetV(w1);
tVec = p2s[1];
tVec.SetV(w2);
tVec = points[1];
tVec.x = wX;
tVec.y = wY;
pointCount = ProcessTwo(x1, x2, p1s, p2s, points);
break;
case 2:
tVec = p1s[2];
tVec.SetV(w1);
tVec = p2s[2];
tVec.SetV(w2);
tVec = points[2];
tVec.x = wX;
tVec.y = wY;
pointCount = ProcessThree(x1, x2, p1s, p2s, points);
break;
};
if (pointCount == 3){
g_GJK_Iterations = iter;
return (0);
};
maxSqr = -(Number.MAX_VALUE);
i = 0;
while (i < pointCount) {
tVec = points[i];
maxSqr = b2Math.b2Max(maxSqr, ((tVec.x * tVec.x) + (tVec.y * tVec.y)));
i++;
};
if ((((pointCount == 3)) || ((vSqr <= ((100 * Number.MIN_VALUE) * maxSqr))))){
g_GJK_Iterations = iter;
vX = (x2.x - x1.x);
vY = (x2.y - x1.y);
vSqr = ((vX * vX) + (vY * vY));
return (Math.sqrt(vSqr));
};
iter++;
};
g_GJK_Iterations = maxIterations;
return (Math.sqrt(vSqr));
}
public static function DistanceCC(x1:b2Vec2, x2:b2Vec2, circle1:b2CircleShape, xf1:b2XForm, circle2:b2CircleShape, xf2:b2XForm):Number{
var tMat:b2Mat22;
var tVec:b2Vec2;
var dLen:Number;
var distance:Number;
tMat = xf1.R;
tVec = circle1.m_localPosition;
var p1X:Number = (xf1.position.x + ((tMat.col1.x * tVec.x) + (tMat.col2.x * tVec.y)));
var p1Y:Number = (xf1.position.y + ((tMat.col1.y * tVec.x) + (tMat.col2.y * tVec.y)));
tMat = xf2.R;
tVec = circle2.m_localPosition;
var p2X:Number = (xf2.position.x + ((tMat.col1.x * tVec.x) + (tMat.col2.x * tVec.y)));
var p2Y:Number = (xf2.position.y + ((tMat.col1.y * tVec.x) + (tMat.col2.y * tVec.y)));
var dX:Number = (p2X - p1X);
var dY:Number = (p2Y - p1Y);
var dSqr:Number = ((dX * dX) + (dY * dY));
var r1:Number = (circle1.m_radius - b2Settings.b2_toiSlop);
var r2:Number = (circle2.m_radius - b2Settings.b2_toiSlop);
var r:Number = (r1 + r2);
if (dSqr > (r * r)){
dLen = Math.sqrt(dSqr);
dX = (dX / dLen);
dY = (dY / dLen);
distance = (dLen - r);
x1.x = (p1X + (r1 * dX));
x1.y = (p1Y + (r1 * dY));
x2.x = (p2X - (r2 * dX));
x2.y = (p2Y - (r2 * dY));
return (distance);
};
if (dSqr > (Number.MIN_VALUE * Number.MIN_VALUE)){
dLen = Math.sqrt(dSqr);
dX = (dX / dLen);
dY = (dY / dLen);
x1.x = (p1X + (r1 * dX));
x1.y = (p1Y + (r1 * dY));
x2.x = x1.x;
x2.y = x1.y;
return (0);
};
x1.x = p1X;
x1.y = p1Y;
x2.x = x1.x;
x2.y = x1.y;
return (0);
}
public static function DistancePC(x1:b2Vec2, x2:b2Vec2, polygon:b2PolygonShape, xf1:b2XForm, circle:b2CircleShape, xf2:b2XForm):Number{
var tMat:b2Mat22;
var tVec:b2Vec2;
var dX:Number;
var dY:Number;
var dLen:Number;
var point:b2Point = gPoint;
tVec = circle.m_localPosition;
tMat = xf2.R;
point.p.x = (xf2.position.x + ((tMat.col1.x * tVec.x) + (tMat.col2.x * tVec.y)));
point.p.y = (xf2.position.y + ((tMat.col1.y * tVec.x) + (tMat.col2.y * tVec.y)));
var distance:Number = DistanceGeneric(x1, x2, polygon, xf1, point, b2Math.b2XForm_identity);
var r:Number = (circle.m_radius - b2Settings.b2_toiSlop);
if (distance > r){
distance = (distance - r);
dX = (x2.x - x1.x);
dY = (x2.y - x1.y);
dLen = Math.sqrt(((dX * dX) + (dY * dY)));
dX = (dX / dLen);
dY = (dY / dLen);
x2.x = (x2.x - (r * dX));
x2.y = (x2.y - (r * dY));
} else {
distance = 0;
x2.x = x1.x;
x2.y = x1.y;
};
return (distance);
}
public static function Distance(x1:b2Vec2, x2:b2Vec2, shape1:b2Shape, xf1:b2XForm, shape2:b2Shape, xf2:b2XForm):Number{
var type1:int = shape1.m_type;
var type2:int = shape2.m_type;
if ((((type1 == b2Shape.e_circleShape)) && ((type2 == b2Shape.e_circleShape)))){
return (DistanceCC(x1, x2, (shape1 as b2CircleShape), xf1, (shape2 as b2CircleShape), xf2));
};
if ((((type1 == b2Shape.e_polygonShape)) && ((type2 == b2Shape.e_circleShape)))){
return (DistancePC(x1, x2, (shape1 as b2PolygonShape), xf1, (shape2 as b2CircleShape), xf2));
};
if ((((type1 == b2Shape.e_circleShape)) && ((type2 == b2Shape.e_polygonShape)))){
return (DistancePC(x2, x1, (shape2 as b2PolygonShape), xf2, (shape1 as b2CircleShape), xf1));
};
if ((((type1 == b2Shape.e_polygonShape)) && ((type2 == b2Shape.e_polygonShape)))){
return (DistanceGeneric(x1, x2, (shape1 as b2PolygonShape), xf1, (shape2 as b2PolygonShape), xf2));
};
return (0);
}
}
}//package Box2D.Collision
Section 19
//b2Manifold (Box2D.Collision.b2Manifold)
package Box2D.Collision {
import Box2D.Common.Math.*;
import Box2D.Common.*;
public class b2Manifold {
public var points:Array;
public var normal:b2Vec2;
public var pointCount:int;// = 0
public function b2Manifold(){
super();
points = new Array(b2Settings.b2_maxManifoldPoints);
var i:int;
while (i < b2Settings.b2_maxManifoldPoints) {
points[i] = new b2ManifoldPoint();
i++;
};
normal = new b2Vec2();
}
public function Reset():void{
var i:int;
while (i < b2Settings.b2_maxManifoldPoints) {
(points[i] as b2ManifoldPoint).Reset();
i++;
};
normal.SetZero();
pointCount = 0;
}
public function Set(m:b2Manifold):void{
pointCount = m.pointCount;
var i:int;
while (i < b2Settings.b2_maxManifoldPoints) {
(points[i] as b2ManifoldPoint).Set(m.points[i]);
i++;
};
normal.SetV(m.normal);
}
}
}//package Box2D.Collision
Section 20
//b2ManifoldPoint (Box2D.Collision.b2ManifoldPoint)
package Box2D.Collision {
import Box2D.Common.Math.*;
public class b2ManifoldPoint {
public var localPoint1:b2Vec2;
public var localPoint2:b2Vec2;
public var separation:Number;
public var normalImpulse:Number;
public var tangentImpulse:Number;
public var id:b2ContactID;
public function b2ManifoldPoint(){
localPoint1 = new b2Vec2();
localPoint2 = new b2Vec2();
id = new b2ContactID();
super();
}
public function Reset():void{
localPoint1.SetZero();
localPoint2.SetZero();
separation = 0;
normalImpulse = 0;
tangentImpulse = 0;
id.key = 0;
}
public function Set(m:b2ManifoldPoint):void{
localPoint1.SetV(m.localPoint1);
localPoint2.SetV(m.localPoint2);
separation = m.separation;
normalImpulse = m.normalImpulse;
tangentImpulse = m.tangentImpulse;
id.key = m.id.key;
}
}
}//package Box2D.Collision
Section 21
//b2OBB (Box2D.Collision.b2OBB)
package Box2D.Collision {
import Box2D.Common.Math.*;
public class b2OBB {
public var R:b2Mat22;
public var center:b2Vec2;
public var extents:b2Vec2;
public function b2OBB(){
R = new b2Mat22();
center = new b2Vec2();
extents = new b2Vec2();
super();
}
}
}//package Box2D.Collision
Section 22
//b2Pair (Box2D.Collision.b2Pair)
package Box2D.Collision {
import Box2D.Common.*;
public class b2Pair {
public var userData;// = null
public var proxyId1:uint;
public var proxyId2:uint;
public var next:uint;
public var status:uint;
public static var b2_nullPair:uint = b2Settings.USHRT_MAX;
public static var b2_nullProxy:uint = b2Settings.USHRT_MAX;
public static var b2_tableCapacity:int = b2Settings.b2_maxPairs;
public static var b2_tableMask:int = (b2_tableCapacity - 1);
public static var e_pairBuffered:uint = 1;
public static var e_pairRemoved:uint = 2;
public static var e_pairFinal:uint = 4;
public function SetBuffered():void{
status = (status | e_pairBuffered);
}
public function ClearBuffered():void{
status = (status & ~(e_pairBuffered));
}
public function IsBuffered():Boolean{
return (((status & e_pairBuffered) == e_pairBuffered));
}
public function SetRemoved():void{
status = (status | e_pairRemoved);
}
public function ClearRemoved():void{
status = (status & ~(e_pairRemoved));
}
public function IsRemoved():Boolean{
return (((status & e_pairRemoved) == e_pairRemoved));
}
public function SetFinal():void{
status = (status | e_pairFinal);
}
public function IsFinal():Boolean{
return (((status & e_pairFinal) == e_pairFinal));
}
}
}//package Box2D.Collision
Section 23
//b2PairCallback (Box2D.Collision.b2PairCallback)
package Box2D.Collision {
public class b2PairCallback {
public function PairAdded(proxyUserData1, proxyUserData2){
return (null);
}
public function PairRemoved(proxyUserData1, proxyUserData2, pairUserData):void{
}
}
}//package Box2D.Collision
Section 24
//b2PairManager (Box2D.Collision.b2PairManager)
package Box2D.Collision {
import Box2D.Common.Math.*;
import Box2D.Common.*;
public class b2PairManager {
public var m_broadPhase:b2BroadPhase;
public var m_callback:b2PairCallback;
public var m_pairs:Array;
public var m_freePair:uint;
public var m_pairCount:int;
public var m_pairBuffer:Array;
public var m_pairBufferCount:int;
public var m_hashTable:Array;
public function b2PairManager(){
var i:uint;
super();
m_hashTable = new Array(b2Pair.b2_tableCapacity);
i = 0;
while (i < b2Pair.b2_tableCapacity) {
m_hashTable[i] = b2Pair.b2_nullPair;
i++;
};
m_pairs = new Array(b2Settings.b2_maxPairs);
i = 0;
while (i < b2Settings.b2_maxPairs) {
m_pairs[i] = new b2Pair();
i++;
};
m_pairBuffer = new Array(b2Settings.b2_maxPairs);
i = 0;
while (i < b2Settings.b2_maxPairs) {
m_pairBuffer[i] = new b2BufferedPair();
i++;
};
i = 0;
while (i < b2Settings.b2_maxPairs) {
m_pairs[i].proxyId1 = b2Pair.b2_nullProxy;
m_pairs[i].proxyId2 = b2Pair.b2_nullProxy;
m_pairs[i].userData = null;
m_pairs[i].status = 0;
m_pairs[i].next = (i + 1);
i++;
};
m_pairs[int((b2Settings.b2_maxPairs - 1))].next = b2Pair.b2_nullPair;
m_pairCount = 0;
m_pairBufferCount = 0;
}
public function Initialize(broadPhase:b2BroadPhase, callback:b2PairCallback):void{
m_broadPhase = broadPhase;
m_callback = callback;
}
public function AddBufferedPair(proxyId1:int, proxyId2:int):void{
var bufferedPair:b2BufferedPair;
var pair:b2Pair = AddPair(proxyId1, proxyId2);
if (pair.IsBuffered() == false){
pair.SetBuffered();
bufferedPair = m_pairBuffer[m_pairBufferCount];
bufferedPair.proxyId1 = pair.proxyId1;
bufferedPair.proxyId2 = pair.proxyId2;
m_pairBufferCount++;
};
pair.ClearRemoved();
if (b2BroadPhase.s_validate){
ValidateBuffer();
};
}
public function RemoveBufferedPair(proxyId1:int, proxyId2:int):void{
var bufferedPair:b2BufferedPair;
var pair:b2Pair = Find(proxyId1, proxyId2);
if (pair == null){
return;
};
if (pair.IsBuffered() == false){
pair.SetBuffered();
bufferedPair = m_pairBuffer[m_pairBufferCount];
bufferedPair.proxyId1 = pair.proxyId1;
bufferedPair.proxyId2 = pair.proxyId2;
m_pairBufferCount++;
};
pair.SetRemoved();
if (b2BroadPhase.s_validate){
ValidateBuffer();
};
}
public function Commit():void{
var bufferedPair:b2BufferedPair;
var i:int;
var pair:b2Pair;
var proxy1:b2Proxy;
var proxy2:b2Proxy;
var removeCount:int;
var proxies:Array = m_broadPhase.m_proxyPool;
i = 0;
while (i < m_pairBufferCount) {
bufferedPair = m_pairBuffer[i];
pair = Find(bufferedPair.proxyId1, bufferedPair.proxyId2);
pair.ClearBuffered();
proxy1 = proxies[pair.proxyId1];
proxy2 = proxies[pair.proxyId2];
if (pair.IsRemoved()){
if (pair.IsFinal() == true){
m_callback.PairRemoved(proxy1.userData, proxy2.userData, pair.userData);
};
bufferedPair = m_pairBuffer[removeCount];
bufferedPair.proxyId1 = pair.proxyId1;
bufferedPair.proxyId2 = pair.proxyId2;
removeCount++;
} else {
if (pair.IsFinal() == false){
pair.userData = m_callback.PairAdded(proxy1.userData, proxy2.userData);
pair.SetFinal();
};
};
i++;
};
i = 0;
while (i < removeCount) {
bufferedPair = m_pairBuffer[i];
RemovePair(bufferedPair.proxyId1, bufferedPair.proxyId2);
i++;
};
m_pairBufferCount = 0;
if (b2BroadPhase.s_validate){
ValidateTable();
};
}
private function AddPair(proxyId1:uint, proxyId2:uint):b2Pair{
var temp:uint;
if (proxyId1 > proxyId2){
temp = proxyId1;
proxyId1 = proxyId2;
proxyId2 = temp;
};
var hash:uint = (Hash(proxyId1, proxyId2) & b2Pair.b2_tableMask);
var pair = FindHash(proxyId1, proxyId2, hash);
if (pair != null){
return (pair);
};
var pIndex:uint = m_freePair;
pair = m_pairs[pIndex];
m_freePair = pair.next;
pair.proxyId1 = proxyId1;
pair.proxyId2 = proxyId2;
pair.status = 0;
pair.userData = null;
pair.next = m_hashTable[hash];
m_hashTable[hash] = pIndex;
m_pairCount++;
return (pair);
}
private function RemovePair(proxyId1:uint, proxyId2:uint){
var pair:b2Pair;
var temp:uint;
var index:uint;
var userData:*;
if (proxyId1 > proxyId2){
temp = proxyId1;
proxyId1 = proxyId2;
proxyId2 = temp;
};
var hash:uint = (Hash(proxyId1, proxyId2) & b2Pair.b2_tableMask);
var node:uint = m_hashTable[hash];
var pNode:b2Pair;
while (node != b2Pair.b2_nullPair) {
if (Equals(m_pairs[node], proxyId1, proxyId2)){
index = node;
pair = m_pairs[node];
if (pNode){
pNode.next = pair.next;
} else {
m_hashTable[hash] = pair.next;
};
pair = m_pairs[index];
userData = pair.userData;
pair.next = m_freePair;
pair.proxyId1 = b2Pair.b2_nullProxy;
pair.proxyId2 = b2Pair.b2_nullProxy;
pair.userData = null;
pair.status = 0;
m_freePair = index;
m_pairCount--;
return (userData);
} else {
pNode = m_pairs[node];
node = pNode.next;
};
};
return (null);
}
private function Find(proxyId1:uint, proxyId2:uint):b2Pair{
var temp:uint;
if (proxyId1 > proxyId2){
temp = proxyId1;
proxyId1 = proxyId2;
proxyId2 = temp;
};
var hash:uint = (Hash(proxyId1, proxyId2) & b2Pair.b2_tableMask);
return (FindHash(proxyId1, proxyId2, hash));
}
private function FindHash(proxyId1:uint, proxyId2:uint, hash:uint):b2Pair{
var pair:b2Pair;
var index:uint = m_hashTable[hash];
pair = m_pairs[index];
while (((!((index == b2Pair.b2_nullPair))) && ((Equals(pair, proxyId1, proxyId2) == false)))) {
index = pair.next;
pair = m_pairs[index];
};
if (index == b2Pair.b2_nullPair){
return (null);
};
return (pair);
}
private function ValidateBuffer():void{
}
private function ValidateTable():void{
}
public static function Hash(proxyId1:uint, proxyId2:uint):uint{
var key:uint = (((proxyId2 << 16) & 4294901760) | proxyId1);
key = (~(key) + ((key << 15) & 4294934528));
key = (key ^ ((key >> 12) & 1048575));
key = (key + ((key << 2) & 4294967292));
key = (key ^ ((key >> 4) & 268435455));
key = (key * 2057);
key = (key ^ ((key >> 16) & 0xFFFF));
return (key);
}
public static function Equals(pair:b2Pair, proxyId1:uint, proxyId2:uint):Boolean{
return ((((pair.proxyId1 == proxyId1)) && ((pair.proxyId2 == proxyId2))));
}
public static function EqualsPair(pair1:b2BufferedPair, pair2:b2BufferedPair):Boolean{
return ((((pair1.proxyId1 == pair2.proxyId1)) && ((pair1.proxyId2 == pair2.proxyId2))));
}
}
}//package Box2D.Collision
Section 25
//b2Point (Box2D.Collision.b2Point)
package Box2D.Collision {
import Box2D.Common.Math.*;
public class b2Point {
public var p:b2Vec2;
public function b2Point(){
p = new b2Vec2();
super();
}
public function Support(xf:b2XForm, vX:Number, vY:Number):b2Vec2{
return (p);
}
public function GetFirstVertex(xf:b2XForm):b2Vec2{
return (p);
}
}
}//package Box2D.Collision
Section 26
//b2Proxy (Box2D.Collision.b2Proxy)
package Box2D.Collision {
public class b2Proxy {
public var lowerBounds:Array;
public var upperBounds:Array;
public var overlapCount:uint;
public var timeStamp:uint;
public var userData;// = null
public function b2Proxy(){
lowerBounds = [uint(0), uint(0)];
upperBounds = [uint(0), uint(0)];
super();
}
public function GetNext():uint{
return (lowerBounds[0]);
}
public function SetNext(next:uint):void{
lowerBounds[0] = (next & 0xFFFF);
}
public function IsValid():Boolean{
return (!((overlapCount == b2BroadPhase.b2_invalid)));
}
}
}//package Box2D.Collision
Section 27
//b2Segment (Box2D.Collision.b2Segment)
package Box2D.Collision {
import Box2D.Common.Math.*;
import Box2D.Common.*;
public class b2Segment {
public var p1:b2Vec2;
public var p2:b2Vec2;
public function b2Segment(){
p1 = new b2Vec2();
p2 = new b2Vec2();
super();
}
public function TestSegment(lambda:Array, normal:b2Vec2, segment:b2Segment, maxLambda:Number):Boolean{
var bX:Number;
var bY:Number;
var a:Number;
var mu2:Number;
var nLen:Number;
var s:b2Vec2 = segment.p1;
var rX:Number = (segment.p2.x - s.x);
var rY:Number = (segment.p2.y - s.y);
var dX:Number = (p2.x - p1.x);
var dY:Number = (p2.y - p1.y);
var nX:Number = dY;
var nY:Number = -(dX);
var k_slop:Number = (100 * Number.MIN_VALUE);
var denom:Number = -(((rX * nX) + (rY * nY)));
if (denom > k_slop){
bX = (s.x - p1.x);
bY = (s.y - p1.y);
a = ((bX * nX) + (bY * nY));
if ((((0 <= a)) && ((a <= (maxLambda * denom))))){
mu2 = ((-(rX) * bY) + (rY * bX));
if (((((-(k_slop) * denom) <= mu2)) && ((mu2 <= (denom * (1 + k_slop)))))){
a = (a / denom);
nLen = Math.sqrt(((nX * nX) + (nY * nY)));
nX = (nX / nLen);
nY = (nY / nLen);
lambda[0] = a;
normal.Set(nX, nY);
return (true);
};
};
};
return (false);
}
}
}//package Box2D.Collision
Section 28
//b2TimeOfImpact (Box2D.Collision.b2TimeOfImpact)
package Box2D.Collision {
import Box2D.Collision.Shapes.*;
import Box2D.Common.Math.*;
import Box2D.Common.*;
public class b2TimeOfImpact {
public static var s_p1:b2Vec2 = new b2Vec2();
public static var s_p2:b2Vec2 = new b2Vec2();
public static var s_xf1:b2XForm = new b2XForm();
public static var s_xf2:b2XForm = new b2XForm();
public static function TimeOfImpact(shape1:b2Shape, sweep1:b2Sweep, shape2:b2Shape, sweep2:b2Sweep):Number{
var math1:Number;
var math2:Number;
var t:Number;
var xf1:b2XForm;
var xf2:b2XForm;
var nLen:Number;
var approachVelocityBound:Number;
var dAlpha:Number;
var newAlpha:Number;
var r1:Number = shape1.m_sweepRadius;
var r2:Number = shape2.m_sweepRadius;
var t0:Number = sweep1.t0;
var v1X:Number = (sweep1.c.x - sweep1.c0.x);
var v1Y:Number = (sweep1.c.y - sweep1.c0.y);
var v2X:Number = (sweep2.c.x - sweep2.c0.x);
var v2Y:Number = (sweep2.c.y - sweep2.c0.y);
var omega1:Number = (sweep1.a - sweep1.a0);
var omega2:Number = (sweep2.a - sweep2.a0);
var alpha:Number = 0;
var p1:b2Vec2 = s_p1;
var p2:b2Vec2 = s_p2;
var k_maxIterations = 20;
var iter:int;
var normalX:Number = 0;
var normalY:Number = 0;
var distance:Number = 0;
var targetDistance:Number = 0;
while (true) {
t = (((1 - alpha) * t0) + alpha);
xf1 = s_xf1;
xf2 = s_xf2;
sweep1.GetXForm(xf1, t);
sweep2.GetXForm(xf2, t);
distance = b2Distance.Distance(p1, p2, shape1, xf1, shape2, xf2);
if (iter == 0){
if (distance > (2 * b2Settings.b2_toiSlop)){
targetDistance = (1.5 * b2Settings.b2_toiSlop);
} else {
math1 = (0.05 * b2Settings.b2_toiSlop);
math2 = (distance - (0.5 * b2Settings.b2_toiSlop));
targetDistance = ((math1 > math2)) ? math1 : math2;
};
};
if (((((distance - targetDistance) < (0.05 * b2Settings.b2_toiSlop))) || ((iter == k_maxIterations)))){
break;
};
normalX = (p2.x - p1.x);
normalY = (p2.y - p1.y);
nLen = Math.sqrt(((normalX * normalX) + (normalY * normalY)));
normalX = (normalX / nLen);
normalY = (normalY / nLen);
approachVelocityBound = ((((normalX * (v1X - v2X)) + (normalY * (v1Y - v2Y))) + (((omega1 < 0)) ? -(omega1) : omega1 * r1)) + (((omega2 < 0)) ? -(omega2) : omega2 * r2));
if (approachVelocityBound == 0){
alpha = 1;
break;
};
dAlpha = ((distance - targetDistance) / approachVelocityBound);
newAlpha = (alpha + dAlpha);
if ((((newAlpha < 0)) || ((1 < newAlpha)))){
alpha = 1;
break;
};
if (newAlpha < ((1 + (100 * Number.MIN_VALUE)) * alpha)){
break;
};
alpha = newAlpha;
iter++;
};
return (alpha);
}
}
}//package Box2D.Collision
Section 29
//ClipVertex (Box2D.Collision.ClipVertex)
package Box2D.Collision {
import Box2D.Common.Math.*;
public class ClipVertex {
public var v:b2Vec2;
public var id:b2ContactID;
public function ClipVertex(){
v = new b2Vec2();
id = new b2ContactID();
super();
}
}
}//package Box2D.Collision
Section 30
//Features (Box2D.Collision.Features)
package Box2D.Collision {
public class Features {
public var _referenceEdge:int;
public var _incidentEdge:int;
public var _incidentVertex:int;
public var _flip:int;
public var _m_id:b2ContactID;
public function set referenceEdge(value:int):void{
_referenceEdge = value;
_m_id._key = ((_m_id._key & 4294967040) | (_referenceEdge & 0xFF));
}
public function get referenceEdge():int{
return (_referenceEdge);
}
public function set incidentEdge(value:int):void{
_incidentEdge = value;
_m_id._key = ((_m_id._key & 4294902015) | ((_incidentEdge << 8) & 0xFF00));
}
public function get incidentEdge():int{
return (_incidentEdge);
}
public function set incidentVertex(value:int):void{
_incidentVertex = value;
_m_id._key = ((_m_id._key & 4278255615) | ((_incidentVertex << 16) & 0xFF0000));
}
public function get incidentVertex():int{
return (_incidentVertex);
}
public function set flip(value:int):void{
_flip = value;
_m_id._key = ((_m_id._key & 0xFFFFFF) | ((_flip << 24) & 4278190080));
}
public function get flip():int{
return (_flip);
}
}
}//package Box2D.Collision
Section 31
//b2Mat22 (Box2D.Common.Math.b2Mat22)
package Box2D.Common.Math {
public class b2Mat22 {
public var col1:b2Vec2;
public var col2:b2Vec2;
public function b2Mat22(angle:Number=0, c1:b2Vec2=null, c2:b2Vec2=null){
var c:Number;
var s:Number;
col1 = new b2Vec2();
col2 = new b2Vec2();
super();
if (((!((c1 == null))) && (!((c2 == null))))){
col1.SetV(c1);
col2.SetV(c2);
} else {
c = Math.cos(angle);
s = Math.sin(angle);
col1.x = c;
col2.x = -(s);
col1.y = s;
col2.y = c;
};
}
public function Set(angle:Number):void{
var c:Number;
c = Math.cos(angle);
var s:Number = Math.sin(angle);
col1.x = c;
col2.x = -(s);
col1.y = s;
col2.y = c;
}
public function SetVV(c1:b2Vec2, c2:b2Vec2):void{
col1.SetV(c1);
col2.SetV(c2);
}
public function Copy():b2Mat22{
return (new b2Mat22(0, col1, col2));
}
public function SetM(m:b2Mat22):void{
col1.SetV(m.col1);
col2.SetV(m.col2);
}
public function AddM(m:b2Mat22):void{
col1.x = (col1.x + m.col1.x);
col1.y = (col1.y + m.col1.y);
col2.x = (col2.x + m.col2.x);
col2.y = (col2.y + m.col2.y);
}
public function SetIdentity():void{
col1.x = 1;
col2.x = 0;
col1.y = 0;
col2.y = 1;
}
public function SetZero():void{
col1.x = 0;
col2.x = 0;
col1.y = 0;
col2.y = 0;
}
public function GetAngle():Number{
return (Math.atan2(col1.y, col1.x));
}
public function Invert(out:b2Mat22):b2Mat22{
var a:Number;
var c:Number;
var det:Number;
a = col1.x;
var b:Number = col2.x;
c = col1.y;
var d:Number = col2.y;
det = ((a * d) - (b * c));
det = (1 / det);
out.col1.x = (det * d);
out.col2.x = (-(det) * b);
out.col1.y = (-(det) * c);
out.col2.y = (det * a);
return (out);
}
public function Solve(out:b2Vec2, bX:Number, bY:Number):b2Vec2{
var a11:Number = col1.x;
var a12:Number = col2.x;
var a21:Number = col1.y;
var a22:Number = col2.y;
var det:Number = ((a11 * a22) - (a12 * a21));
det = (1 / det);
out.x = (det * ((a22 * bX) - (a12 * bY)));
out.y = (det * ((a11 * bY) - (a21 * bX)));
return (out);
}
public function Abs():void{
col1.Abs();
col2.Abs();
}
}
}//package Box2D.Common.Math
Section 32
//b2Math (Box2D.Common.Math.b2Math)
package Box2D.Common.Math {
public class b2Math {
public static const b2Vec2_zero:b2Vec2 = new b2Vec2(0, 0);
public static const b2Mat22_identity:b2Mat22 = new b2Mat22(0, new b2Vec2(1, 0), new b2Vec2(0, 1));
public static const b2XForm_identity:b2XForm = new b2XForm(b2Vec2_zero, b2Mat22_identity);
public static function b2IsValid(x:Number):Boolean{
return (isFinite(x));
}
public static function b2Dot(a:b2Vec2, b:b2Vec2):Number{
return (((a.x * b.x) + (a.y * b.y)));
}
public static function b2CrossVV(a:b2Vec2, b:b2Vec2):Number{
return (((a.x * b.y) - (a.y * b.x)));
}
public static function b2CrossVF(a:b2Vec2, s:Number):b2Vec2{
var v:b2Vec2 = new b2Vec2((s * a.y), (-(s) * a.x));
return (v);
}
public static function b2CrossFV(s:Number, a:b2Vec2):b2Vec2{
var v:b2Vec2 = new b2Vec2((-(s) * a.y), (s * a.x));
return (v);
}
public static function b2MulMV(A:b2Mat22, v:b2Vec2):b2Vec2{
var u:b2Vec2 = new b2Vec2(((A.col1.x * v.x) + (A.col2.x * v.y)), ((A.col1.y * v.x) + (A.col2.y * v.y)));
return (u);
}
public static function b2MulTMV(A:b2Mat22, v:b2Vec2):b2Vec2{
var u:b2Vec2 = new b2Vec2(b2Dot(v, A.col1), b2Dot(v, A.col2));
return (u);
}
public static function b2MulX(T:b2XForm, v:b2Vec2):b2Vec2{
var a:b2Vec2;
a = b2MulMV(T.R, v);
a.x = (a.x + T.position.x);
a.y = (a.y + T.position.y);
return (a);
}
public static function b2MulXT(T:b2XForm, v:b2Vec2):b2Vec2{
var a:b2Vec2;
var tX:Number;
a = SubtractVV(v, T.position);
tX = ((a.x * T.R.col1.x) + (a.y * T.R.col1.y));
a.y = ((a.x * T.R.col2.x) + (a.y * T.R.col2.y));
a.x = tX;
return (a);
}
public static function AddVV(a:b2Vec2, b:b2Vec2):b2Vec2{
var v:b2Vec2 = new b2Vec2((a.x + b.x), (a.y + b.y));
return (v);
}
public static function SubtractVV(a:b2Vec2, b:b2Vec2):b2Vec2{
var v:b2Vec2 = new b2Vec2((a.x - b.x), (a.y - b.y));
return (v);
}
public static function b2Distance(a:b2Vec2, b:b2Vec2):Number{
var cX:Number = (a.x - b.x);
var cY:Number = (a.y - b.y);
return (Math.sqrt(((cX * cX) + (cY * cY))));
}
public static function b2DistanceSquared(a:b2Vec2, b:b2Vec2):Number{
var cX:Number = (a.x - b.x);
var cY:Number = (a.y - b.y);
return (((cX * cX) + (cY * cY)));
}
public static function MulFV(s:Number, a:b2Vec2):b2Vec2{
var v:b2Vec2 = new b2Vec2((s * a.x), (s * a.y));
return (v);
}
public static function AddMM(A:b2Mat22, B:b2Mat22):b2Mat22{
var C:b2Mat22 = new b2Mat22(0, AddVV(A.col1, B.col1), AddVV(A.col2, B.col2));
return (C);
}
public static function b2MulMM(A:b2Mat22, B:b2Mat22):b2Mat22{
var C:b2Mat22 = new b2Mat22(0, b2MulMV(A, B.col1), b2MulMV(A, B.col2));
return (C);
}
public static function b2MulTMM(A:b2Mat22, B:b2Mat22):b2Mat22{
var c1:b2Vec2 = new b2Vec2(b2Dot(A.col1, B.col1), b2Dot(A.col2, B.col1));
var c2:b2Vec2 = new b2Vec2(b2Dot(A.col1, B.col2), b2Dot(A.col2, B.col2));
var C:b2Mat22 = new b2Mat22(0, c1, c2);
return (C);
}
public static function b2Abs(a:Number):Number{
return (((a > 0)) ? a : -(a));
}
public static function b2AbsV(a:b2Vec2):b2Vec2{
var b:b2Vec2 = new b2Vec2(b2Abs(a.x), b2Abs(a.y));
return (b);
}
public static function b2AbsM(A:b2Mat22):b2Mat22{
var B:b2Mat22 = new b2Mat22(0, b2AbsV(A.col1), b2AbsV(A.col2));
return (B);
}
public static function b2Min(a:Number, b:Number):Number{
return (((a < b)) ? a : b);
}
public static function b2MinV(a:b2Vec2, b:b2Vec2):b2Vec2{
var c:b2Vec2 = new b2Vec2(b2Min(a.x, b.x), b2Min(a.y, b.y));
return (c);
}
public static function b2Max(a:Number, b:Number):Number{
return (((a > b)) ? a : b);
}
public static function b2MaxV(a:b2Vec2, b:b2Vec2):b2Vec2{
var c:b2Vec2 = new b2Vec2(b2Max(a.x, b.x), b2Max(a.y, b.y));
return (c);
}
public static function b2Clamp(a:Number, low:Number, high:Number):Number{
return (b2Max(low, b2Min(a, high)));
}
public static function b2ClampV(a:b2Vec2, low:b2Vec2, high:b2Vec2):b2Vec2{
return (b2MaxV(low, b2MinV(a, high)));
}
public static function b2Swap(a:Array, b:Array):void{
var tmp:* = a[0];
a[0] = b[0];
b[0] = tmp;
}
public static function b2Random():Number{
return (((Math.random() * 2) - 1));
}
public static function b2RandomRange(lo:Number, hi:Number):Number{
var r:Number = Math.random();
r = (((hi - lo) * r) + lo);
return (r);
}
public static function b2NextPowerOfTwo(x:uint):uint{
x = (x | ((x >> 1) & 2147483647));
x = (x | ((x >> 2) & 1073741823));
x = (x | ((x >> 4) & 268435455));
x = (x | ((x >> 8) & 0xFFFFFF));
x = (x | ((x >> 16) & 0xFFFF));
return ((x + 1));
}
public static function b2IsPowerOfTwo(x:uint):Boolean{
var result:Boolean = (((x > 0)) && (((x & (x - 1)) == 0)));
return (result);
}
}
}//package Box2D.Common.Math
Section 33
//b2Sweep (Box2D.Common.Math.b2Sweep)
package Box2D.Common.Math {
public class b2Sweep {
public var localCenter:b2Vec2;
public var c0:b2Vec2;
public var c:b2Vec2;
public var a0:Number;
public var a:Number;
public var t0:Number;
public function b2Sweep(){
localCenter = new b2Vec2();
c0 = new b2Vec2();
c = new b2Vec2();
super();
}
public function GetXForm(xf:b2XForm, t:Number):void{
var alpha:Number;
var angle:Number;
if ((1 - t0) > Number.MIN_VALUE){
alpha = ((t - t0) / (1 - t0));
xf.position.x = (((1 - alpha) * c0.x) + (alpha * c.x));
xf.position.y = (((1 - alpha) * c0.y) + (alpha * c.y));
angle = (((1 - alpha) * a0) + (alpha * a));
xf.R.Set(angle);
} else {
xf.position.SetV(c);
xf.R.Set(a);
};
var tMat:b2Mat22 = xf.R;
xf.position.x = (xf.position.x - ((tMat.col1.x * localCenter.x) + (tMat.col2.x * localCenter.y)));
xf.position.y = (xf.position.y - ((tMat.col1.y * localCenter.x) + (tMat.col2.y * localCenter.y)));
}
public function Advance(t:Number):void{
var alpha:Number;
if ((((t0 < t)) && (((1 - t0) > Number.MIN_VALUE)))){
alpha = ((t - t0) / (1 - t0));
c0.x = (((1 - alpha) * c0.x) + (alpha * c.x));
c0.y = (((1 - alpha) * c0.y) + (alpha * c.y));
a0 = (((1 - alpha) * a0) + (alpha * a));
t0 = t;
};
}
}
}//package Box2D.Common.Math
Section 34
//b2Vec2 (Box2D.Common.Math.b2Vec2)
package Box2D.Common.Math {
public class b2Vec2 {
public var x:Number;
public var y:Number;
public function b2Vec2(x_:Number=0, y_:Number=0):void{
super();
x = x_;
y = y_;
}
public function SetZero():void{
x = 0;
y = 0;
}
public function Set(x_:Number=0, y_:Number=0):void{
x = x_;
y = y_;
}
public function SetV(v:b2Vec2):void{
x = v.x;
y = v.y;
}
public function Negative():b2Vec2{
return (new b2Vec2(-(x), -(y)));
}
public function Copy():b2Vec2{
return (new b2Vec2(x, y));
}
public function Add(v:b2Vec2):void{
x = (x + v.x);
y = (y + v.y);
}
public function Subtract(v:b2Vec2):void{
x = (x - v.x);
y = (y - v.y);
}
public function Multiply(a:Number):void{
x = (x * a);
y = (y * a);
}
public function MulM(A:b2Mat22):void{
var tX:Number = x;
x = ((A.col1.x * tX) + (A.col2.x * y));
y = ((A.col1.y * tX) + (A.col2.y * y));
}
public function MulTM(A:b2Mat22):void{
var tX:Number = b2Math.b2Dot(this, A.col1);
y = b2Math.b2Dot(this, A.col2);
x = tX;
}
public function CrossVF(s:Number):void{
var tX:Number = x;
x = (s * y);
y = (-(s) * tX);
}
public function CrossFV(s:Number):void{
var tX:Number = x;
x = (-(s) * y);
y = (s * tX);
}
public function MinV(b:b2Vec2):void{
x = ((x < b.x)) ? x : b.x;
y = ((y < b.y)) ? y : b.y;
}
public function MaxV(b:b2Vec2):void{
x = ((x > b.x)) ? x : b.x;
y = ((y > b.y)) ? y : b.y;
}
public function Abs():void{
if (x < 0){
x = -(x);
};
if (y < 0){
y = -(y);
};
}
public function Length():Number{
return (Math.sqrt(((x * x) + (y * y))));
}
public function LengthSquared():Number{
return (((x * x) + (y * y)));
}
public function Normalize():Number{
var length:Number = Math.sqrt(((x * x) + (y * y)));
if (length < Number.MIN_VALUE){
return (0);
};
var invLength:Number = (1 / length);
x = (x * invLength);
y = (y * invLength);
return (length);
}
public function IsValid():Boolean{
return (((b2Math.b2IsValid(x)) && (b2Math.b2IsValid(y))));
}
public static function Make(x_:Number, y_:Number):b2Vec2{
return (new b2Vec2(x_, y_));
}
}
}//package Box2D.Common.Math
Section 35
//b2XForm (Box2D.Common.Math.b2XForm)
package Box2D.Common.Math {
public class b2XForm {
public var position:b2Vec2;
public var R:b2Mat22;
public function b2XForm(pos:b2Vec2=null, r:b2Mat22=null):void{
position = new b2Vec2();
R = new b2Mat22();
super();
if (pos){
position.SetV(pos);
R.SetM(r);
};
}
public function Initialize(pos:b2Vec2, r:b2Mat22):void{
position.SetV(pos);
R.SetM(r);
}
public function SetIdentity():void{
position.SetZero();
R.SetIdentity();
}
public function Set(x:b2XForm):void{
position.SetV(x.position);
R.SetM(x.R);
}
}
}//package Box2D.Common.Math
Section 36
//b2Color (Box2D.Common.b2Color)
package Box2D.Common {
import Box2D.Common.Math.*;
public class b2Color {
private var _r:uint;// = 0
private var _g:uint;// = 0
private var _b:uint;// = 0
public function b2Color(rr:Number, gg:Number, bb:Number){
super();
_r = uint((0xFF * b2Math.b2Clamp(rr, 0, 1)));
_g = uint((0xFF * b2Math.b2Clamp(gg, 0, 1)));
_b = uint((0xFF * b2Math.b2Clamp(bb, 0, 1)));
}
public function Set(rr:Number, gg:Number, bb:Number):void{
_r = uint((0xFF * b2Math.b2Clamp(rr, 0, 1)));
_g = uint((0xFF * b2Math.b2Clamp(gg, 0, 1)));
_b = uint((0xFF * b2Math.b2Clamp(bb, 0, 1)));
}
public function set r(rr:Number):void{
_r = uint((0xFF * b2Math.b2Clamp(rr, 0, 1)));
}
public function set g(gg:Number):void{
_g = uint((0xFF * b2Math.b2Clamp(gg, 0, 1)));
}
public function set b(bb:Number):void{
_b = uint((0xFF * b2Math.b2Clamp(bb, 0, 1)));
}
public function get color():uint{
return (((_r | (_g << 8)) | (_b << 16)));
}
}
}//package Box2D.Common
Section 37
//b2Settings (Box2D.Common.b2Settings)
package Box2D.Common {
import Box2D.Common.Math.*;
public class b2Settings {
public static const USHRT_MAX:int = 0xFFFF;
public static const b2_pi:Number = 3.14159265358979;
public static const b2_maxManifoldPoints:int = 2;
public static const b2_maxPolygonVertices:int = 8;
public static const b2_maxProxies:int = 0x0200;
public static const b2_maxPairs:int = 4096;
public static const b2_linearSlop:Number = 0.005;
public static const b2_angularSlop:Number = 0.0349065850398866;
public static const b2_toiSlop:Number = 0.04;
public static const b2_maxTOIContactsPerIsland:int = 32;
public static const b2_velocityThreshold:Number = 1;
public static const b2_maxLinearCorrection:Number = 0.2;
public static const b2_maxAngularCorrection:Number = 0.139626340159546;
public static const b2_maxLinearVelocity:Number = 200;
public static const b2_maxLinearVelocitySquared:Number = 40000;
public static const b2_maxAngularVelocity:Number = 250;
public static const b2_maxAngularVelocitySquared:Number = 62500;
public static const b2_contactBaumgarte:Number = 0.2;
public static const b2_timeToSleep:Number = 0.5;
public static const b2_linearSleepTolerance:Number = 0.01;
public static const b2_angularSleepTolerance:Number = 0.0111111111111111;
public static function b2Assert(a:Boolean):void{
var nullVec:b2Vec2;
if (!a){
nullVec.x++;
};
}
}
}//package Box2D.Common
Section 38
//b2CircleContact (Box2D.Dynamics.Contacts.b2CircleContact)
package Box2D.Dynamics.Contacts {
import Box2D.Collision.Shapes.*;
import Box2D.Common.Math.*;
import Box2D.Dynamics.*;
import Box2D.Collision.*;
import Box2D.Common.*;
public class b2CircleContact extends b2Contact {
private var m_manifolds:Array;
public var m_manifold:b2Manifold;
private var m0:b2Manifold;
private static const s_evalCP:b2ContactPoint = new b2ContactPoint();
public function b2CircleContact(shape1:b2Shape, shape2:b2Shape){
m_manifolds = [new b2Manifold()];
m0 = new b2Manifold();
super(shape1, shape2);
m_manifold = m_manifolds[0];
m_manifold.pointCount = 0;
var point:b2ManifoldPoint = m_manifold.points[0];
point.normalImpulse = 0;
point.tangentImpulse = 0;
}
override public function Evaluate(listener:b2ContactListener):void{
var v1:b2Vec2;
var v2:b2Vec2;
var mp0:b2ManifoldPoint;
var mp:b2ManifoldPoint;
var b1:b2Body = m_shape1.m_body;
var b2:b2Body = m_shape2.m_body;
m0.Set(m_manifold);
b2Collision.b2CollideCircles(m_manifold, (m_shape1 as b2CircleShape), b1.m_xf, (m_shape2 as b2CircleShape), b2.m_xf);
var cp:b2ContactPoint = s_evalCP;
cp.shape1 = m_shape1;
cp.shape2 = m_shape2;
cp.friction = m_friction;
cp.restitution = m_restitution;
if (m_manifold.pointCount > 0){
m_manifoldCount = 1;
mp = m_manifold.points[0];
if (m0.pointCount == 0){
mp.normalImpulse = 0;
mp.tangentImpulse = 0;
if (listener){
cp.position = b1.GetWorldPoint(mp.localPoint1);
v1 = b1.GetLinearVelocityFromLocalPoint(mp.localPoint1);
v2 = b2.GetLinearVelocityFromLocalPoint(mp.localPoint2);
cp.velocity.Set((v2.x - v1.x), (v2.y - v1.y));
cp.normal.SetV(m_manifold.normal);
cp.separation = mp.separation;
cp.id.key = mp.id._key;
listener.Add(cp);
};
} else {
mp0 = m0.points[0];
mp.normalImpulse = mp0.normalImpulse;
mp.tangentImpulse = mp0.tangentImpulse;
if (listener){
cp.position = b1.GetWorldPoint(mp.localPoint1);
v1 = b1.GetLinearVelocityFromLocalPoint(mp.localPoint1);
v2 = b2.GetLinearVelocityFromLocalPoint(mp.localPoint2);
cp.velocity.Set((v2.x - v1.x), (v2.y - v1.y));
cp.normal.SetV(m_manifold.normal);
cp.separation = mp.separation;
cp.id.key = mp.id._key;
listener.Persist(cp);
};
};
} else {
m_manifoldCount = 0;
if ((((m0.pointCount > 0)) && (listener))){
mp0 = m0.points[0];
cp.position = b1.GetWorldPoint(mp0.localPoint1);
v1 = b1.GetLinearVelocityFromLocalPoint(mp0.localPoint1);
v2 = b2.GetLinearVelocityFromLocalPoint(mp0.localPoint2);
cp.velocity.Set((v2.x - v1.x), (v2.y - v1.y));
cp.normal.SetV(m0.normal);
cp.separation = mp0.separation;
cp.id.key = mp0.id._key;
listener.Remove(cp);
};
};
}
override public function GetManifolds():Array{
return (m_manifolds);
}
public static function Create(shape1:b2Shape, shape2:b2Shape, allocator):b2Contact{
return (new b2CircleContact(shape1, shape2));
}
public static function Destroy(contact:b2Contact, allocator):void{
}
}
}//package Box2D.Dynamics.Contacts
Section 39
//b2Contact (Box2D.Dynamics.Contacts.b2Contact)
package Box2D.Dynamics.Contacts {
import Box2D.Collision.Shapes.*;
import Box2D.Common.Math.*;
import Box2D.Dynamics.*;
import Box2D.Collision.*;
import Box2D.Common.*;
public class b2Contact {
public var m_flags:uint;
public var m_prev:b2Contact;
public var m_next:b2Contact;
public var m_node1:b2ContactEdge;
public var m_node2:b2ContactEdge;
public var m_shape1:b2Shape;
public var m_shape2:b2Shape;
public var m_manifoldCount:int;
public var m_friction:Number;
public var m_restitution:Number;
public var m_toi:Number;
public static var e_nonSolidFlag:uint = 1;
public static var e_slowFlag:uint = 2;
public static var e_islandFlag:uint = 4;
public static var e_toiFlag:uint = 8;
public static var s_registers:Array;
public static var s_initialized:Boolean = false;
public function b2Contact(s1:b2Shape=null, s2:b2Shape=null){
m_node1 = new b2ContactEdge();
m_node2 = new b2ContactEdge();
super();
m_flags = 0;
if (((!(s1)) || (!(s2)))){
m_shape1 = null;
m_shape2 = null;
return;
};
if (((s1.IsSensor()) || (s2.IsSensor()))){
m_flags = (m_flags | e_nonSolidFlag);
};
m_shape1 = s1;
m_shape2 = s2;
m_manifoldCount = 0;
m_friction = Math.sqrt((m_shape1.m_friction * m_shape2.m_friction));
m_restitution = b2Math.b2Max(m_shape1.m_restitution, m_shape2.m_restitution);
m_prev = null;
m_next = null;
m_node1.contact = null;
m_node1.prev = null;
m_node1.next = null;
m_node1.other = null;
m_node2.contact = null;
m_node2.prev = null;
m_node2.next = null;
m_node2.other = null;
}
public function GetManifolds():Array{
return (null);
}
public function GetManifoldCount():int{
return (m_manifoldCount);
}
public function IsSolid():Boolean{
return (((m_flags & e_nonSolidFlag) == 0));
}
public function GetNext():b2Contact{
return (m_next);
}
public function GetShape1():b2Shape{
return (m_shape1);
}
public function GetShape2():b2Shape{
return (m_shape2);
}
public function Update(listener:b2ContactListener):void{
var oldCount:int = m_manifoldCount;
Evaluate(listener);
var newCount:int = m_manifoldCount;
var body1:b2Body = m_shape1.m_body;
var body2:b2Body = m_shape2.m_body;
if ((((newCount == 0)) && ((oldCount > 0)))){
body1.WakeUp();
body2.WakeUp();
};
if (((((((body1.IsStatic()) || (body1.IsBullet()))) || (body2.IsStatic()))) || (body2.IsBullet()))){
m_flags = (m_flags & ~(e_slowFlag));
} else {
m_flags = (m_flags | e_slowFlag);
};
}
public function Evaluate(listener:b2ContactListener):void{
}
public static function AddType(createFcn:Function, destroyFcn:Function, type1:int, type2:int):void{
s_registers[type1][type2].createFcn = createFcn;
s_registers[type1][type2].destroyFcn = destroyFcn;
s_registers[type1][type2].primary = true;
if (type1 != type2){
s_registers[type2][type1].createFcn = createFcn;
s_registers[type2][type1].destroyFcn = destroyFcn;
s_registers[type2][type1].primary = false;
};
}
public static function InitializeRegisters():void{
var j:int;
s_registers = new Array(b2Shape.e_shapeTypeCount);
var i:int;
while (i < b2Shape.e_shapeTypeCount) {
s_registers[i] = new Array(b2Shape.e_shapeTypeCount);
j = 0;
while (j < b2Shape.e_shapeTypeCount) {
s_registers[i][j] = new b2ContactRegister();
j++;
};
i++;
};
AddType(b2CircleContact.Create, b2CircleContact.Destroy, b2Shape.e_circleShape, b2Shape.e_circleShape);
AddType(b2PolyAndCircleContact.Create, b2PolyAndCircleContact.Destroy, b2Shape.e_polygonShape, b2Shape.e_circleShape);
AddType(b2PolygonContact.Create, b2PolygonContact.Destroy, b2Shape.e_polygonShape, b2Shape.e_polygonShape);
}
public static function Create(shape1:b2Shape, shape2:b2Shape, allocator):b2Contact{
var c:b2Contact;
var i:int;
var m:b2Manifold;
if (s_initialized == false){
InitializeRegisters();
s_initialized = true;
};
var type1:int = shape1.m_type;
var type2:int = shape2.m_type;
var reg:b2ContactRegister = s_registers[type1][type2];
var createFcn:Function = reg.createFcn;
if (createFcn != null){
if (reg.primary){
return (createFcn(shape1, shape2, allocator));
};
c = createFcn(shape2, shape1, allocator);
i = 0;
while (i < c.m_manifoldCount) {
m = c.GetManifolds()[i];
m.normal = m.normal.Negative();
i++;
};
return (c);
//unresolved jump
};
return (null);
}
public static function Destroy(contact:b2Contact, allocator):void{
if (contact.m_manifoldCount > 0){
contact.m_shape1.m_body.WakeUp();
contact.m_shape2.m_body.WakeUp();
};
var type1:int = contact.m_shape1.m_type;
var type2:int = contact.m_shape2.m_type;
var reg:b2ContactRegister = s_registers[type1][type2];
var destroyFcn:Function = reg.destroyFcn;
destroyFcn(contact, allocator);
}
}
}//package Box2D.Dynamics.Contacts
Section 40
//b2ContactConstraint (Box2D.Dynamics.Contacts.b2ContactConstraint)
package Box2D.Dynamics.Contacts {
import Box2D.Common.Math.*;
import Box2D.Dynamics.*;
import Box2D.Collision.*;
import Box2D.Common.*;
public class b2ContactConstraint {
public var points:Array;
public var normal:b2Vec2;
public var manifold:b2Manifold;
public var body1:b2Body;
public var body2:b2Body;
public var friction:Number;
public var restitution:Number;
public var pointCount:int;
public function b2ContactConstraint(){
normal = new b2Vec2();
super();
points = new Array(b2Settings.b2_maxManifoldPoints);
var i:int;
while (i < b2Settings.b2_maxManifoldPoints) {
points[i] = new b2ContactConstraintPoint();
i++;
};
}
}
}//package Box2D.Dynamics.Contacts
Section 41
//b2ContactConstraintPoint (Box2D.Dynamics.Contacts.b2ContactConstraintPoint)
package Box2D.Dynamics.Contacts {
import Box2D.Common.Math.*;
public class b2ContactConstraintPoint {
public var localAnchor1:b2Vec2;
public var localAnchor2:b2Vec2;
public var r1:b2Vec2;
public var r2:b2Vec2;
public var normalImpulse:Number;
public var tangentImpulse:Number;
public var positionImpulse:Number;
public var normalMass:Number;
public var tangentMass:Number;
public var equalizedMass:Number;
public var separation:Number;
public var velocityBias:Number;
public function b2ContactConstraintPoint(){
localAnchor1 = new b2Vec2();
localAnchor2 = new b2Vec2();
r1 = new b2Vec2();
r2 = new b2Vec2();
super();
}
}
}//package Box2D.Dynamics.Contacts
Section 42
//b2ContactEdge (Box2D.Dynamics.Contacts.b2ContactEdge)
package Box2D.Dynamics.Contacts {
import Box2D.Dynamics.*;
public class b2ContactEdge {
public var other:b2Body;
public var contact:b2Contact;
public var prev:b2ContactEdge;
public var next:b2ContactEdge;
}
}//package Box2D.Dynamics.Contacts
Section 43
//b2ContactRegister (Box2D.Dynamics.Contacts.b2ContactRegister)
package Box2D.Dynamics.Contacts {
public class b2ContactRegister {
public var createFcn:Function;
public var destroyFcn:Function;
public var primary:Boolean;
}
}//package Box2D.Dynamics.Contacts
Section 44
//b2ContactResult (Box2D.Dynamics.Contacts.b2ContactResult)
package Box2D.Dynamics.Contacts {
import Box2D.Collision.Shapes.*;
import Box2D.Common.Math.*;
import Box2D.Collision.*;
public class b2ContactResult {
public var shape1:b2Shape;
public var shape2:b2Shape;
public var position:b2Vec2;
public var normal:b2Vec2;
public var normalImpulse:Number;
public var tangentImpulse:Number;
public var id:b2ContactID;
public function b2ContactResult(){
position = new b2Vec2();
normal = new b2Vec2();
id = new b2ContactID();
super();
}
}
}//package Box2D.Dynamics.Contacts
Section 45
//b2ContactSolver (Box2D.Dynamics.Contacts.b2ContactSolver)
package Box2D.Dynamics.Contacts {
import Box2D.Common.Math.*;
import Box2D.Dynamics.*;
import Box2D.Collision.*;
import Box2D.Common.*;
public class b2ContactSolver {
public var m_step:b2TimeStep;
public var m_allocator;
public var m_constraints:Array;
public var m_constraintCount:int;
public function b2ContactSolver(step:b2TimeStep, contacts:Array, contactCount:int, allocator){
var contact:b2Contact;
var i:int;
var tVec:b2Vec2;
var tMat:b2Mat22;
var b1:b2Body;
var b2:b2Body;
var manifoldCount:int;
var manifolds:Array;
var friction:Number;
var restitution:Number;
var v1X:Number;
var v1Y:Number;
var v2X:Number;
var v2Y:Number;
var w1:Number;
var w2:Number;
var j:int;
var manifold:b2Manifold;
var normalX:Number;
var normalY:Number;
var c:b2ContactConstraint;
var k:uint;
var cp:b2ManifoldPoint;
var ccp:b2ContactConstraintPoint;
var tX:Number;
var tY:Number;
var r1X:Number;
var r1Y:Number;
var r2X:Number;
var r2Y:Number;
var r1Sqr:Number;
var r2Sqr:Number;
var rn1:Number;
var rn2:Number;
var kNormal:Number;
var kEqualized:Number;
var tangentX:Number;
var tangentY:Number;
var rt1:Number;
var rt2:Number;
var kTangent:Number;
var vRel:Number;
m_step = new b2TimeStep();
m_constraints = new Array();
super();
m_step.dt = step.dt;
m_step.inv_dt = step.inv_dt;
m_step.maxIterations = step.maxIterations;
m_allocator = allocator;
m_constraintCount = 0;
i = 0;
while (i < contactCount) {
contact = contacts[i];
m_constraintCount = (m_constraintCount + contact.m_manifoldCount);
i++;
};
i = 0;
while (i < m_constraintCount) {
m_constraints[i] = new b2ContactConstraint();
i++;
};
var count:int;
i = 0;
while (i < contactCount) {
contact = contacts[i];
b1 = contact.m_shape1.m_body;
b2 = contact.m_shape2.m_body;
manifoldCount = contact.m_manifoldCount;
manifolds = contact.GetManifolds();
friction = contact.m_friction;
restitution = contact.m_restitution;
v1X = b1.m_linearVelocity.x;
v1Y = b1.m_linearVelocity.y;
v2X = b2.m_linearVelocity.x;
v2Y = b2.m_linearVelocity.y;
w1 = b1.m_angularVelocity;
w2 = b2.m_angularVelocity;
j = 0;
while (j < manifoldCount) {
manifold = manifolds[j];
normalX = manifold.normal.x;
normalY = manifold.normal.y;
c = m_constraints[count];
c.body1 = b1;
c.body2 = b2;
c.manifold = manifold;
c.normal.x = normalX;
c.normal.y = normalY;
c.pointCount = manifold.pointCount;
c.friction = friction;
c.restitution = restitution;
k = 0;
while (k < c.pointCount) {
cp = manifold.points[k];
ccp = c.points[k];
ccp.normalImpulse = cp.normalImpulse;
ccp.tangentImpulse = cp.tangentImpulse;
ccp.separation = cp.separation;
ccp.positionImpulse = 0;
ccp.localAnchor1.SetV(cp.localPoint1);
ccp.localAnchor2.SetV(cp.localPoint2);
tMat = b1.m_xf.R;
r1X = (cp.localPoint1.x - b1.m_sweep.localCenter.x);
r1Y = (cp.localPoint1.y - b1.m_sweep.localCenter.y);
tX = ((tMat.col1.x * r1X) + (tMat.col2.x * r1Y));
r1Y = ((tMat.col1.y * r1X) + (tMat.col2.y * r1Y));
r1X = tX;
ccp.r1.Set(r1X, r1Y);
tMat = b2.m_xf.R;
r2X = (cp.localPoint2.x - b2.m_sweep.localCenter.x);
r2Y = (cp.localPoint2.y - b2.m_sweep.localCenter.y);
tX = ((tMat.col1.x * r2X) + (tMat.col2.x * r2Y));
r2Y = ((tMat.col1.y * r2X) + (tMat.col2.y * r2Y));
r2X = tX;
ccp.r2.Set(r2X, r2Y);
r1Sqr = ((r1X * r1X) + (r1Y * r1Y));
r2Sqr = ((r2X * r2X) + (r2Y * r2Y));
rn1 = ((r1X * normalX) + (r1Y * normalY));
rn2 = ((r2X * normalX) + (r2Y * normalY));
kNormal = (b1.m_invMass + b2.m_invMass);
kNormal = (kNormal + ((b1.m_invI * (r1Sqr - (rn1 * rn1))) + (b2.m_invI * (r2Sqr - (rn2 * rn2)))));
ccp.normalMass = (1 / kNormal);
kEqualized = ((b1.m_mass * b1.m_invMass) + (b2.m_mass * b2.m_invMass));
kEqualized = (kEqualized + (((b1.m_mass * b1.m_invI) * (r1Sqr - (rn1 * rn1))) + ((b2.m_mass * b2.m_invI) * (r2Sqr - (rn2 * rn2)))));
ccp.equalizedMass = (1 / kEqualized);
tangentX = normalY;
tangentY = -(normalX);
rt1 = ((r1X * tangentX) + (r1Y * tangentY));
rt2 = ((r2X * tangentX) + (r2Y * tangentY));
kTangent = (b1.m_invMass + b2.m_invMass);
kTangent = (kTangent + ((b1.m_invI * (r1Sqr - (rt1 * rt1))) + (b2.m_invI * (r2Sqr - (rt2 * rt2)))));
ccp.tangentMass = (1 / kTangent);
ccp.velocityBias = 0;
if (ccp.separation > 0){
ccp.velocityBias = (-60 * ccp.separation);
};
tX = (((v2X + (-(w2) * r2Y)) - v1X) - (-(w1) * r1Y));
tY = (((v2Y + (w2 * r2X)) - v1Y) - (w1 * r1X));
vRel = ((c.normal.x * tX) + (c.normal.y * tY));
if (vRel < -(b2Settings.b2_velocityThreshold)){
ccp.velocityBias = (ccp.velocityBias + (-(c.restitution) * vRel));
};
k++;
};
count++;
j++;
};
i++;
};
}
public function InitVelocityConstraints(step:b2TimeStep):void{
var tVec:b2Vec2;
var tVec2:b2Vec2;
var tMat:b2Mat22;
var c:b2ContactConstraint;
var b1:b2Body;
var b2:b2Body;
var invMass1:Number;
var invI1:Number;
var invMass2:Number;
var invI2:Number;
var normalX:Number;
var normalY:Number;
var tangentX:Number;
var tangentY:Number;
var tX:Number;
var j:int;
var tCount:int;
var ccp:b2ContactConstraintPoint;
var PX:Number;
var PY:Number;
var ccp2:b2ContactConstraintPoint;
var i:int;
while (i < m_constraintCount) {
c = m_constraints[i];
b1 = c.body1;
b2 = c.body2;
invMass1 = b1.m_invMass;
invI1 = b1.m_invI;
invMass2 = b2.m_invMass;
invI2 = b2.m_invI;
normalX = c.normal.x;
normalY = c.normal.y;
tangentX = normalY;
tangentY = -(normalX);
if (step.warmStarting){
tCount = c.pointCount;
j = 0;
while (j < tCount) {
ccp = c.points[j];
ccp.normalImpulse = (ccp.normalImpulse * step.dtRatio);
ccp.tangentImpulse = (ccp.tangentImpulse * step.dtRatio);
PX = ((ccp.normalImpulse * normalX) + (ccp.tangentImpulse * tangentX));
PY = ((ccp.normalImpulse * normalY) + (ccp.tangentImpulse * tangentY));
b1.m_angularVelocity = (b1.m_angularVelocity - (invI1 * ((ccp.r1.x * PY) - (ccp.r1.y * PX))));
b1.m_linearVelocity.x = (b1.m_linearVelocity.x - (invMass1 * PX));
b1.m_linearVelocity.y = (b1.m_linearVelocity.y - (invMass1 * PY));
b2.m_angularVelocity = (b2.m_angularVelocity + (invI2 * ((ccp.r2.x * PY) - (ccp.r2.y * PX))));
b2.m_linearVelocity.x = (b2.m_linearVelocity.x + (invMass2 * PX));
b2.m_linearVelocity.y = (b2.m_linearVelocity.y + (invMass2 * PY));
j++;
};
} else {
tCount = c.pointCount;
j = 0;
while (j < tCount) {
ccp2 = c.points[j];
ccp2.normalImpulse = 0;
ccp2.tangentImpulse = 0;
j++;
};
};
i++;
};
}
public function SolveVelocityConstraints():void{
var j:int;
var ccp:b2ContactConstraintPoint;
var r1X:Number;
var r1Y:Number;
var r2X:Number;
var r2Y:Number;
var dvX:Number;
var dvY:Number;
var vn:Number;
var vt:Number;
var lambda_n:Number;
var lambda_t:Number;
var newImpulse_n:Number;
var newImpulse_t:Number;
var PX:Number;
var PY:Number;
var tMat:b2Mat22;
var tVec:b2Vec2;
var c:b2ContactConstraint;
var b1:b2Body;
var b2:b2Body;
var w1:Number;
var w2:Number;
var v1:b2Vec2;
var v2:b2Vec2;
var invMass1:Number;
var invI1:Number;
var invMass2:Number;
var invI2:Number;
var normalX:Number;
var normalY:Number;
var tangentX:Number;
var tangentY:Number;
var friction:Number;
var tX:Number;
var tCount:int;
var maxFriction:Number;
var i:int;
while (i < m_constraintCount) {
c = m_constraints[i];
b1 = c.body1;
b2 = c.body2;
w1 = b1.m_angularVelocity;
w2 = b2.m_angularVelocity;
v1 = b1.m_linearVelocity;
v2 = b2.m_linearVelocity;
invMass1 = b1.m_invMass;
invI1 = b1.m_invI;
invMass2 = b2.m_invMass;
invI2 = b2.m_invI;
normalX = c.normal.x;
normalY = c.normal.y;
tangentX = normalY;
tangentY = -(normalX);
friction = c.friction;
tCount = c.pointCount;
j = 0;
while (j < tCount) {
ccp = c.points[j];
dvX = (((v2.x + (-(w2) * ccp.r2.y)) - v1.x) - (-(w1) * ccp.r1.y));
dvY = (((v2.y + (w2 * ccp.r2.x)) - v1.y) - (w1 * ccp.r1.x));
vn = ((dvX * normalX) + (dvY * normalY));
lambda_n = (-(ccp.normalMass) * (vn - ccp.velocityBias));
vt = ((dvX * tangentX) + (dvY * tangentY));
lambda_t = (ccp.tangentMass * -(vt));
newImpulse_n = b2Math.b2Max((ccp.normalImpulse + lambda_n), 0);
lambda_n = (newImpulse_n - ccp.normalImpulse);
maxFriction = (friction * ccp.normalImpulse);
newImpulse_t = b2Math.b2Clamp((ccp.tangentImpulse + lambda_t), -(maxFriction), maxFriction);
lambda_t = (newImpulse_t - ccp.tangentImpulse);
PX = ((lambda_n * normalX) + (lambda_t * tangentX));
PY = ((lambda_n * normalY) + (lambda_t * tangentY));
v1.x = (v1.x - (invMass1 * PX));
v1.y = (v1.y - (invMass1 * PY));
w1 = (w1 - (invI1 * ((ccp.r1.x * PY) - (ccp.r1.y * PX))));
v2.x = (v2.x + (invMass2 * PX));
v2.y = (v2.y + (invMass2 * PY));
w2 = (w2 + (invI2 * ((ccp.r2.x * PY) - (ccp.r2.y * PX))));
ccp.normalImpulse = newImpulse_n;
ccp.tangentImpulse = newImpulse_t;
j++;
};
b1.m_angularVelocity = w1;
b2.m_angularVelocity = w2;
i++;
};
}
public function FinalizeVelocityConstraints():void{
var c:b2ContactConstraint;
var m:b2Manifold;
var j:int;
var point1:b2ManifoldPoint;
var point2:b2ContactConstraintPoint;
var i:int;
while (i < m_constraintCount) {
c = m_constraints[i];
m = c.manifold;
j = 0;
while (j < c.pointCount) {
point1 = m.points[j];
point2 = c.points[j];
point1.normalImpulse = point2.normalImpulse;
point1.tangentImpulse = point2.tangentImpulse;
j++;
};
i++;
};
}
public function SolvePositionConstraints(baumgarte:Number):Boolean{
var tMat:b2Mat22;
var tVec:b2Vec2;
var c:b2ContactConstraint;
var b1:b2Body;
var b2:b2Body;
var b1_sweep_c:b2Vec2;
var b1_sweep_a:Number;
var b2_sweep_c:b2Vec2;
var b2_sweep_a:Number;
var invMass1:Number;
var invI1:Number;
var invMass2:Number;
var invI2:Number;
var normalX:Number;
var normalY:Number;
var tCount:int;
var j:int;
var ccp:b2ContactConstraintPoint;
var r1X:Number;
var r1Y:Number;
var r2X:Number;
var r2Y:Number;
var tX:Number;
var p1X:Number;
var p1Y:Number;
var p2X:Number;
var p2Y:Number;
var dpX:Number;
var dpY:Number;
var separation:Number;
var C:Number;
var dImpulse:Number;
var impulse0:Number;
var impulseX:Number;
var impulseY:Number;
var minSeparation:Number = 0;
var i:int;
while (i < m_constraintCount) {
c = m_constraints[i];
b1 = c.body1;
b2 = c.body2;
b1_sweep_c = b1.m_sweep.c;
b1_sweep_a = b1.m_sweep.a;
b2_sweep_c = b2.m_sweep.c;
b2_sweep_a = b2.m_sweep.a;
invMass1 = (b1.m_mass * b1.m_invMass);
invI1 = (b1.m_mass * b1.m_invI);
invMass2 = (b2.m_mass * b2.m_invMass);
invI2 = (b2.m_mass * b2.m_invI);
normalX = c.normal.x;
normalY = c.normal.y;
tCount = c.pointCount;
j = 0;
while (j < tCount) {
ccp = c.points[j];
tMat = b1.m_xf.R;
tVec = b1.m_sweep.localCenter;
r1X = (ccp.localAnchor1.x - tVec.x);
r1Y = (ccp.localAnchor1.y - tVec.y);
tX = ((tMat.col1.x * r1X) + (tMat.col2.x * r1Y));
r1Y = ((tMat.col1.y * r1X) + (tMat.col2.y * r1Y));
r1X = tX;
tMat = b2.m_xf.R;
tVec = b2.m_sweep.localCenter;
r2X = (ccp.localAnchor2.x - tVec.x);
r2Y = (ccp.localAnchor2.y - tVec.y);
tX = ((tMat.col1.x * r2X) + (tMat.col2.x * r2Y));
r2Y = ((tMat.col1.y * r2X) + (tMat.col2.y * r2Y));
r2X = tX;
p1X = (b1_sweep_c.x + r1X);
p1Y = (b1_sweep_c.y + r1Y);
p2X = (b2_sweep_c.x + r2X);
p2Y = (b2_sweep_c.y + r2Y);
dpX = (p2X - p1X);
dpY = (p2Y - p1Y);
separation = (((dpX * normalX) + (dpY * normalY)) + ccp.separation);
minSeparation = b2Math.b2Min(minSeparation, separation);
C = (baumgarte * b2Math.b2Clamp((separation + b2Settings.b2_linearSlop), -(b2Settings.b2_maxLinearCorrection), 0));
dImpulse = (-(ccp.equalizedMass) * C);
impulse0 = ccp.positionImpulse;
ccp.positionImpulse = b2Math.b2Max((impulse0 + dImpulse), 0);
dImpulse = (ccp.positionImpulse - impulse0);
impulseX = (dImpulse * normalX);
impulseY = (dImpulse * normalY);
b1_sweep_c.x = (b1_sweep_c.x - (invMass1 * impulseX));
b1_sweep_c.y = (b1_sweep_c.y - (invMass1 * impulseY));
b1_sweep_a = (b1_sweep_a - (invI1 * ((r1X * impulseY) - (r1Y * impulseX))));
b1.m_sweep.a = b1_sweep_a;
b1.SynchronizeTransform();
b2_sweep_c.x = (b2_sweep_c.x + (invMass2 * impulseX));
b2_sweep_c.y = (b2_sweep_c.y + (invMass2 * impulseY));
b2_sweep_a = (b2_sweep_a + (invI2 * ((r2X * impulseY) - (r2Y * impulseX))));
b2.m_sweep.a = b2_sweep_a;
b2.SynchronizeTransform();
j++;
};
i++;
};
return ((minSeparation >= (-1.5 * b2Settings.b2_linearSlop)));
}
}
}//package Box2D.Dynamics.Contacts
Section 46
//b2NullContact (Box2D.Dynamics.Contacts.b2NullContact)
package Box2D.Dynamics.Contacts {
import Box2D.Dynamics.*;
public class b2NullContact extends b2Contact {
public function b2NullContact(){
super();
}
override public function Evaluate(l:b2ContactListener):void{
}
override public function GetManifolds():Array{
return (null);
}
}
}//package Box2D.Dynamics.Contacts
Section 47
//b2PolyAndCircleContact (Box2D.Dynamics.Contacts.b2PolyAndCircleContact)
package Box2D.Dynamics.Contacts {
import Box2D.Collision.Shapes.*;
import Box2D.Common.Math.*;
import Box2D.Dynamics.*;
import Box2D.Collision.*;
import Box2D.Common.*;
public class b2PolyAndCircleContact extends b2Contact {
private var m_manifolds:Array;
public var m_manifold:b2Manifold;
private var m0:b2Manifold;
private static const s_evalCP:b2ContactPoint = new b2ContactPoint();
public function b2PolyAndCircleContact(shape1:b2Shape, shape2:b2Shape){
m_manifolds = [new b2Manifold()];
m0 = new b2Manifold();
super(shape1, shape2);
m_manifold = m_manifolds[0];
b2Settings.b2Assert((m_shape1.m_type == b2Shape.e_polygonShape));
b2Settings.b2Assert((m_shape2.m_type == b2Shape.e_circleShape));
m_manifold.pointCount = 0;
var point:b2ManifoldPoint = m_manifold.points[0];
point.normalImpulse = 0;
point.tangentImpulse = 0;
}
override public function Evaluate(listener:b2ContactListener):void{
var i:int;
var v1:b2Vec2;
var v2:b2Vec2;
var mp0:b2ManifoldPoint;
var mp:b2ManifoldPoint;
var found:Boolean;
var idKey:uint;
var j:int;
var b1:b2Body = m_shape1.m_body;
var b2:b2Body = m_shape2.m_body;
m0.Set(m_manifold);
b2Collision.b2CollidePolygonAndCircle(m_manifold, (m_shape1 as b2PolygonShape), b1.m_xf, (m_shape2 as b2CircleShape), b2.m_xf);
var persisted:Array = [false, false];
var cp:b2ContactPoint = s_evalCP;
cp.shape1 = m_shape1;
cp.shape2 = m_shape2;
cp.friction = m_friction;
cp.restitution = m_restitution;
if (m_manifold.pointCount > 0){
i = 0;
while (i < m_manifold.pointCount) {
mp = m_manifold.points[i];
mp.normalImpulse = 0;
mp.tangentImpulse = 0;
found = false;
idKey = mp.id._key;
j = 0;
while (j < m0.pointCount) {
if (persisted[j] == true){
} else {
mp0 = m0.points[j];
if (mp0.id._key == idKey){
persisted[j] = true;
mp.normalImpulse = mp0.normalImpulse;
mp.tangentImpulse = mp0.tangentImpulse;
found = true;
if (listener != null){
cp.position = b1.GetWorldPoint(mp.localPoint1);
v1 = b1.GetLinearVelocityFromLocalPoint(mp.localPoint1);
v2 = b2.GetLinearVelocityFromLocalPoint(mp.localPoint2);
cp.velocity.Set((v2.x - v1.x), (v2.y - v1.y));
cp.normal.SetV(m_manifold.normal);
cp.separation = mp.separation;
cp.id.key = idKey;
listener.Persist(cp);
};
break;
};
};
j++;
};
if ((((found == false)) && (!((listener == null))))){
cp.position = b1.GetWorldPoint(mp.localPoint1);
v1 = b1.GetLinearVelocityFromLocalPoint(mp.localPoint1);
v2 = b2.GetLinearVelocityFromLocalPoint(mp.localPoint2);
cp.velocity.Set((v2.x - v1.x), (v2.y - v1.y));
cp.normal.SetV(m_manifold.normal);
cp.separation = mp.separation;
cp.id.key = idKey;
listener.Add(cp);
};
i++;
};
m_manifoldCount = 1;
} else {
m_manifoldCount = 0;
};
if (listener == null){
return;
};
i = 0;
while (i < m0.pointCount) {
if (persisted[i]){
} else {
mp0 = m0.points[i];
cp.position = b1.GetWorldPoint(mp0.localPoint1);
v1 = b1.GetLinearVelocityFromLocalPoint(mp0.localPoint1);
v2 = b2.GetLinearVelocityFromLocalPoint(mp0.localPoint2);
cp.velocity.Set((v2.x - v1.x), (v2.y - v1.y));
cp.normal.SetV(m0.normal);
cp.separation = mp0.separation;
cp.id.key = mp0.id._key;
listener.Remove(cp);
};
i++;
};
}
override public function GetManifolds():Array{
return (m_manifolds);
}
public static function Create(shape1:b2Shape, shape2:b2Shape, allocator):b2Contact{
return (new b2PolyAndCircleContact(shape1, shape2));
}
public static function Destroy(contact:b2Contact, allocator):void{
}
}
}//package Box2D.Dynamics.Contacts
Section 48
//b2PolygonContact (Box2D.Dynamics.Contacts.b2PolygonContact)
package Box2D.Dynamics.Contacts {
import Box2D.Collision.Shapes.*;
import Box2D.Common.Math.*;
import Box2D.Dynamics.*;
import Box2D.Collision.*;
import Box2D.Common.*;
public class b2PolygonContact extends b2Contact {
private var m0:b2Manifold;
private var m_manifolds:Array;
public var m_manifold:b2Manifold;
private static const s_evalCP:b2ContactPoint = new b2ContactPoint();
public function b2PolygonContact(shape1:b2Shape, shape2:b2Shape):void{
m0 = new b2Manifold();
m_manifolds = [new b2Manifold()];
super(shape1, shape2);
m_manifold = m_manifolds[0];
m_manifold.pointCount = 0;
}
override public function Evaluate(listener:b2ContactListener):void{
var v1:b2Vec2;
var v2:b2Vec2;
var mp0:b2ManifoldPoint;
var cp:b2ContactPoint;
var i:int;
var mp:b2ManifoldPoint;
var found:Boolean;
var idKey:uint;
var j:int;
var b1:b2Body = m_shape1.m_body;
var b2:b2Body = m_shape2.m_body;
m0.Set(m_manifold);
b2Collision.b2CollidePolygons(m_manifold, (m_shape1 as b2PolygonShape), b1.m_xf, (m_shape2 as b2PolygonShape), b2.m_xf);
var persisted:Array = [false, false];
cp = s_evalCP;
cp.shape1 = m_shape1;
cp.shape2 = m_shape2;
cp.friction = m_friction;
cp.restitution = m_restitution;
if (m_manifold.pointCount > 0){
i = 0;
while (i < m_manifold.pointCount) {
mp = m_manifold.points[i];
mp.normalImpulse = 0;
mp.tangentImpulse = 0;
found = false;
idKey = mp.id._key;
j = 0;
while (j < m0.pointCount) {
if (persisted[j] == true){
} else {
mp0 = m0.points[j];
if (mp0.id._key == idKey){
persisted[j] = true;
mp.normalImpulse = mp0.normalImpulse;
mp.tangentImpulse = mp0.tangentImpulse;
found = true;
if (listener != null){
cp.position = b1.GetWorldPoint(mp.localPoint1);
v1 = b1.GetLinearVelocityFromLocalPoint(mp.localPoint1);
v2 = b2.GetLinearVelocityFromLocalPoint(mp.localPoint2);
cp.velocity.Set((v2.x - v1.x), (v2.y - v1.y));
cp.normal.SetV(m_manifold.normal);
cp.separation = mp.separation;
cp.id.key = idKey;
listener.Persist(cp);
};
break;
};
};
j++;
};
if ((((found == false)) && (!((listener == null))))){
cp.position = b1.GetWorldPoint(mp.localPoint1);
v1 = b1.GetLinearVelocityFromLocalPoint(mp.localPoint1);
v2 = b2.GetLinearVelocityFromLocalPoint(mp.localPoint2);
cp.velocity.Set((v2.x - v1.x), (v2.y - v1.y));
cp.normal.SetV(m_manifold.normal);
cp.separation = mp.separation;
cp.id.key = idKey;
listener.Add(cp);
};
i++;
};
m_manifoldCount = 1;
} else {
m_manifoldCount = 0;
};
if (listener == null){
return;
};
i = 0;
while (i < m0.pointCount) {
if (persisted[i]){
} else {
mp0 = m0.points[i];
cp.position = b1.GetWorldPoint(mp0.localPoint1);
v1 = b1.GetLinearVelocityFromLocalPoint(mp0.localPoint1);
v2 = b2.GetLinearVelocityFromLocalPoint(mp0.localPoint2);
cp.velocity.Set((v2.x - v1.x), (v2.y - v1.y));
cp.normal.SetV(m0.normal);
cp.separation = mp0.separation;
cp.id.key = mp0.id._key;
listener.Remove(cp);
};
i++;
};
}
override public function GetManifolds():Array{
return (m_manifolds);
}
public static function Create(shape1:b2Shape, shape2:b2Shape, allocator):b2Contact{
return (new b2PolygonContact(shape1, shape2));
}
public static function Destroy(contact:b2Contact, allocator):void{
}
}
}//package Box2D.Dynamics.Contacts
Section 49
//b2DistanceJoint (Box2D.Dynamics.Joints.b2DistanceJoint)
package Box2D.Dynamics.Joints {
import Box2D.Common.Math.*;
import Box2D.Dynamics.*;
import Box2D.Common.*;
public class b2DistanceJoint extends b2Joint {
public var m_localAnchor1:b2Vec2;
public var m_localAnchor2:b2Vec2;
public var m_u:b2Vec2;
public var m_frequencyHz:Number;
public var m_dampingRatio:Number;
public var m_gamma:Number;
public var m_bias:Number;
public var m_impulse:Number;
public var m_mass:Number;
public var m_length:Number;
public function b2DistanceJoint(def:b2DistanceJointDef){
var tMat:b2Mat22;
var tX:Number;
var tY:Number;
m_localAnchor1 = new b2Vec2();
m_localAnchor2 = new b2Vec2();
m_u = new b2Vec2();
super(def);
m_localAnchor1.SetV(def.localAnchor1);
m_localAnchor2.SetV(def.localAnchor2);
m_length = def.length;
m_frequencyHz = def.frequencyHz;
m_dampingRatio = def.dampingRatio;
m_impulse = 0;
m_gamma = 0;
m_bias = 0;
m_inv_dt = 0;
}
override public function InitVelocityConstraints(step:b2TimeStep):void{
var tMat:b2Mat22;
var tX:Number;
var b1:b2Body;
var b2:b2Body;
var r1X:Number;
var r2X:Number;
var C:Number;
var omega:Number;
var d:Number;
var k:Number;
var PX:Number;
var PY:Number;
m_inv_dt = step.inv_dt;
b1 = m_body1;
b2 = m_body2;
tMat = b1.m_xf.R;
r1X = (m_localAnchor1.x - b1.m_sweep.localCenter.x);
var r1Y:Number = (m_localAnchor1.y - b1.m_sweep.localCenter.y);
tX = ((tMat.col1.x * r1X) + (tMat.col2.x * r1Y));
r1Y = ((tMat.col1.y * r1X) + (tMat.col2.y * r1Y));
r1X = tX;
tMat = b2.m_xf.R;
r2X = (m_localAnchor2.x - b2.m_sweep.localCenter.x);
var r2Y:Number = (m_localAnchor2.y - b2.m_sweep.localCenter.y);
tX = ((tMat.col1.x * r2X) + (tMat.col2.x * r2Y));
r2Y = ((tMat.col1.y * r2X) + (tMat.col2.y * r2Y));
r2X = tX;
m_u.x = (((b2.m_sweep.c.x + r2X) - b1.m_sweep.c.x) - r1X);
m_u.y = (((b2.m_sweep.c.y + r2Y) - b1.m_sweep.c.y) - r1Y);
var length:Number = Math.sqrt(((m_u.x * m_u.x) + (m_u.y * m_u.y)));
if (length > b2Settings.b2_linearSlop){
m_u.Multiply((1 / length));
} else {
m_u.SetZero();
};
var cr1u:Number = ((r1X * m_u.y) - (r1Y * m_u.x));
var cr2u:Number = ((r2X * m_u.y) - (r2Y * m_u.x));
var invMass:Number = (((b1.m_invMass + ((b1.m_invI * cr1u) * cr1u)) + b2.m_invMass) + ((b2.m_invI * cr2u) * cr2u));
m_mass = (1 / invMass);
if (m_frequencyHz > 0){
C = (length - m_length);
omega = ((2 * Math.PI) * m_frequencyHz);
d = (((2 * m_mass) * m_dampingRatio) * omega);
k = ((m_mass * omega) * omega);
m_gamma = (1 / (step.dt * (d + (step.dt * k))));
m_bias = (((C * step.dt) * k) * m_gamma);
m_mass = (1 / (invMass + m_gamma));
};
if (step.warmStarting){
m_impulse = (m_impulse * step.dtRatio);
PX = (m_impulse * m_u.x);
PY = (m_impulse * m_u.y);
b1.m_linearVelocity.x = (b1.m_linearVelocity.x - (b1.m_invMass * PX));
b1.m_linearVelocity.y = (b1.m_linearVelocity.y - (b1.m_invMass * PY));
b1.m_angularVelocity = (b1.m_angularVelocity - (b1.m_invI * ((r1X * PY) - (r1Y * PX))));
b2.m_linearVelocity.x = (b2.m_linearVelocity.x + (b2.m_invMass * PX));
b2.m_linearVelocity.y = (b2.m_linearVelocity.y + (b2.m_invMass * PY));
b2.m_angularVelocity = (b2.m_angularVelocity + (b2.m_invI * ((r2X * PY) - (r2Y * PX))));
} else {
m_impulse = 0;
};
}
override public function SolveVelocityConstraints(step:b2TimeStep):void{
var tMat:b2Mat22;
var b1:b2Body = m_body1;
var b2:b2Body = m_body2;
tMat = b1.m_xf.R;
var r1X:Number = (m_localAnchor1.x - b1.m_sweep.localCenter.x);
var r1Y:Number = (m_localAnchor1.y - b1.m_sweep.localCenter.y);
var tX:Number = ((tMat.col1.x * r1X) + (tMat.col2.x * r1Y));
r1Y = ((tMat.col1.y * r1X) + (tMat.col2.y * r1Y));
r1X = tX;
tMat = b2.m_xf.R;
var r2X:Number = (m_localAnchor2.x - b2.m_sweep.localCenter.x);
var r2Y:Number = (m_localAnchor2.y - b2.m_sweep.localCenter.y);
tX = ((tMat.col1.x * r2X) + (tMat.col2.x * r2Y));
r2Y = ((tMat.col1.y * r2X) + (tMat.col2.y * r2Y));
r2X = tX;
var v1X:Number = (b1.m_linearVelocity.x + (-(b1.m_angularVelocity) * r1Y));
var v1Y:Number = (b1.m_linearVelocity.y + (b1.m_angularVelocity * r1X));
var v2X:Number = (b2.m_linearVelocity.x + (-(b2.m_angularVelocity) * r2Y));
var v2Y:Number = (b2.m_linearVelocity.y + (b2.m_angularVelocity * r2X));
var Cdot:Number = ((m_u.x * (v2X - v1X)) + (m_u.y * (v2Y - v1Y)));
var impulse:Number = (-(m_mass) * ((Cdot + m_bias) + (m_gamma * m_impulse)));
m_impulse = (m_impulse + impulse);
var PX:Number = (impulse * m_u.x);
var PY:Number = (impulse * m_u.y);
b1.m_linearVelocity.x = (b1.m_linearVelocity.x - (b1.m_invMass * PX));
b1.m_linearVelocity.y = (b1.m_linearVelocity.y - (b1.m_invMass * PY));
b1.m_angularVelocity = (b1.m_angularVelocity - (b1.m_invI * ((r1X * PY) - (r1Y * PX))));
b2.m_linearVelocity.x = (b2.m_linearVelocity.x + (b2.m_invMass * PX));
b2.m_linearVelocity.y = (b2.m_linearVelocity.y + (b2.m_invMass * PY));
b2.m_angularVelocity = (b2.m_angularVelocity + (b2.m_invI * ((r2X * PY) - (r2Y * PX))));
}
override public function SolvePositionConstraints():Boolean{
var tMat:b2Mat22;
if (m_frequencyHz > 0){
return (true);
};
var b1:b2Body = m_body1;
var b2:b2Body = m_body2;
tMat = b1.m_xf.R;
var r1X:Number = (m_localAnchor1.x - b1.m_sweep.localCenter.x);
var r1Y:Number = (m_localAnchor1.y - b1.m_sweep.localCenter.y);
var tX:Number = ((tMat.col1.x * r1X) + (tMat.col2.x * r1Y));
r1Y = ((tMat.col1.y * r1X) + (tMat.col2.y * r1Y));
r1X = tX;
tMat = b2.m_xf.R;
var r2X:Number = (m_localAnchor2.x - b2.m_sweep.localCenter.x);
var r2Y:Number = (m_localAnchor2.y - b2.m_sweep.localCenter.y);
tX = ((tMat.col1.x * r2X) + (tMat.col2.x * r2Y));
r2Y = ((tMat.col1.y * r2X) + (tMat.col2.y * r2Y));
r2X = tX;
var dX:Number = (((b2.m_sweep.c.x + r2X) - b1.m_sweep.c.x) - r1X);
var dY:Number = (((b2.m_sweep.c.y + r2Y) - b1.m_sweep.c.y) - r1Y);
var length:Number = Math.sqrt(((dX * dX) + (dY * dY)));
dX = (dX / length);
dY = (dY / length);
var C:Number = (length - m_length);
C = b2Math.b2Clamp(C, -(b2Settings.b2_maxLinearCorrection), b2Settings.b2_maxLinearCorrection);
var impulse:Number = (-(m_mass) * C);
m_u.Set(dX, dY);
var PX:Number = (impulse * m_u.x);
var PY:Number = (impulse * m_u.y);
b1.m_sweep.c.x = (b1.m_sweep.c.x - (b1.m_invMass * PX));
b1.m_sweep.c.y = (b1.m_sweep.c.y - (b1.m_invMass * PY));
b1.m_sweep.a = (b1.m_sweep.a - (b1.m_invI * ((r1X * PY) - (r1Y * PX))));
b2.m_sweep.c.x = (b2.m_sweep.c.x + (b2.m_invMass * PX));
b2.m_sweep.c.y = (b2.m_sweep.c.y + (b2.m_invMass * PY));
b2.m_sweep.a = (b2.m_sweep.a + (b2.m_invI * ((r2X * PY) - (r2Y * PX))));
b1.SynchronizeTransform();
b2.SynchronizeTransform();
return ((b2Math.b2Abs(C) < b2Settings.b2_linearSlop));
}
override public function GetAnchor1():b2Vec2{
return (m_body1.GetWorldPoint(m_localAnchor1));
}
override public function GetAnchor2():b2Vec2{
return (m_body2.GetWorldPoint(m_localAnchor2));
}
override public function GetReactionForce():b2Vec2{
var F:b2Vec2 = new b2Vec2();
F.SetV(m_u);
F.Multiply((m_inv_dt * m_impulse));
return (F);
}
override public function GetReactionTorque():Number{
return (0);
}
}
}//package Box2D.Dynamics.Joints
Section 50
//b2DistanceJointDef (Box2D.Dynamics.Joints.b2DistanceJointDef)
package Box2D.Dynamics.Joints {
import Box2D.Common.Math.*;
import Box2D.Dynamics.*;
public class b2DistanceJointDef extends b2JointDef {
public var localAnchor1:b2Vec2;
public var localAnchor2:b2Vec2;
public var length:Number;
public var frequencyHz:Number;
public var dampingRatio:Number;
public function b2DistanceJointDef(){
localAnchor1 = new b2Vec2();
localAnchor2 = new b2Vec2();
super();
type = b2Joint.e_distanceJoint;
length = 1;
frequencyHz = 0;
dampingRatio = 0;
}
public function Initialize(b1:b2Body, b2:b2Body, anchor1:b2Vec2, anchor2:b2Vec2):void{
body1 = b1;
body2 = b2;
localAnchor1.SetV(body1.GetLocalPoint(anchor1));
localAnchor2.SetV(body2.GetLocalPoint(anchor2));
var dX:Number = (anchor2.x - anchor1.x);
var dY:Number = (anchor2.y - anchor1.y);
length = Math.sqrt(((dX * dX) + (dY * dY)));
frequencyHz = 0;
dampingRatio = 0;
}
}
}//package Box2D.Dynamics.Joints
Section 51
//b2GearJoint (Box2D.Dynamics.Joints.b2GearJoint)
package Box2D.Dynamics.Joints {
import Box2D.Common.Math.*;
import Box2D.Dynamics.*;
import Box2D.Common.*;
public class b2GearJoint extends b2Joint {
public var m_ground1:b2Body;
public var m_ground2:b2Body;
public var m_revolute1:b2RevoluteJoint;
public var m_prismatic1:b2PrismaticJoint;
public var m_revolute2:b2RevoluteJoint;
public var m_prismatic2:b2PrismaticJoint;
public var m_groundAnchor1:b2Vec2;
public var m_groundAnchor2:b2Vec2;
public var m_localAnchor1:b2Vec2;
public var m_localAnchor2:b2Vec2;
public var m_J:b2Jacobian;
public var m_constant:Number;
public var m_ratio:Number;
public var m_mass:Number;
public var m_force:Number;
public function b2GearJoint(def:b2GearJointDef){
var coordinate1:Number;
var coordinate2:Number;
m_groundAnchor1 = new b2Vec2();
m_groundAnchor2 = new b2Vec2();
m_localAnchor1 = new b2Vec2();
m_localAnchor2 = new b2Vec2();
m_J = new b2Jacobian();
super(def);
var type1:int = def.joint1.m_type;
var type2:int = def.joint2.m_type;
m_revolute1 = null;
m_prismatic1 = null;
m_revolute2 = null;
m_prismatic2 = null;
m_ground1 = def.joint1.m_body1;
m_body1 = def.joint1.m_body2;
if (type1 == b2Joint.e_revoluteJoint){
m_revolute1 = (def.joint1 as b2RevoluteJoint);
m_groundAnchor1.SetV(m_revolute1.m_localAnchor1);
m_localAnchor1.SetV(m_revolute1.m_localAnchor2);
coordinate1 = m_revolute1.GetJointAngle();
} else {
m_prismatic1 = (def.joint1 as b2PrismaticJoint);
m_groundAnchor1.SetV(m_prismatic1.m_localAnchor1);
m_localAnchor1.SetV(m_prismatic1.m_localAnchor2);
coordinate1 = m_prismatic1.GetJointTranslation();
};
m_ground2 = def.joint2.m_body1;
m_body2 = def.joint2.m_body2;
if (type2 == b2Joint.e_revoluteJoint){
m_revolute2 = (def.joint2 as b2RevoluteJoint);
m_groundAnchor2.SetV(m_revolute2.m_localAnchor1);
m_localAnchor2.SetV(m_revolute2.m_localAnchor2);
coordinate2 = m_revolute2.GetJointAngle();
} else {
m_prismatic2 = (def.joint2 as b2PrismaticJoint);
m_groundAnchor2.SetV(m_prismatic2.m_localAnchor1);
m_localAnchor2.SetV(m_prismatic2.m_localAnchor2);
coordinate2 = m_prismatic2.GetJointTranslation();
};
m_ratio = def.ratio;
m_constant = (coordinate1 + (m_ratio * coordinate2));
m_force = 0;
}
override public function GetAnchor1():b2Vec2{
return (m_body1.GetWorldPoint(m_localAnchor1));
}
override public function GetAnchor2():b2Vec2{
return (m_body2.GetWorldPoint(m_localAnchor2));
}
override public function GetReactionForce():b2Vec2{
var F:b2Vec2 = new b2Vec2((m_force * m_J.linear2.x), (m_force * m_J.linear2.y));
return (F);
}
override public function GetReactionTorque():Number{
var tMat:b2Mat22 = m_body2.m_xf.R;
var rX:Number = (m_localAnchor1.x - m_body2.m_sweep.localCenter.x);
var rY:Number = (m_localAnchor1.y - m_body2.m_sweep.localCenter.y);
var tX:Number = ((tMat.col1.x * rX) + (tMat.col2.x * rY));
rY = ((tMat.col1.y * rX) + (tMat.col2.y * rY));
rX = tX;
tX = ((m_force * m_J.angular2) - ((rX * (m_force * m_J.linear2.y)) - (rY * (m_force * m_J.linear2.x))));
return (tX);
}
public function GetRatio():Number{
return (m_ratio);
}
override public function InitVelocityConstraints(step:b2TimeStep):void{
var ugX:Number;
var ugY:Number;
var rX:Number;
var rY:Number;
var tMat:b2Mat22;
var tVec:b2Vec2;
var crug:Number;
var tX:Number;
var P:Number;
var g1:b2Body = m_ground1;
var g2:b2Body = m_ground2;
var b1:b2Body = m_body1;
var b2:b2Body = m_body2;
var K:Number = 0;
m_J.SetZero();
if (m_revolute1){
m_J.angular1 = -1;
K = (K + b1.m_invI);
} else {
tMat = g1.m_xf.R;
tVec = m_prismatic1.m_localXAxis1;
ugX = ((tMat.col1.x * tVec.x) + (tMat.col2.x * tVec.y));
ugY = ((tMat.col1.y * tVec.x) + (tMat.col2.y * tVec.y));
tMat = b1.m_xf.R;
rX = (m_localAnchor1.x - b1.m_sweep.localCenter.x);
rY = (m_localAnchor1.y - b1.m_sweep.localCenter.y);
tX = ((tMat.col1.x * rX) + (tMat.col2.x * rY));
rY = ((tMat.col1.y * rX) + (tMat.col2.y * rY));
rX = tX;
crug = ((rX * ugY) - (rY * ugX));
m_J.linear1.Set(-(ugX), -(ugY));
m_J.angular1 = -(crug);
K = (K + (b1.m_invMass + ((b1.m_invI * crug) * crug)));
};
if (m_revolute2){
m_J.angular2 = -(m_ratio);
K = (K + ((m_ratio * m_ratio) * b2.m_invI));
} else {
tMat = g2.m_xf.R;
tVec = m_prismatic2.m_localXAxis1;
ugX = ((tMat.col1.x * tVec.x) + (tMat.col2.x * tVec.y));
ugY = ((tMat.col1.y * tVec.x) + (tMat.col2.y * tVec.y));
tMat = b2.m_xf.R;
rX = (m_localAnchor2.x - b2.m_sweep.localCenter.x);
rY = (m_localAnchor2.y - b2.m_sweep.localCenter.y);
tX = ((tMat.col1.x * rX) + (tMat.col2.x * rY));
rY = ((tMat.col1.y * rX) + (tMat.col2.y * rY));
rX = tX;
crug = ((rX * ugY) - (rY * ugX));
m_J.linear2.Set((-(m_ratio) * ugX), (-(m_ratio) * ugY));
m_J.angular2 = (-(m_ratio) * crug);
K = (K + ((m_ratio * m_ratio) * (b2.m_invMass + ((b2.m_invI * crug) * crug))));
};
m_mass = (1 / K);
if (step.warmStarting){
P = (step.dt * m_force);
b1.m_linearVelocity.x = (b1.m_linearVelocity.x + ((b1.m_invMass * P) * m_J.linear1.x));
b1.m_linearVelocity.y = (b1.m_linearVelocity.y + ((b1.m_invMass * P) * m_J.linear1.y));
b1.m_angularVelocity = (b1.m_angularVelocity + ((b1.m_invI * P) * m_J.angular1));
b2.m_linearVelocity.x = (b2.m_linearVelocity.x + ((b2.m_invMass * P) * m_J.linear2.x));
b2.m_linearVelocity.y = (b2.m_linearVelocity.y + ((b2.m_invMass * P) * m_J.linear2.y));
b2.m_angularVelocity = (b2.m_angularVelocity + ((b2.m_invI * P) * m_J.angular2));
} else {
m_force = 0;
};
}
override public function SolveVelocityConstraints(step:b2TimeStep):void{
var b1:b2Body = m_body1;
var b2:b2Body = m_body2;
var Cdot:Number = m_J.Compute(b1.m_linearVelocity, b1.m_angularVelocity, b2.m_linearVelocity, b2.m_angularVelocity);
var force:Number = ((-(step.inv_dt) * m_mass) * Cdot);
m_force = (m_force + force);
var P:Number = (step.dt * force);
b1.m_linearVelocity.x = (b1.m_linearVelocity.x + ((b1.m_invMass * P) * m_J.linear1.x));
b1.m_linearVelocity.y = (b1.m_linearVelocity.y + ((b1.m_invMass * P) * m_J.linear1.y));
b1.m_angularVelocity = (b1.m_angularVelocity + ((b1.m_invI * P) * m_J.angular1));
b2.m_linearVelocity.x = (b2.m_linearVelocity.x + ((b2.m_invMass * P) * m_J.linear2.x));
b2.m_linearVelocity.y = (b2.m_linearVelocity.y + ((b2.m_invMass * P) * m_J.linear2.y));
b2.m_angularVelocity = (b2.m_angularVelocity + ((b2.m_invI * P) * m_J.angular2));
}
override public function SolvePositionConstraints():Boolean{
var coordinate1:Number;
var coordinate2:Number;
var linearError:Number = 0;
var b1:b2Body = m_body1;
var b2:b2Body = m_body2;
if (m_revolute1){
coordinate1 = m_revolute1.GetJointAngle();
} else {
coordinate1 = m_prismatic1.GetJointTranslation();
};
if (m_revolute2){
coordinate2 = m_revolute2.GetJointAngle();
} else {
coordinate2 = m_prismatic2.GetJointTranslation();
};
var C:Number = (m_constant - (coordinate1 + (m_ratio * coordinate2)));
var impulse:Number = (-(m_mass) * C);
b1.m_sweep.c.x = (b1.m_sweep.c.x + ((b1.m_invMass * impulse) * m_J.linear1.x));
b1.m_sweep.c.y = (b1.m_sweep.c.y + ((b1.m_invMass * impulse) * m_J.linear1.y));
b1.m_sweep.a = (b1.m_sweep.a + ((b1.m_invI * impulse) * m_J.angular1));
b2.m_sweep.c.x = (b2.m_sweep.c.x + ((b2.m_invMass * impulse) * m_J.linear2.x));
b2.m_sweep.c.y = (b2.m_sweep.c.y + ((b2.m_invMass * impulse) * m_J.linear2.y));
b2.m_sweep.a = (b2.m_sweep.a + ((b2.m_invI * impulse) * m_J.angular2));
b1.SynchronizeTransform();
b2.SynchronizeTransform();
return ((linearError < b2Settings.b2_linearSlop));
}
}
}//package Box2D.Dynamics.Joints
Section 52
//b2GearJointDef (Box2D.Dynamics.Joints.b2GearJointDef)
package Box2D.Dynamics.Joints {
public class b2GearJointDef extends b2JointDef {
public var joint1:b2Joint;
public var joint2:b2Joint;
public var ratio:Number;
public function b2GearJointDef(){
super();
type = b2Joint.e_gearJoint;
joint1 = null;
joint2 = null;
ratio = 1;
}
}
}//package Box2D.Dynamics.Joints
Section 53
//b2Jacobian (Box2D.Dynamics.Joints.b2Jacobian)
package Box2D.Dynamics.Joints {
import Box2D.Common.Math.*;
public class b2Jacobian {
public var linear1:b2Vec2;
public var angular1:Number;
public var linear2:b2Vec2;
public var angular2:Number;
public function b2Jacobian(){
linear1 = new b2Vec2();
linear2 = new b2Vec2();
super();
}
public function SetZero():void{
linear1.SetZero();
angular1 = 0;
linear2.SetZero();
angular2 = 0;
}
public function Set(x1:b2Vec2, a1:Number, x2:b2Vec2, a2:Number):void{
linear1.SetV(x1);
angular1 = a1;
linear2.SetV(x2);
angular2 = a2;
}
public function Compute(x1:b2Vec2, a1:Number, x2:b2Vec2, a2:Number):Number{
return ((((((linear1.x * x1.x) + (linear1.y * x1.y)) + (angular1 * a1)) + ((linear2.x * x2.x) + (linear2.y * x2.y))) + (angular2 * a2)));
}
}
}//package Box2D.Dynamics.Joints
Section 54
//b2Joint (Box2D.Dynamics.Joints.b2Joint)
package Box2D.Dynamics.Joints {
import Box2D.Common.Math.*;
import Box2D.Dynamics.*;
public class b2Joint {
public var m_type:int;
public var m_prev:b2Joint;
public var m_next:b2Joint;
public var m_node1:b2JointEdge;
public var m_node2:b2JointEdge;
public var m_body1:b2Body;
public var m_body2:b2Body;
public var m_inv_dt:Number;
public var m_islandFlag:Boolean;
public var m_collideConnected:Boolean;
public var m_userData;
public static const e_unknownJoint:int = 0;
public static const e_revoluteJoint:int = 1;
public static const e_prismaticJoint:int = 2;
public static const e_distanceJoint:int = 3;
public static const e_pulleyJoint:int = 4;
public static const e_mouseJoint:int = 5;
public static const e_gearJoint:int = 6;
public static const e_inactiveLimit:int = 0;
public static const e_atLowerLimit:int = 1;
public static const e_atUpperLimit:int = 2;
public static const e_equalLimits:int = 3;
public function b2Joint(def:b2JointDef){
m_node1 = new b2JointEdge();
m_node2 = new b2JointEdge();
super();
m_type = def.type;
m_prev = null;
m_next = null;
m_body1 = def.body1;
m_body2 = def.body2;
m_collideConnected = def.collideConnected;
m_islandFlag = false;
m_userData = def.userData;
}
public function GetType():int{
return (m_type);
}
public function GetAnchor1():b2Vec2{
return (null);
}
public function GetAnchor2():b2Vec2{
return (null);
}
public function GetReactionForce():b2Vec2{
return (null);
}
public function GetReactionTorque():Number{
return (0);
}
public function GetBody1():b2Body{
return (m_body1);
}
public function GetBody2():b2Body{
return (m_body2);
}
public function GetNext():b2Joint{
return (m_next);
}
public function GetUserData(){
return (m_userData);
}
public function SetUserData(data):void{
m_userData = data;
}
public function InitVelocityConstraints(step:b2TimeStep):void{
}
public function SolveVelocityConstraints(step:b2TimeStep):void{
}
public function InitPositionConstraints():void{
}
public function SolvePositionConstraints():Boolean{
return (false);
}
public static function Create(def:b2JointDef, allocator):b2Joint{
var joint:b2Joint;
switch (def.type){
case e_distanceJoint:
joint = new b2DistanceJoint((def as b2DistanceJointDef));
break;
case e_mouseJoint:
joint = new b2MouseJoint((def as b2MouseJointDef));
break;
case e_prismaticJoint:
joint = new b2PrismaticJoint((def as b2PrismaticJointDef));
break;
case e_revoluteJoint:
joint = new b2RevoluteJoint((def as b2RevoluteJointDef));
break;
case e_pulleyJoint:
joint = new b2PulleyJoint((def as b2PulleyJointDef));
break;
case e_gearJoint:
joint = new b2GearJoint((def as b2GearJointDef));
break;
default:
break;
};
return (joint);
}
public static function Destroy(joint:b2Joint, allocator):void{
}
}
}//package Box2D.Dynamics.Joints
Section 55
//b2JointDef (Box2D.Dynamics.Joints.b2JointDef)
package Box2D.Dynamics.Joints {
import Box2D.Dynamics.*;
public class b2JointDef {
public var type:int;
public var userData;
public var body1:b2Body;
public var body2:b2Body;
public var collideConnected:Boolean;
public function b2JointDef(){
super();
type = b2Joint.e_unknownJoint;
userData = null;
body1 = null;
body2 = null;
collideConnected = false;
}
}
}//package Box2D.Dynamics.Joints
Section 56
//b2JointEdge (Box2D.Dynamics.Joints.b2JointEdge)
package Box2D.Dynamics.Joints {
import Box2D.Dynamics.*;
public class b2JointEdge {
public var other:b2Body;
public var joint:b2Joint;
public var prev:b2JointEdge;
public var next:b2JointEdge;
}
}//package Box2D.Dynamics.Joints
Section 57
//b2MouseJoint (Box2D.Dynamics.Joints.b2MouseJoint)
package Box2D.Dynamics.Joints {
import Box2D.Common.Math.*;
import Box2D.Dynamics.*;
import Box2D.Common.*;
public class b2MouseJoint extends b2Joint {
private var K:b2Mat22;
private var K1:b2Mat22;
private var K2:b2Mat22;
public var m_localAnchor:b2Vec2;
public var m_target:b2Vec2;
public var m_impulse:b2Vec2;
public var m_mass:b2Mat22;
public var m_C:b2Vec2;
public var m_maxForce:Number;
public var m_beta:Number;
public var m_gamma:Number;
public function b2MouseJoint(def:b2MouseJointDef){
var tY:Number;
K = new b2Mat22();
K1 = new b2Mat22();
K2 = new b2Mat22();
m_localAnchor = new b2Vec2();
m_target = new b2Vec2();
m_impulse = new b2Vec2();
m_mass = new b2Mat22();
m_C = new b2Vec2();
super(def);
m_target.SetV(def.target);
var tX:Number = (m_target.x - m_body2.m_xf.position.x);
tY = (m_target.y - m_body2.m_xf.position.y);
var tMat:b2Mat22 = m_body2.m_xf.R;
m_localAnchor.x = ((tX * tMat.col1.x) + (tY * tMat.col1.y));
m_localAnchor.y = ((tX * tMat.col2.x) + (tY * tMat.col2.y));
m_maxForce = def.maxForce;
m_impulse.SetZero();
var mass:Number = m_body2.m_mass;
var omega:Number = ((2 * b2Settings.b2_pi) * def.frequencyHz);
var d:Number = (((2 * mass) * def.dampingRatio) * omega);
var k:Number = ((def.timeStep * mass) * (omega * omega));
m_gamma = (1 / (d + k));
m_beta = (k / (d + k));
}
override public function GetAnchor1():b2Vec2{
return (m_target);
}
override public function GetAnchor2():b2Vec2{
return (m_body2.GetWorldPoint(m_localAnchor));
}
override public function GetReactionForce():b2Vec2{
return (m_impulse);
}
override public function GetReactionTorque():Number{
return (0);
}
public function SetTarget(target:b2Vec2):void{
if (m_body2.IsSleeping()){
m_body2.WakeUp();
};
m_target = target;
}
override public function InitVelocityConstraints(step:b2TimeStep):void{
var b:b2Body;
var tMat:b2Mat22;
var rX:Number;
var rY:Number;
var invMass:Number;
var invI:Number;
b = m_body2;
tMat = b.m_xf.R;
rX = (m_localAnchor.x - b.m_sweep.localCenter.x);
rY = (m_localAnchor.y - b.m_sweep.localCenter.y);
var tX:Number = ((tMat.col1.x * rX) + (tMat.col2.x * rY));
rY = ((tMat.col1.y * rX) + (tMat.col2.y * rY));
rX = tX;
invMass = b.m_invMass;
invI = b.m_invI;
K1.col1.x = invMass;
K1.col2.x = 0;
K1.col1.y = 0;
K1.col2.y = invMass;
K2.col1.x = ((invI * rY) * rY);
K2.col2.x = ((-(invI) * rX) * rY);
K2.col1.y = ((-(invI) * rX) * rY);
K2.col2.y = ((invI * rX) * rX);
K.SetM(K1);
K.AddM(K2);
K.col1.x = (K.col1.x + m_gamma);
K.col2.y = (K.col2.y + m_gamma);
K.Invert(m_mass);
m_C.x = ((b.m_sweep.c.x + rX) - m_target.x);
m_C.y = ((b.m_sweep.c.y + rY) - m_target.y);
b.m_angularVelocity = (b.m_angularVelocity * 0.98);
var PX:Number = (step.dt * m_impulse.x);
var PY:Number = (step.dt * m_impulse.y);
b.m_linearVelocity.x = (b.m_linearVelocity.x + (invMass * PX));
b.m_linearVelocity.y = (b.m_linearVelocity.y + (invMass * PY));
b.m_angularVelocity = (b.m_angularVelocity + (invI * ((rX * PY) - (rY * PX))));
}
override public function SolveVelocityConstraints(step:b2TimeStep):void{
var tMat:b2Mat22;
var tX:Number;
var tY:Number;
var b:b2Body = m_body2;
tMat = b.m_xf.R;
var rX:Number = (m_localAnchor.x - b.m_sweep.localCenter.x);
var rY:Number = (m_localAnchor.y - b.m_sweep.localCenter.y);
tX = ((tMat.col1.x * rX) + (tMat.col2.x * rY));
rY = ((tMat.col1.y * rX) + (tMat.col2.y * rY));
rX = tX;
var CdotX:Number = (b.m_linearVelocity.x + (-(b.m_angularVelocity) * rY));
var CdotY:Number = (b.m_linearVelocity.y + (b.m_angularVelocity * rX));
tMat = m_mass;
tX = ((CdotX + ((m_beta * step.inv_dt) * m_C.x)) + ((m_gamma * step.dt) * m_impulse.x));
tY = ((CdotY + ((m_beta * step.inv_dt) * m_C.y)) + ((m_gamma * step.dt) * m_impulse.y));
var forceX:Number = (-(step.inv_dt) * ((tMat.col1.x * tX) + (tMat.col2.x * tY)));
var forceY:Number = (-(step.inv_dt) * ((tMat.col1.y * tX) + (tMat.col2.y * tY)));
var oldForceX:Number = m_impulse.x;
var oldForceY:Number = m_impulse.y;
m_impulse.x = (m_impulse.x + forceX);
m_impulse.y = (m_impulse.y + forceY);
var forceMagnitude:Number = m_impulse.Length();
if (forceMagnitude > m_maxForce){
m_impulse.Multiply((m_maxForce / forceMagnitude));
};
forceX = (m_impulse.x - oldForceX);
forceY = (m_impulse.y - oldForceY);
var PX:Number = (step.dt * forceX);
var PY:Number = (step.dt * forceY);
b.m_linearVelocity.x = (b.m_linearVelocity.x + (b.m_invMass * PX));
b.m_linearVelocity.y = (b.m_linearVelocity.y + (b.m_invMass * PY));
b.m_angularVelocity = (b.m_angularVelocity + (b.m_invI * ((rX * PY) - (rY * PX))));
}
override public function SolvePositionConstraints():Boolean{
return (true);
}
}
}//package Box2D.Dynamics.Joints
Section 58
//b2MouseJointDef (Box2D.Dynamics.Joints.b2MouseJointDef)
package Box2D.Dynamics.Joints {
import Box2D.Common.Math.*;
public class b2MouseJointDef extends b2JointDef {
public var target:b2Vec2;
public var maxForce:Number;
public var frequencyHz:Number;
public var dampingRatio:Number;
public var timeStep:Number;
public function b2MouseJointDef(){
target = new b2Vec2();
super();
type = b2Joint.e_mouseJoint;
maxForce = 0;
frequencyHz = 5;
dampingRatio = 0.7;
timeStep = (1 / 60);
}
}
}//package Box2D.Dynamics.Joints
Section 59
//b2PrismaticJoint (Box2D.Dynamics.Joints.b2PrismaticJoint)
package Box2D.Dynamics.Joints {
import Box2D.Common.Math.*;
import Box2D.Dynamics.*;
import Box2D.Common.*;
public class b2PrismaticJoint extends b2Joint {
public var m_localAnchor1:b2Vec2;
public var m_localAnchor2:b2Vec2;
public var m_localXAxis1:b2Vec2;
public var m_localYAxis1:b2Vec2;
public var m_refAngle:Number;
public var m_linearJacobian:b2Jacobian;
public var m_linearMass:Number;
public var m_force:Number;
public var m_angularMass:Number;
public var m_torque:Number;
public var m_motorJacobian:b2Jacobian;
public var m_motorMass:Number;
public var m_motorForce:Number;
public var m_limitForce:Number;
public var m_limitPositionImpulse:Number;
public var m_lowerTranslation:Number;
public var m_upperTranslation:Number;
public var m_maxMotorForce:Number;
public var m_motorSpeed:Number;
public var m_enableLimit:Boolean;
public var m_enableMotor:Boolean;
public var m_limitState:int;
public function b2PrismaticJoint(def:b2PrismaticJointDef){
var tMat:b2Mat22;
var tX:Number;
var tY:Number;
m_localAnchor1 = new b2Vec2();
m_localAnchor2 = new b2Vec2();
m_localXAxis1 = new b2Vec2();
m_localYAxis1 = new b2Vec2();
m_linearJacobian = new b2Jacobian();
m_motorJacobian = new b2Jacobian();
super(def);
m_localAnchor1.SetV(def.localAnchor1);
m_localAnchor2.SetV(def.localAnchor2);
m_localXAxis1.SetV(def.localAxis1);
m_localYAxis1.x = -(m_localXAxis1.y);
m_localYAxis1.y = m_localXAxis1.x;
m_refAngle = def.referenceAngle;
m_linearJacobian.SetZero();
m_linearMass = 0;
m_force = 0;
m_angularMass = 0;
m_torque = 0;
m_motorJacobian.SetZero();
m_motorMass = 0;
m_motorForce = 0;
m_limitForce = 0;
m_limitPositionImpulse = 0;
m_lowerTranslation = def.lowerTranslation;
m_upperTranslation = def.upperTranslation;
m_maxMotorForce = def.maxMotorForce;
m_motorSpeed = def.motorSpeed;
m_enableLimit = def.enableLimit;
m_enableMotor = def.enableMotor;
}
override public function GetAnchor1():b2Vec2{
return (m_body1.GetWorldPoint(m_localAnchor1));
}
override public function GetAnchor2():b2Vec2{
return (m_body2.GetWorldPoint(m_localAnchor2));
}
override public function GetReactionForce():b2Vec2{
var tMat:b2Mat22 = m_body1.m_xf.R;
var ax1X:Number = (m_limitForce * ((tMat.col1.x * m_localXAxis1.x) + (tMat.col2.x * m_localXAxis1.y)));
var ax1Y:Number = (m_limitForce * ((tMat.col1.y * m_localXAxis1.x) + (tMat.col2.y * m_localXAxis1.y)));
var ay1X:Number = (m_force * ((tMat.col1.x * m_localYAxis1.x) + (tMat.col2.x * m_localYAxis1.y)));
var ay1Y:Number = (m_force * ((tMat.col1.y * m_localYAxis1.x) + (tMat.col2.y * m_localYAxis1.y)));
return (new b2Vec2(((m_limitForce * ax1X) + (m_force * ay1X)), ((m_limitForce * ax1Y) + (m_force * ay1Y))));
}
override public function GetReactionTorque():Number{
return (m_torque);
}
public function GetJointTranslation():Number{
var tMat:b2Mat22;
var b1:b2Body = m_body1;
var b2:b2Body = m_body2;
var p1:b2Vec2 = b1.GetWorldPoint(m_localAnchor1);
var p2:b2Vec2 = b2.GetWorldPoint(m_localAnchor2);
var dX:Number = (p2.x - p1.x);
var dY:Number = (p2.y - p1.y);
var axis:b2Vec2 = b1.GetWorldVector(m_localXAxis1);
var translation:Number = ((axis.x * dX) + (axis.y * dY));
return (translation);
}
public function GetJointSpeed():Number{
var tMat:b2Mat22;
var b1:b2Body = m_body1;
var b2:b2Body = m_body2;
tMat = b1.m_xf.R;
var r1X:Number = (m_localAnchor1.x - b1.m_sweep.localCenter.x);
var r1Y:Number = (m_localAnchor1.y - b1.m_sweep.localCenter.y);
var tX:Number = ((tMat.col1.x * r1X) + (tMat.col2.x * r1Y));
r1Y = ((tMat.col1.y * r1X) + (tMat.col2.y * r1Y));
r1X = tX;
tMat = b2.m_xf.R;
var r2X:Number = (m_localAnchor2.x - b2.m_sweep.localCenter.x);
var r2Y:Number = (m_localAnchor2.y - b2.m_sweep.localCenter.y);
tX = ((tMat.col1.x * r2X) + (tMat.col2.x * r2Y));
r2Y = ((tMat.col1.y * r2X) + (tMat.col2.y * r2Y));
r2X = tX;
var p1X:Number = (b1.m_sweep.c.x + r1X);
var p1Y:Number = (b1.m_sweep.c.y + r1Y);
var p2X:Number = (b2.m_sweep.c.x + r2X);
var p2Y:Number = (b2.m_sweep.c.y + r2Y);
var dX:Number = (p2X - p1X);
var dY:Number = (p2Y - p1Y);
var axis:b2Vec2 = b1.GetWorldVector(m_localXAxis1);
var v1:b2Vec2 = b1.m_linearVelocity;
var v2:b2Vec2 = b2.m_linearVelocity;
var w1:Number = b1.m_angularVelocity;
var w2:Number = b2.m_angularVelocity;
var speed:Number = (((dX * (-(w1) * axis.y)) + (dY * (w1 * axis.x))) + ((axis.x * (((v2.x + (-(w2) * r2Y)) - v1.x) - (-(w1) * r1Y))) + (axis.y * (((v2.y + (w2 * r2X)) - v1.y) - (w1 * r1X)))));
return (speed);
}
public function IsLimitEnabled():Boolean{
return (m_enableLimit);
}
public function EnableLimit(flag:Boolean):void{
m_enableLimit = flag;
}
public function GetLowerLimit():Number{
return (m_lowerTranslation);
}
public function GetUpperLimit():Number{
return (m_upperTranslation);
}
public function SetLimits(lower:Number, upper:Number):void{
m_lowerTranslation = lower;
m_upperTranslation = upper;
}
public function IsMotorEnabled():Boolean{
return (m_enableMotor);
}
public function EnableMotor(flag:Boolean):void{
m_enableMotor = flag;
}
public function SetMotorSpeed(speed:Number):void{
m_motorSpeed = speed;
}
public function GetMotorSpeed():Number{
return (m_motorSpeed);
}
public function SetMaxMotorForce(force:Number):void{
m_maxMotorForce = force;
}
public function GetMotorForce():Number{
return (m_motorForce);
}
override public function InitVelocityConstraints(step:b2TimeStep):void{
var tMat:b2Mat22;
var tX:Number;
var ax1X:Number;
var ax1Y:Number;
var dX:Number;
var dY:Number;
var jointTranslation:Number;
var P1X:Number;
var P1Y:Number;
var P2X:Number;
var P2Y:Number;
var L1:Number;
var L2:Number;
var b1:b2Body = m_body1;
var b2:b2Body = m_body2;
tMat = b1.m_xf.R;
var r1X:Number = (m_localAnchor1.x - b1.m_sweep.localCenter.x);
var r1Y:Number = (m_localAnchor1.y - b1.m_sweep.localCenter.y);
tX = ((tMat.col1.x * r1X) + (tMat.col2.x * r1Y));
r1Y = ((tMat.col1.y * r1X) + (tMat.col2.y * r1Y));
r1X = tX;
tMat = b2.m_xf.R;
var r2X:Number = (m_localAnchor2.x - b2.m_sweep.localCenter.x);
var r2Y:Number = (m_localAnchor2.y - b2.m_sweep.localCenter.y);
tX = ((tMat.col1.x * r2X) + (tMat.col2.x * r2Y));
r2Y = ((tMat.col1.y * r2X) + (tMat.col2.y * r2Y));
r2X = tX;
var invMass1:Number = b1.m_invMass;
var invMass2:Number = b2.m_invMass;
var invI1:Number = b1.m_invI;
var invI2:Number = b2.m_invI;
tMat = b1.m_xf.R;
var ay1X:Number = ((tMat.col1.x * m_localYAxis1.x) + (tMat.col2.x * m_localYAxis1.y));
var ay1Y:Number = ((tMat.col1.y * m_localYAxis1.x) + (tMat.col2.y * m_localYAxis1.y));
var eX:Number = ((b2.m_sweep.c.x + r2X) - b1.m_sweep.c.x);
var eY:Number = ((b2.m_sweep.c.y + r2Y) - b1.m_sweep.c.y);
m_linearJacobian.linear1.x = -(ay1X);
m_linearJacobian.linear1.y = -(ay1Y);
m_linearJacobian.linear2.x = ay1X;
m_linearJacobian.linear2.y = ay1Y;
m_linearJacobian.angular1 = -(((eX * ay1Y) - (eY * ay1X)));
m_linearJacobian.angular2 = ((r2X * ay1Y) - (r2Y * ay1X));
m_linearMass = (((invMass1 + ((invI1 * m_linearJacobian.angular1) * m_linearJacobian.angular1)) + invMass2) + ((invI2 * m_linearJacobian.angular2) * m_linearJacobian.angular2));
m_linearMass = (1 / m_linearMass);
m_angularMass = (invI1 + invI2);
if (m_angularMass > Number.MIN_VALUE){
m_angularMass = (1 / m_angularMass);
};
if (((m_enableLimit) || (m_enableMotor))){
tMat = b1.m_xf.R;
ax1X = ((tMat.col1.x * m_localXAxis1.x) + (tMat.col2.x * m_localXAxis1.y));
ax1Y = ((tMat.col1.y * m_localXAxis1.x) + (tMat.col2.y * m_localXAxis1.y));
m_motorJacobian.linear1.x = -(ax1X);
m_motorJacobian.linear1.y = -(ax1Y);
m_motorJacobian.linear2.x = ax1X;
m_motorJacobian.linear2.y = ax1Y;
m_motorJacobian.angular1 = -(((eX * ax1Y) - (eY * ax1X)));
m_motorJacobian.angular2 = ((r2X * ax1Y) - (r2Y * ax1X));
m_motorMass = (((invMass1 + ((invI1 * m_motorJacobian.angular1) * m_motorJacobian.angular1)) + invMass2) + ((invI2 * m_motorJacobian.angular2) * m_motorJacobian.angular2));
m_motorMass = (1 / m_motorMass);
if (m_enableLimit){
dX = (eX - r1X);
dY = (eY - r1Y);
jointTranslation = ((ax1X * dX) + (ax1Y * dY));
if (b2Math.b2Abs((m_upperTranslation - m_lowerTranslation)) < (2 * b2Settings.b2_linearSlop)){
m_limitState = e_equalLimits;
} else {
if (jointTranslation <= m_lowerTranslation){
if (m_limitState != e_atLowerLimit){
m_limitForce = 0;
};
m_limitState = e_atLowerLimit;
} else {
if (jointTranslation >= m_upperTranslation){
if (m_limitState != e_atUpperLimit){
m_limitForce = 0;
};
m_limitState = e_atUpperLimit;
} else {
m_limitState = e_inactiveLimit;
m_limitForce = 0;
};
};
};
};
};
if (m_enableMotor == false){
m_motorForce = 0;
};
if (m_enableLimit == false){
m_limitForce = 0;
};
if (step.warmStarting){
P1X = (step.dt * ((m_force * m_linearJacobian.linear1.x) + ((m_motorForce + m_limitForce) * m_motorJacobian.linear1.x)));
P1Y = (step.dt * ((m_force * m_linearJacobian.linear1.y) + ((m_motorForce + m_limitForce) * m_motorJacobian.linear1.y)));
P2X = (step.dt * ((m_force * m_linearJacobian.linear2.x) + ((m_motorForce + m_limitForce) * m_motorJacobian.linear2.x)));
P2Y = (step.dt * ((m_force * m_linearJacobian.linear2.y) + ((m_motorForce + m_limitForce) * m_motorJacobian.linear2.y)));
L1 = (step.dt * (((m_force * m_linearJacobian.angular1) - m_torque) + ((m_motorForce + m_limitForce) * m_motorJacobian.angular1)));
L2 = (step.dt * (((m_force * m_linearJacobian.angular2) + m_torque) + ((m_motorForce + m_limitForce) * m_motorJacobian.angular2)));
b1.m_linearVelocity.x = (b1.m_linearVelocity.x + (invMass1 * P1X));
b1.m_linearVelocity.y = (b1.m_linearVelocity.y + (invMass1 * P1Y));
b1.m_angularVelocity = (b1.m_angularVelocity + (invI1 * L1));
b2.m_linearVelocity.x = (b2.m_linearVelocity.x + (invMass2 * P2X));
b2.m_linearVelocity.y = (b2.m_linearVelocity.y + (invMass2 * P2Y));
b2.m_angularVelocity = (b2.m_angularVelocity + (invI2 * L2));
} else {
m_force = 0;
m_torque = 0;
m_limitForce = 0;
m_motorForce = 0;
};
m_limitPositionImpulse = 0;
}
override public function SolveVelocityConstraints(step:b2TimeStep):void{
var oldLimitForce:Number;
var motorCdot:Number;
var motorForce:Number;
var oldMotorForce:Number;
var limitCdot:Number;
var limitForce:Number;
var b1:b2Body = m_body1;
var b2:b2Body = m_body2;
var invMass1:Number = b1.m_invMass;
var invMass2:Number = b2.m_invMass;
var invI1:Number = b1.m_invI;
var invI2:Number = b2.m_invI;
var linearCdot:Number = m_linearJacobian.Compute(b1.m_linearVelocity, b1.m_angularVelocity, b2.m_linearVelocity, b2.m_angularVelocity);
var force:Number = ((-(step.inv_dt) * m_linearMass) * linearCdot);
m_force = (m_force + force);
var P:Number = (step.dt * force);
b1.m_linearVelocity.x = (b1.m_linearVelocity.x + ((invMass1 * P) * m_linearJacobian.linear1.x));
b1.m_linearVelocity.y = (b1.m_linearVelocity.y + ((invMass1 * P) * m_linearJacobian.linear1.y));
b1.m_angularVelocity = (b1.m_angularVelocity + ((invI1 * P) * m_linearJacobian.angular1));
b2.m_linearVelocity.x = (b2.m_linearVelocity.x + ((invMass2 * P) * m_linearJacobian.linear2.x));
b2.m_linearVelocity.y = (b2.m_linearVelocity.y + ((invMass2 * P) * m_linearJacobian.linear2.y));
b2.m_angularVelocity = (b2.m_angularVelocity + ((invI2 * P) * m_linearJacobian.angular2));
var angularCdot:Number = (b2.m_angularVelocity - b1.m_angularVelocity);
var torque:Number = ((-(step.inv_dt) * m_angularMass) * angularCdot);
m_torque = (m_torque + torque);
var L:Number = (step.dt * torque);
b1.m_angularVelocity = (b1.m_angularVelocity - (invI1 * L));
b2.m_angularVelocity = (b2.m_angularVelocity + (invI2 * L));
if (((m_enableMotor) && (!((m_limitState == e_equalLimits))))){
motorCdot = (m_motorJacobian.Compute(b1.m_linearVelocity, b1.m_angularVelocity, b2.m_linearVelocity, b2.m_angularVelocity) - m_motorSpeed);
motorForce = ((-(step.inv_dt) * m_motorMass) * motorCdot);
oldMotorForce = m_motorForce;
m_motorForce = b2Math.b2Clamp((m_motorForce + motorForce), -(m_maxMotorForce), m_maxMotorForce);
motorForce = (m_motorForce - oldMotorForce);
P = (step.dt * motorForce);
b1.m_linearVelocity.x = (b1.m_linearVelocity.x + ((invMass1 * P) * m_motorJacobian.linear1.x));
b1.m_linearVelocity.y = (b1.m_linearVelocity.y + ((invMass1 * P) * m_motorJacobian.linear1.y));
b1.m_angularVelocity = (b1.m_angularVelocity + ((invI1 * P) * m_motorJacobian.angular1));
b2.m_linearVelocity.x = (b2.m_linearVelocity.x + ((invMass2 * P) * m_motorJacobian.linear2.x));
b2.m_linearVelocity.y = (b2.m_linearVelocity.y + ((invMass2 * P) * m_motorJacobian.linear2.y));
b2.m_angularVelocity = (b2.m_angularVelocity + ((invI2 * P) * m_motorJacobian.angular2));
};
if (((m_enableLimit) && (!((m_limitState == e_inactiveLimit))))){
limitCdot = m_motorJacobian.Compute(b1.m_linearVelocity, b1.m_angularVelocity, b2.m_linearVelocity, b2.m_angularVelocity);
limitForce = ((-(step.inv_dt) * m_motorMass) * limitCdot);
if (m_limitState == e_equalLimits){
m_limitForce = (m_limitForce + limitForce);
} else {
if (m_limitState == e_atLowerLimit){
oldLimitForce = m_limitForce;
m_limitForce = b2Math.b2Max((m_limitForce + limitForce), 0);
limitForce = (m_limitForce - oldLimitForce);
} else {
if (m_limitState == e_atUpperLimit){
oldLimitForce = m_limitForce;
m_limitForce = b2Math.b2Min((m_limitForce + limitForce), 0);
limitForce = (m_limitForce - oldLimitForce);
};
};
};
P = (step.dt * limitForce);
b1.m_linearVelocity.x = (b1.m_linearVelocity.x + ((invMass1 * P) * m_motorJacobian.linear1.x));
b1.m_linearVelocity.y = (b1.m_linearVelocity.y + ((invMass1 * P) * m_motorJacobian.linear1.y));
b1.m_angularVelocity = (b1.m_angularVelocity + ((invI1 * P) * m_motorJacobian.angular1));
b2.m_linearVelocity.x = (b2.m_linearVelocity.x + ((invMass2 * P) * m_motorJacobian.linear2.x));
b2.m_linearVelocity.y = (b2.m_linearVelocity.y + ((invMass2 * P) * m_motorJacobian.linear2.y));
b2.m_angularVelocity = (b2.m_angularVelocity + ((invI2 * P) * m_motorJacobian.angular2));
};
}
override public function SolvePositionConstraints():Boolean{
var limitC:Number;
var oldLimitImpulse:Number;
var tMat:b2Mat22;
var tX:Number;
var ax1X:Number;
var ax1Y:Number;
var translation:Number;
var limitImpulse:Number;
var b1:b2Body = m_body1;
var b2:b2Body = m_body2;
var invMass1:Number = b1.m_invMass;
var invMass2:Number = b2.m_invMass;
var invI1:Number = b1.m_invI;
var invI2:Number = b2.m_invI;
tMat = b1.m_xf.R;
var r1X:Number = (m_localAnchor1.x - b1.m_sweep.localCenter.x);
var r1Y:Number = (m_localAnchor1.y - b1.m_sweep.localCenter.y);
tX = ((tMat.col1.x * r1X) + (tMat.col2.x * r1Y));
r1Y = ((tMat.col1.y * r1X) + (tMat.col2.y * r1Y));
r1X = tX;
tMat = b2.m_xf.R;
var r2X:Number = (m_localAnchor2.x - b2.m_sweep.localCenter.x);
var r2Y:Number = (m_localAnchor2.y - b2.m_sweep.localCenter.y);
tX = ((tMat.col1.x * r2X) + (tMat.col2.x * r2Y));
r2Y = ((tMat.col1.y * r2X) + (tMat.col2.y * r2Y));
r2X = tX;
var p1X:Number = (b1.m_sweep.c.x + r1X);
var p1Y:Number = (b1.m_sweep.c.y + r1Y);
var p2X:Number = (b2.m_sweep.c.x + r2X);
var p2Y:Number = (b2.m_sweep.c.y + r2Y);
var dX:Number = (p2X - p1X);
var dY:Number = (p2Y - p1Y);
tMat = b1.m_xf.R;
var ay1X:Number = ((tMat.col1.x * m_localYAxis1.x) + (tMat.col2.x * m_localYAxis1.y));
var ay1Y:Number = ((tMat.col1.y * m_localYAxis1.x) + (tMat.col2.y * m_localYAxis1.y));
var linearC:Number = ((ay1X * dX) + (ay1Y * dY));
linearC = b2Math.b2Clamp(linearC, -(b2Settings.b2_maxLinearCorrection), b2Settings.b2_maxLinearCorrection);
var linearImpulse:Number = (-(m_linearMass) * linearC);
b1.m_sweep.c.x = (b1.m_sweep.c.x + ((invMass1 * linearImpulse) * m_linearJacobian.linear1.x));
b1.m_sweep.c.y = (b1.m_sweep.c.y + ((invMass1 * linearImpulse) * m_linearJacobian.linear1.y));
b1.m_sweep.a = (b1.m_sweep.a + ((invI1 * linearImpulse) * m_linearJacobian.angular1));
b2.m_sweep.c.x = (b2.m_sweep.c.x + ((invMass2 * linearImpulse) * m_linearJacobian.linear2.x));
b2.m_sweep.c.y = (b2.m_sweep.c.y + ((invMass2 * linearImpulse) * m_linearJacobian.linear2.y));
b2.m_sweep.a = (b2.m_sweep.a + ((invI2 * linearImpulse) * m_linearJacobian.angular2));
var positionError:Number = b2Math.b2Abs(linearC);
var angularC:Number = ((b2.m_sweep.a - b1.m_sweep.a) - m_refAngle);
angularC = b2Math.b2Clamp(angularC, -(b2Settings.b2_maxAngularCorrection), b2Settings.b2_maxAngularCorrection);
var angularImpulse:Number = (-(m_angularMass) * angularC);
b1.m_sweep.a = (b1.m_sweep.a - (b1.m_invI * angularImpulse));
b2.m_sweep.a = (b2.m_sweep.a + (b2.m_invI * angularImpulse));
b1.SynchronizeTransform();
b2.SynchronizeTransform();
var angularError:Number = b2Math.b2Abs(angularC);
if (((m_enableLimit) && (!((m_limitState == e_inactiveLimit))))){
tMat = b1.m_xf.R;
r1X = (m_localAnchor1.x - b1.m_sweep.localCenter.x);
r1Y = (m_localAnchor1.y - b1.m_sweep.localCenter.y);
tX = ((tMat.col1.x * r1X) + (tMat.col2.x * r1Y));
r1Y = ((tMat.col1.y * r1X) + (tMat.col2.y * r1Y));
r1X = tX;
tMat = b2.m_xf.R;
r2X = (m_localAnchor2.x - b2.m_sweep.localCenter.x);
r2Y = (m_localAnchor2.y - b2.m_sweep.localCenter.y);
tX = ((tMat.col1.x * r2X) + (tMat.col2.x * r2Y));
r2Y = ((tMat.col1.y * r2X) + (tMat.col2.y * r2Y));
r2X = tX;
p1X = (b1.m_sweep.c.x + r1X);
p1Y = (b1.m_sweep.c.y + r1Y);
p2X = (b2.m_sweep.c.x + r2X);
p2Y = (b2.m_sweep.c.y + r2Y);
dX = (p2X - p1X);
dY = (p2Y - p1Y);
tMat = b1.m_xf.R;
ax1X = ((tMat.col1.x * m_localXAxis1.x) + (tMat.col2.x * m_localXAxis1.y));
ax1Y = ((tMat.col1.y * m_localXAxis1.x) + (tMat.col2.y * m_localXAxis1.y));
translation = ((ax1X * dX) + (ax1Y * dY));
limitImpulse = 0;
if (m_limitState == e_equalLimits){
limitC = b2Math.b2Clamp(translation, -(b2Settings.b2_maxLinearCorrection), b2Settings.b2_maxLinearCorrection);
limitImpulse = (-(m_motorMass) * limitC);
positionError = b2Math.b2Max(positionError, b2Math.b2Abs(angularC));
} else {
if (m_limitState == e_atLowerLimit){
limitC = (translation - m_lowerTranslation);
positionError = b2Math.b2Max(positionError, -(limitC));
limitC = b2Math.b2Clamp((limitC + b2Settings.b2_linearSlop), -(b2Settings.b2_maxLinearCorrection), 0);
limitImpulse = (-(m_motorMass) * limitC);
oldLimitImpulse = m_limitPositionImpulse;
m_limitPositionImpulse = b2Math.b2Max((m_limitPositionImpulse + limitImpulse), 0);
limitImpulse = (m_limitPositionImpulse - oldLimitImpulse);
} else {
if (m_limitState == e_atUpperLimit){
limitC = (translation - m_upperTranslation);
positionError = b2Math.b2Max(positionError, limitC);
limitC = b2Math.b2Clamp((limitC - b2Settings.b2_linearSlop), 0, b2Settings.b2_maxLinearCorrection);
limitImpulse = (-(m_motorMass) * limitC);
oldLimitImpulse = m_limitPositionImpulse;
m_limitPositionImpulse = b2Math.b2Min((m_limitPositionImpulse + limitImpulse), 0);
limitImpulse = (m_limitPositionImpulse - oldLimitImpulse);
};
};
};
b1.m_sweep.c.x = (b1.m_sweep.c.x + ((invMass1 * limitImpulse) * m_motorJacobian.linear1.x));
b1.m_sweep.c.y = (b1.m_sweep.c.y + ((invMass1 * limitImpulse) * m_motorJacobian.linear1.y));
b1.m_sweep.a = (b1.m_sweep.a + ((invI1 * limitImpulse) * m_motorJacobian.angular1));
b2.m_sweep.c.x = (b2.m_sweep.c.x + ((invMass2 * limitImpulse) * m_motorJacobian.linear2.x));
b2.m_sweep.c.y = (b2.m_sweep.c.y + ((invMass2 * limitImpulse) * m_motorJacobian.linear2.y));
b2.m_sweep.a = (b2.m_sweep.a + ((invI2 * limitImpulse) * m_motorJacobian.angular2));
b1.SynchronizeTransform();
b2.SynchronizeTransform();
};
return ((((positionError <= b2Settings.b2_linearSlop)) && ((angularError <= b2Settings.b2_angularSlop))));
}
}
}//package Box2D.Dynamics.Joints
Section 60
//b2PrismaticJointDef (Box2D.Dynamics.Joints.b2PrismaticJointDef)
package Box2D.Dynamics.Joints {
import Box2D.Common.Math.*;
import Box2D.Dynamics.*;
public class b2PrismaticJointDef extends b2JointDef {
public var localAnchor1:b2Vec2;
public var localAnchor2:b2Vec2;
public var localAxis1:b2Vec2;
public var referenceAngle:Number;
public var enableLimit:Boolean;
public var lowerTranslation:Number;
public var upperTranslation:Number;
public var enableMotor:Boolean;
public var maxMotorForce:Number;
public var motorSpeed:Number;
public function b2PrismaticJointDef(){
localAnchor1 = new b2Vec2();
localAnchor2 = new b2Vec2();
localAxis1 = new b2Vec2();
super();
type = b2Joint.e_prismaticJoint;
localAxis1.Set(1, 0);
referenceAngle = 0;
enableLimit = false;
lowerTranslation = 0;
upperTranslation = 0;
enableMotor = false;
maxMotorForce = 0;
motorSpeed = 0;
}
public function Initialize(b1:b2Body, b2:b2Body, anchor:b2Vec2, axis:b2Vec2):void{
body1 = b1;
body2 = b2;
localAnchor1 = body1.GetLocalPoint(anchor);
localAnchor2 = body2.GetLocalPoint(anchor);
localAxis1 = body1.GetLocalVector(axis);
referenceAngle = (body2.GetAngle() - body1.GetAngle());
}
}
}//package Box2D.Dynamics.Joints
Section 61
//b2PulleyJoint (Box2D.Dynamics.Joints.b2PulleyJoint)
package Box2D.Dynamics.Joints {
import Box2D.Common.Math.*;
import Box2D.Dynamics.*;
import Box2D.Common.*;
public class b2PulleyJoint extends b2Joint {
public var m_ground:b2Body;
public var m_groundAnchor1:b2Vec2;
public var m_groundAnchor2:b2Vec2;
public var m_localAnchor1:b2Vec2;
public var m_localAnchor2:b2Vec2;
public var m_u1:b2Vec2;
public var m_u2:b2Vec2;
public var m_constant:Number;
public var m_ratio:Number;
public var m_maxLength1:Number;
public var m_maxLength2:Number;
public var m_pulleyMass:Number;
public var m_limitMass1:Number;
public var m_limitMass2:Number;
public var m_force:Number;
public var m_limitForce1:Number;
public var m_limitForce2:Number;
public var m_positionImpulse:Number;
public var m_limitPositionImpulse1:Number;
public var m_limitPositionImpulse2:Number;
public var m_state:int;
public var m_limitState1:int;
public var m_limitState2:int;
public static const b2_minPulleyLength:Number = 2;
public function b2PulleyJoint(def:b2PulleyJointDef){
var tMat:b2Mat22;
var tX:Number;
var tY:Number;
m_groundAnchor1 = new b2Vec2();
m_groundAnchor2 = new b2Vec2();
m_localAnchor1 = new b2Vec2();
m_localAnchor2 = new b2Vec2();
m_u1 = new b2Vec2();
m_u2 = new b2Vec2();
super(def);
m_ground = m_body1.m_world.m_groundBody;
m_groundAnchor1.x = (def.groundAnchor1.x - m_ground.m_xf.position.x);
m_groundAnchor1.y = (def.groundAnchor1.y - m_ground.m_xf.position.y);
m_groundAnchor2.x = (def.groundAnchor2.x - m_ground.m_xf.position.x);
m_groundAnchor2.y = (def.groundAnchor2.y - m_ground.m_xf.position.y);
m_localAnchor1.SetV(def.localAnchor1);
m_localAnchor2.SetV(def.localAnchor2);
m_ratio = def.ratio;
m_constant = (def.length1 + (m_ratio * def.length2));
m_maxLength1 = b2Math.b2Min(def.maxLength1, (m_constant - (m_ratio * b2_minPulleyLength)));
m_maxLength2 = b2Math.b2Min(def.maxLength2, ((m_constant - b2_minPulleyLength) / m_ratio));
m_force = 0;
m_limitForce1 = 0;
m_limitForce2 = 0;
}
override public function GetAnchor1():b2Vec2{
return (m_body1.GetWorldPoint(m_localAnchor1));
}
override public function GetAnchor2():b2Vec2{
return (m_body2.GetWorldPoint(m_localAnchor2));
}
override public function GetReactionForce():b2Vec2{
var F:b2Vec2 = m_u2.Copy();
F.Multiply(m_force);
return (F);
}
override public function GetReactionTorque():Number{
return (0);
}
public function GetGroundAnchor1():b2Vec2{
var a:b2Vec2 = m_ground.m_xf.position.Copy();
a.Add(m_groundAnchor1);
return (a);
}
public function GetGroundAnchor2():b2Vec2{
var a:b2Vec2 = m_ground.m_xf.position.Copy();
a.Add(m_groundAnchor2);
return (a);
}
public function GetLength1():Number{
var p:b2Vec2 = m_body1.GetWorldPoint(m_localAnchor1);
var sX:Number = (m_ground.m_xf.position.x + m_groundAnchor1.x);
var sY:Number = (m_ground.m_xf.position.y + m_groundAnchor1.y);
var dX:Number = (p.x - sX);
var dY:Number = (p.y - sY);
return (Math.sqrt(((dX * dX) + (dY * dY))));
}
public function GetLength2():Number{
var p:b2Vec2 = m_body2.GetWorldPoint(m_localAnchor2);
var sX:Number = (m_ground.m_xf.position.x + m_groundAnchor2.x);
var sY:Number = (m_ground.m_xf.position.y + m_groundAnchor2.y);
var dX:Number = (p.x - sX);
var dY:Number = (p.y - sY);
return (Math.sqrt(((dX * dX) + (dY * dY))));
}
public function GetRatio():Number{
return (m_ratio);
}
override public function InitVelocityConstraints(step:b2TimeStep):void{
var tMat:b2Mat22;
var P1X:Number;
var P1Y:Number;
var P2X:Number;
var P2Y:Number;
var b1:b2Body = m_body1;
var b2:b2Body = m_body2;
tMat = b1.m_xf.R;
var r1X:Number = (m_localAnchor1.x - b1.m_sweep.localCenter.x);
var r1Y:Number = (m_localAnchor1.y - b1.m_sweep.localCenter.y);
var tX:Number = ((tMat.col1.x * r1X) + (tMat.col2.x * r1Y));
r1Y = ((tMat.col1.y * r1X) + (tMat.col2.y * r1Y));
r1X = tX;
tMat = b2.m_xf.R;
var r2X:Number = (m_localAnchor2.x - b2.m_sweep.localCenter.x);
var r2Y:Number = (m_localAnchor2.y - b2.m_sweep.localCenter.y);
tX = ((tMat.col1.x * r2X) + (tMat.col2.x * r2Y));
r2Y = ((tMat.col1.y * r2X) + (tMat.col2.y * r2Y));
r2X = tX;
var p1X:Number = (b1.m_sweep.c.x + r1X);
var p1Y:Number = (b1.m_sweep.c.y + r1Y);
var p2X:Number = (b2.m_sweep.c.x + r2X);
var p2Y:Number = (b2.m_sweep.c.y + r2Y);
var s1X:Number = (m_ground.m_xf.position.x + m_groundAnchor1.x);
var s1Y:Number = (m_ground.m_xf.position.y + m_groundAnchor1.y);
var s2X:Number = (m_ground.m_xf.position.x + m_groundAnchor2.x);
var s2Y:Number = (m_ground.m_xf.position.y + m_groundAnchor2.y);
m_u1.Set((p1X - s1X), (p1Y - s1Y));
m_u2.Set((p2X - s2X), (p2Y - s2Y));
var length1:Number = m_u1.Length();
var length2:Number = m_u2.Length();
if (length1 > b2Settings.b2_linearSlop){
m_u1.Multiply((1 / length1));
} else {
m_u1.SetZero();
};
if (length2 > b2Settings.b2_linearSlop){
m_u2.Multiply((1 / length2));
} else {
m_u2.SetZero();
};
var C:Number = ((m_constant - length1) - (m_ratio * length2));
if (C > 0){
m_state = e_inactiveLimit;
m_force = 0;
} else {
m_state = e_atUpperLimit;
m_positionImpulse = 0;
};
if (length1 < m_maxLength1){
m_limitState1 = e_inactiveLimit;
m_limitForce1 = 0;
} else {
m_limitState1 = e_atUpperLimit;
m_limitPositionImpulse1 = 0;
};
if (length2 < m_maxLength2){
m_limitState2 = e_inactiveLimit;
m_limitForce2 = 0;
} else {
m_limitState2 = e_atUpperLimit;
m_limitPositionImpulse2 = 0;
};
var cr1u1:Number = ((r1X * m_u1.y) - (r1Y * m_u1.x));
var cr2u2:Number = ((r2X * m_u2.y) - (r2Y * m_u2.x));
m_limitMass1 = (b1.m_invMass + ((b1.m_invI * cr1u1) * cr1u1));
m_limitMass2 = (b2.m_invMass + ((b2.m_invI * cr2u2) * cr2u2));
m_pulleyMass = (m_limitMass1 + ((m_ratio * m_ratio) * m_limitMass2));
m_limitMass1 = (1 / m_limitMass1);
m_limitMass2 = (1 / m_limitMass2);
m_pulleyMass = (1 / m_pulleyMass);
if (step.warmStarting){
P1X = ((step.dt * (-(m_force) - m_limitForce1)) * m_u1.x);
P1Y = ((step.dt * (-(m_force) - m_limitForce1)) * m_u1.y);
P2X = ((step.dt * ((-(m_ratio) * m_force) - m_limitForce2)) * m_u2.x);
P2Y = ((step.dt * ((-(m_ratio) * m_force) - m_limitForce2)) * m_u2.y);
b1.m_linearVelocity.x = (b1.m_linearVelocity.x + (b1.m_invMass * P1X));
b1.m_linearVelocity.y = (b1.m_linearVelocity.y + (b1.m_invMass * P1Y));
b1.m_angularVelocity = (b1.m_angularVelocity + (b1.m_invI * ((r1X * P1Y) - (r1Y * P1X))));
b2.m_linearVelocity.x = (b2.m_linearVelocity.x + (b2.m_invMass * P2X));
b2.m_linearVelocity.y = (b2.m_linearVelocity.y + (b2.m_invMass * P2Y));
b2.m_angularVelocity = (b2.m_angularVelocity + (b2.m_invI * ((r2X * P2Y) - (r2Y * P2X))));
} else {
m_force = 0;
m_limitForce1 = 0;
m_limitForce2 = 0;
};
}
override public function SolveVelocityConstraints(step:b2TimeStep):void{
var tMat:b2Mat22;
var v1X:Number;
var v1Y:Number;
var v2X:Number;
var v2Y:Number;
var P1X:Number;
var P1Y:Number;
var P2X:Number;
var P2Y:Number;
var Cdot:Number;
var force:Number;
var oldForce:Number;
var b1:b2Body = m_body1;
var b2:b2Body = m_body2;
tMat = b1.m_xf.R;
var r1X:Number = (m_localAnchor1.x - b1.m_sweep.localCenter.x);
var r1Y:Number = (m_localAnchor1.y - b1.m_sweep.localCenter.y);
var tX:Number = ((tMat.col1.x * r1X) + (tMat.col2.x * r1Y));
r1Y = ((tMat.col1.y * r1X) + (tMat.col2.y * r1Y));
r1X = tX;
tMat = b2.m_xf.R;
var r2X:Number = (m_localAnchor2.x - b2.m_sweep.localCenter.x);
var r2Y:Number = (m_localAnchor2.y - b2.m_sweep.localCenter.y);
tX = ((tMat.col1.x * r2X) + (tMat.col2.x * r2Y));
r2Y = ((tMat.col1.y * r2X) + (tMat.col2.y * r2Y));
r2X = tX;
if (m_state == e_atUpperLimit){
v1X = (b1.m_linearVelocity.x + (-(b1.m_angularVelocity) * r1Y));
v1Y = (b1.m_linearVelocity.y + (b1.m_angularVelocity * r1X));
v2X = (b2.m_linearVelocity.x + (-(b2.m_angularVelocity) * r2Y));
v2Y = (b2.m_linearVelocity.y + (b2.m_angularVelocity * r2X));
Cdot = (-(((m_u1.x * v1X) + (m_u1.y * v1Y))) - (m_ratio * ((m_u2.x * v2X) + (m_u2.y * v2Y))));
force = ((-(step.inv_dt) * m_pulleyMass) * Cdot);
oldForce = m_force;
m_force = b2Math.b2Max(0, (m_force + force));
force = (m_force - oldForce);
P1X = ((-(step.dt) * force) * m_u1.x);
P1Y = ((-(step.dt) * force) * m_u1.y);
P2X = (((-(step.dt) * m_ratio) * force) * m_u2.x);
P2Y = (((-(step.dt) * m_ratio) * force) * m_u2.y);
b1.m_linearVelocity.x = (b1.m_linearVelocity.x + (b1.m_invMass * P1X));
b1.m_linearVelocity.y = (b1.m_linearVelocity.y + (b1.m_invMass * P1Y));
b1.m_angularVelocity = (b1.m_angularVelocity + (b1.m_invI * ((r1X * P1Y) - (r1Y * P1X))));
b2.m_linearVelocity.x = (b2.m_linearVelocity.x + (b2.m_invMass * P2X));
b2.m_linearVelocity.y = (b2.m_linearVelocity.y + (b2.m_invMass * P2Y));
b2.m_angularVelocity = (b2.m_angularVelocity + (b2.m_invI * ((r2X * P2Y) - (r2Y * P2X))));
};
if (m_limitState1 == e_atUpperLimit){
v1X = (b1.m_linearVelocity.x + (-(b1.m_angularVelocity) * r1Y));
v1Y = (b1.m_linearVelocity.y + (b1.m_angularVelocity * r1X));
Cdot = -(((m_u1.x * v1X) + (m_u1.y * v1Y)));
force = ((-(step.inv_dt) * m_limitMass1) * Cdot);
oldForce = m_limitForce1;
m_limitForce1 = b2Math.b2Max(0, (m_limitForce1 + force));
force = (m_limitForce1 - oldForce);
P1X = ((-(step.dt) * force) * m_u1.x);
P1Y = ((-(step.dt) * force) * m_u1.y);
b1.m_linearVelocity.x = (b1.m_linearVelocity.x + (b1.m_invMass * P1X));
b1.m_linearVelocity.y = (b1.m_linearVelocity.y + (b1.m_invMass * P1Y));
b1.m_angularVelocity = (b1.m_angularVelocity + (b1.m_invI * ((r1X * P1Y) - (r1Y * P1X))));
};
if (m_limitState2 == e_atUpperLimit){
v2X = (b2.m_linearVelocity.x + (-(b2.m_angularVelocity) * r2Y));
v2Y = (b2.m_linearVelocity.y + (b2.m_angularVelocity * r2X));
Cdot = -(((m_u2.x * v2X) + (m_u2.y * v2Y)));
force = ((-(step.inv_dt) * m_limitMass2) * Cdot);
oldForce = m_limitForce2;
m_limitForce2 = b2Math.b2Max(0, (m_limitForce2 + force));
force = (m_limitForce2 - oldForce);
P2X = ((-(step.dt) * force) * m_u2.x);
P2Y = ((-(step.dt) * force) * m_u2.y);
b2.m_linearVelocity.x = (b2.m_linearVelocity.x + (b2.m_invMass * P2X));
b2.m_linearVelocity.y = (b2.m_linearVelocity.y + (b2.m_invMass * P2Y));
b2.m_angularVelocity = (b2.m_angularVelocity + (b2.m_invI * ((r2X * P2Y) - (r2Y * P2X))));
};
}
override public function SolvePositionConstraints():Boolean{
var tMat:b2Mat22;
var r1X:Number;
var r1Y:Number;
var r2X:Number;
var r2Y:Number;
var p1X:Number;
var p1Y:Number;
var p2X:Number;
var p2Y:Number;
var length1:Number;
var length2:Number;
var C:Number;
var impulse:Number;
var oldImpulse:Number;
var oldLimitPositionImpulse:Number;
var tX:Number;
var b1:b2Body = m_body1;
var b2:b2Body = m_body2;
var s1X:Number = (m_ground.m_xf.position.x + m_groundAnchor1.x);
var s1Y:Number = (m_ground.m_xf.position.y + m_groundAnchor1.y);
var s2X:Number = (m_ground.m_xf.position.x + m_groundAnchor2.x);
var s2Y:Number = (m_ground.m_xf.position.y + m_groundAnchor2.y);
var linearError:Number = 0;
if (m_state == e_atUpperLimit){
tMat = b1.m_xf.R;
r1X = (m_localAnchor1.x - b1.m_sweep.localCenter.x);
r1Y = (m_localAnchor1.y - b1.m_sweep.localCenter.y);
tX = ((tMat.col1.x * r1X) + (tMat.col2.x * r1Y));
r1Y = ((tMat.col1.y * r1X) + (tMat.col2.y * r1Y));
r1X = tX;
tMat = b2.m_xf.R;
r2X = (m_localAnchor2.x - b2.m_sweep.localCenter.x);
r2Y = (m_localAnchor2.y - b2.m_sweep.localCenter.y);
tX = ((tMat.col1.x * r2X) + (tMat.col2.x * r2Y));
r2Y = ((tMat.col1.y * r2X) + (tMat.col2.y * r2Y));
r2X = tX;
p1X = (b1.m_sweep.c.x + r1X);
p1Y = (b1.m_sweep.c.y + r1Y);
p2X = (b2.m_sweep.c.x + r2X);
p2Y = (b2.m_sweep.c.y + r2Y);
m_u1.Set((p1X - s1X), (p1Y - s1Y));
m_u2.Set((p2X - s2X), (p2Y - s2Y));
length1 = m_u1.Length();
length2 = m_u2.Length();
if (length1 > b2Settings.b2_linearSlop){
m_u1.Multiply((1 / length1));
} else {
m_u1.SetZero();
};
if (length2 > b2Settings.b2_linearSlop){
m_u2.Multiply((1 / length2));
} else {
m_u2.SetZero();
};
C = ((m_constant - length1) - (m_ratio * length2));
linearError = b2Math.b2Max(linearError, -(C));
C = b2Math.b2Clamp((C + b2Settings.b2_linearSlop), -(b2Settings.b2_maxLinearCorrection), 0);
impulse = (-(m_pulleyMass) * C);
oldImpulse = m_positionImpulse;
m_positionImpulse = b2Math.b2Max(0, (m_positionImpulse + impulse));
impulse = (m_positionImpulse - oldImpulse);
p1X = (-(impulse) * m_u1.x);
p1Y = (-(impulse) * m_u1.y);
p2X = ((-(m_ratio) * impulse) * m_u2.x);
p2Y = ((-(m_ratio) * impulse) * m_u2.y);
b1.m_sweep.c.x = (b1.m_sweep.c.x + (b1.m_invMass * p1X));
b1.m_sweep.c.y = (b1.m_sweep.c.y + (b1.m_invMass * p1Y));
b1.m_sweep.a = (b1.m_sweep.a + (b1.m_invI * ((r1X * p1Y) - (r1Y * p1X))));
b2.m_sweep.c.x = (b2.m_sweep.c.x + (b2.m_invMass * p2X));
b2.m_sweep.c.y = (b2.m_sweep.c.y + (b2.m_invMass * p2Y));
b2.m_sweep.a = (b2.m_sweep.a + (b2.m_invI * ((r2X * p2Y) - (r2Y * p2X))));
b1.SynchronizeTransform();
b2.SynchronizeTransform();
};
if (m_limitState1 == e_atUpperLimit){
tMat = b1.m_xf.R;
r1X = (m_localAnchor1.x - b1.m_sweep.localCenter.x);
r1Y = (m_localAnchor1.y - b1.m_sweep.localCenter.y);
tX = ((tMat.col1.x * r1X) + (tMat.col2.x * r1Y));
r1Y = ((tMat.col1.y * r1X) + (tMat.col2.y * r1Y));
r1X = tX;
p1X = (b1.m_sweep.c.x + r1X);
p1Y = (b1.m_sweep.c.y + r1Y);
m_u1.Set((p1X - s1X), (p1Y - s1Y));
length1 = m_u1.Length();
if (length1 > b2Settings.b2_linearSlop){
m_u1.x = (m_u1.x * (1 / length1));
m_u1.y = (m_u1.y * (1 / length1));
} else {
m_u1.SetZero();
};
C = (m_maxLength1 - length1);
linearError = b2Math.b2Max(linearError, -(C));
C = b2Math.b2Clamp((C + b2Settings.b2_linearSlop), -(b2Settings.b2_maxLinearCorrection), 0);
impulse = (-(m_limitMass1) * C);
oldLimitPositionImpulse = m_limitPositionImpulse1;
m_limitPositionImpulse1 = b2Math.b2Max(0, (m_limitPositionImpulse1 + impulse));
impulse = (m_limitPositionImpulse1 - oldLimitPositionImpulse);
p1X = (-(impulse) * m_u1.x);
p1Y = (-(impulse) * m_u1.y);
b1.m_sweep.c.x = (b1.m_sweep.c.x + (b1.m_invMass * p1X));
b1.m_sweep.c.y = (b1.m_sweep.c.y + (b1.m_invMass * p1Y));
b1.m_sweep.a = (b1.m_sweep.a + (b1.m_invI * ((r1X * p1Y) - (r1Y * p1X))));
b1.SynchronizeTransform();
};
if (m_limitState2 == e_atUpperLimit){
tMat = b2.m_xf.R;
r2X = (m_localAnchor2.x - b2.m_sweep.localCenter.x);
r2Y = (m_localAnchor2.y - b2.m_sweep.localCenter.y);
tX = ((tMat.col1.x * r2X) + (tMat.col2.x * r2Y));
r2Y = ((tMat.col1.y * r2X) + (tMat.col2.y * r2Y));
r2X = tX;
p2X = (b2.m_sweep.c.x + r2X);
p2Y = (b2.m_sweep.c.y + r2Y);
m_u2.Set((p2X - s2X), (p2Y - s2Y));
length2 = m_u2.Length();
if (length2 > b2Settings.b2_linearSlop){
m_u2.x = (m_u2.x * (1 / length2));
m_u2.y = (m_u2.y * (1 / length2));
} else {
m_u2.SetZero();
};
C = (m_maxLength2 - length2);
linearError = b2Math.b2Max(linearError, -(C));
C = b2Math.b2Clamp((C + b2Settings.b2_linearSlop), -(b2Settings.b2_maxLinearCorrection), 0);
impulse = (-(m_limitMass2) * C);
oldLimitPositionImpulse = m_limitPositionImpulse2;
m_limitPositionImpulse2 = b2Math.b2Max(0, (m_limitPositionImpulse2 + impulse));
impulse = (m_limitPositionImpulse2 - oldLimitPositionImpulse);
p2X = (-(impulse) * m_u2.x);
p2Y = (-(impulse) * m_u2.y);
b2.m_sweep.c.x = (b2.m_sweep.c.x + (b2.m_invMass * p2X));
b2.m_sweep.c.y = (b2.m_sweep.c.y + (b2.m_invMass * p2Y));
b2.m_sweep.a = (b2.m_sweep.a + (b2.m_invI * ((r2X * p2Y) - (r2Y * p2X))));
b2.SynchronizeTransform();
};
return ((linearError < b2Settings.b2_linearSlop));
}
}
}//package Box2D.Dynamics.Joints
Section 62
//b2PulleyJointDef (Box2D.Dynamics.Joints.b2PulleyJointDef)
package Box2D.Dynamics.Joints {
import Box2D.Common.Math.*;
import Box2D.Dynamics.*;
public class b2PulleyJointDef extends b2JointDef {
public var groundAnchor1:b2Vec2;
public var groundAnchor2:b2Vec2;
public var localAnchor1:b2Vec2;
public var localAnchor2:b2Vec2;
public var length1:Number;
public var maxLength1:Number;
public var length2:Number;
public var maxLength2:Number;
public var ratio:Number;
public function b2PulleyJointDef(){
groundAnchor1 = new b2Vec2();
groundAnchor2 = new b2Vec2();
localAnchor1 = new b2Vec2();
localAnchor2 = new b2Vec2();
super();
type = b2Joint.e_pulleyJoint;
groundAnchor1.Set(-1, 1);
groundAnchor2.Set(1, 1);
localAnchor1.Set(-1, 0);
localAnchor2.Set(1, 0);
length1 = 0;
maxLength1 = 0;
length2 = 0;
maxLength2 = 0;
ratio = 1;
collideConnected = true;
}
public function Initialize(b1:b2Body, b2:b2Body, ga1:b2Vec2, ga2:b2Vec2, anchor1:b2Vec2, anchor2:b2Vec2, r:Number):void{
body1 = b1;
body2 = b2;
groundAnchor1.SetV(ga1);
groundAnchor2.SetV(ga2);
localAnchor1 = body1.GetLocalPoint(anchor1);
localAnchor2 = body2.GetLocalPoint(anchor2);
var d1X:Number = (anchor1.x - ga1.x);
var d1Y:Number = (anchor1.y - ga1.y);
length1 = Math.sqrt(((d1X * d1X) + (d1Y * d1Y)));
var d2X:Number = (anchor2.x - ga2.x);
var d2Y:Number = (anchor2.y - ga2.y);
length2 = Math.sqrt(((d2X * d2X) + (d2Y * d2Y)));
ratio = r;
var C:Number = (length1 + (ratio * length2));
maxLength1 = (C - (ratio * b2PulleyJoint.b2_minPulleyLength));
maxLength2 = ((C - b2PulleyJoint.b2_minPulleyLength) / ratio);
}
}
}//package Box2D.Dynamics.Joints
Section 63
//b2RevoluteJoint (Box2D.Dynamics.Joints.b2RevoluteJoint)
package Box2D.Dynamics.Joints {
import Box2D.Common.Math.*;
import Box2D.Dynamics.*;
import Box2D.Common.*;
public class b2RevoluteJoint extends b2Joint {
private var K:b2Mat22;
private var K1:b2Mat22;
private var K2:b2Mat22;
private var K3:b2Mat22;
public var m_localAnchor1:b2Vec2;
public var m_localAnchor2:b2Vec2;
public var m_pivotForce:b2Vec2;
public var m_motorForce:Number;
public var m_limitForce:Number;
public var m_limitPositionImpulse:Number;
public var m_pivotMass:b2Mat22;
public var m_motorMass:Number;
public var m_enableMotor:Boolean;
public var m_maxMotorTorque:Number;
public var m_motorSpeed:Number;
public var m_enableLimit:Boolean;
public var m_referenceAngle:Number;
public var m_lowerAngle:Number;
public var m_upperAngle:Number;
public var m_limitState:int;
public static var tImpulse:b2Vec2 = new b2Vec2();
public function b2RevoluteJoint(def:b2RevoluteJointDef){
K = new b2Mat22();
K1 = new b2Mat22();
K2 = new b2Mat22();
K3 = new b2Mat22();
m_localAnchor1 = new b2Vec2();
m_localAnchor2 = new b2Vec2();
m_pivotForce = new b2Vec2();
m_pivotMass = new b2Mat22();
super(def);
m_localAnchor1.SetV(def.localAnchor1);
m_localAnchor2.SetV(def.localAnchor2);
m_referenceAngle = def.referenceAngle;
m_pivotForce.Set(0, 0);
m_motorForce = 0;
m_limitForce = 0;
m_limitPositionImpulse = 0;
m_lowerAngle = def.lowerAngle;
m_upperAngle = def.upperAngle;
m_maxMotorTorque = def.maxMotorTorque;
m_motorSpeed = def.motorSpeed;
m_enableLimit = def.enableLimit;
m_enableMotor = def.enableMotor;
}
override public function GetAnchor1():b2Vec2{
return (m_body1.GetWorldPoint(m_localAnchor1));
}
override public function GetAnchor2():b2Vec2{
return (m_body2.GetWorldPoint(m_localAnchor2));
}
override public function GetReactionForce():b2Vec2{
return (m_pivotForce);
}
override public function GetReactionTorque():Number{
return (m_limitForce);
}
public function GetJointAngle():Number{
return (((m_body2.m_sweep.a - m_body1.m_sweep.a) - m_referenceAngle));
}
public function GetJointSpeed():Number{
return ((m_body2.m_angularVelocity - m_body1.m_angularVelocity));
}
public function IsLimitEnabled():Boolean{
return (m_enableLimit);
}
public function EnableLimit(flag:Boolean):void{
m_enableLimit = flag;
}
public function GetLowerLimit():Number{
return (m_lowerAngle);
}
public function GetUpperLimit():Number{
return (m_upperAngle);
}
public function SetLimits(lower:Number, upper:Number):void{
m_lowerAngle = lower;
m_upperAngle = upper;
}
public function IsMotorEnabled():Boolean{
return (m_enableMotor);
}
public function EnableMotor(flag:Boolean):void{
m_enableMotor = flag;
}
public function SetMotorSpeed(speed:Number):void{
m_motorSpeed = speed;
}
public function GetMotorSpeed():Number{
return (m_motorSpeed);
}
public function SetMaxMotorTorque(torque:Number):void{
m_maxMotorTorque = torque;
}
public function GetMotorTorque():Number{
return (m_motorForce);
}
override public function InitVelocityConstraints(step:b2TimeStep):void{
var b1:b2Body;
var b2:b2Body;
var tMat:b2Mat22;
var tX:Number;
var r1Y:Number;
var jointAngle:Number;
b1 = m_body1;
b2 = m_body2;
tMat = b1.m_xf.R;
var r1X:Number = (m_localAnchor1.x - b1.m_sweep.localCenter.x);
r1Y = (m_localAnchor1.y - b1.m_sweep.localCenter.y);
tX = ((tMat.col1.x * r1X) + (tMat.col2.x * r1Y));
r1Y = ((tMat.col1.y * r1X) + (tMat.col2.y * r1Y));
r1X = tX;
tMat = b2.m_xf.R;
var r2X:Number = (m_localAnchor2.x - b2.m_sweep.localCenter.x);
var r2Y:Number = (m_localAnchor2.y - b2.m_sweep.localCenter.y);
tX = ((tMat.col1.x * r2X) + (tMat.col2.x * r2Y));
r2Y = ((tMat.col1.y * r2X) + (tMat.col2.y * r2Y));
r2X = tX;
var invMass1:Number = b1.m_invMass;
var invMass2:Number = b2.m_invMass;
var invI1:Number = b1.m_invI;
var invI2:Number = b2.m_invI;
K1.col1.x = (invMass1 + invMass2);
K1.col2.x = 0;
K1.col1.y = 0;
K1.col2.y = (invMass1 + invMass2);
K2.col1.x = ((invI1 * r1Y) * r1Y);
K2.col2.x = ((-(invI1) * r1X) * r1Y);
K2.col1.y = ((-(invI1) * r1X) * r1Y);
K2.col2.y = ((invI1 * r1X) * r1X);
K3.col1.x = ((invI2 * r2Y) * r2Y);
K3.col2.x = ((-(invI2) * r2X) * r2Y);
K3.col1.y = ((-(invI2) * r2X) * r2Y);
K3.col2.y = ((invI2 * r2X) * r2X);
K.SetM(K1);
K.AddM(K2);
K.AddM(K3);
K.Invert(m_pivotMass);
m_motorMass = (1 / (invI1 + invI2));
if (m_enableMotor == false){
m_motorForce = 0;
};
if (m_enableLimit){
jointAngle = ((b2.m_sweep.a - b1.m_sweep.a) - m_referenceAngle);
if (b2Math.b2Abs((m_upperAngle - m_lowerAngle)) < (2 * b2Settings.b2_angularSlop)){
m_limitState = e_equalLimits;
} else {
if (jointAngle <= m_lowerAngle){
if (m_limitState != e_atLowerLimit){
m_limitForce = 0;
};
m_limitState = e_atLowerLimit;
} else {
if (jointAngle >= m_upperAngle){
if (m_limitState != e_atUpperLimit){
m_limitForce = 0;
};
m_limitState = e_atUpperLimit;
} else {
m_limitState = e_inactiveLimit;
m_limitForce = 0;
};
};
};
} else {
m_limitForce = 0;
};
if (step.warmStarting){
b1.m_linearVelocity.x = (b1.m_linearVelocity.x - ((step.dt * invMass1) * m_pivotForce.x));
b1.m_linearVelocity.y = (b1.m_linearVelocity.y - ((step.dt * invMass1) * m_pivotForce.y));
b1.m_angularVelocity = (b1.m_angularVelocity - ((step.dt * invI1) * ((((r1X * m_pivotForce.y) - (r1Y * m_pivotForce.x)) + m_motorForce) + m_limitForce)));
b2.m_linearVelocity.x = (b2.m_linearVelocity.x + ((step.dt * invMass2) * m_pivotForce.x));
b2.m_linearVelocity.y = (b2.m_linearVelocity.y + ((step.dt * invMass2) * m_pivotForce.y));
b2.m_angularVelocity = (b2.m_angularVelocity + ((step.dt * invI2) * ((((r2X * m_pivotForce.y) - (r2Y * m_pivotForce.x)) + m_motorForce) + m_limitForce)));
} else {
m_pivotForce.SetZero();
m_motorForce = 0;
m_limitForce = 0;
};
m_limitPositionImpulse = 0;
}
override public function SolveVelocityConstraints(step:b2TimeStep):void{
var tMat:b2Mat22;
var tX:Number;
var oldLimitForce:Number;
var PY:Number;
var motorCdot:Number;
var motorForce:Number;
var oldMotorForce:Number;
var limitCdot:Number;
var limitForce:Number;
var b1:b2Body = m_body1;
var b2:b2Body = m_body2;
tMat = b1.m_xf.R;
var r1X:Number = (m_localAnchor1.x - b1.m_sweep.localCenter.x);
var r1Y:Number = (m_localAnchor1.y - b1.m_sweep.localCenter.y);
tX = ((tMat.col1.x * r1X) + (tMat.col2.x * r1Y));
r1Y = ((tMat.col1.y * r1X) + (tMat.col2.y * r1Y));
r1X = tX;
tMat = b2.m_xf.R;
var r2X:Number = (m_localAnchor2.x - b2.m_sweep.localCenter.x);
var r2Y:Number = (m_localAnchor2.y - b2.m_sweep.localCenter.y);
tX = ((tMat.col1.x * r2X) + (tMat.col2.x * r2Y));
r2Y = ((tMat.col1.y * r2X) + (tMat.col2.y * r2Y));
r2X = tX;
var pivotCdotX:Number = (((b2.m_linearVelocity.x + (-(b2.m_angularVelocity) * r2Y)) - b1.m_linearVelocity.x) - (-(b1.m_angularVelocity) * r1Y));
var pivotCdotY:Number = (((b2.m_linearVelocity.y + (b2.m_angularVelocity * r2X)) - b1.m_linearVelocity.y) - (b1.m_angularVelocity * r1X));
var pivotForceX:Number = (-(step.inv_dt) * ((m_pivotMass.col1.x * pivotCdotX) + (m_pivotMass.col2.x * pivotCdotY)));
var pivotForceY:Number = (-(step.inv_dt) * ((m_pivotMass.col1.y * pivotCdotX) + (m_pivotMass.col2.y * pivotCdotY)));
m_pivotForce.x = (m_pivotForce.x + pivotForceX);
m_pivotForce.y = (m_pivotForce.y + pivotForceY);
var PX:Number = (step.dt * pivotForceX);
PY = (step.dt * pivotForceY);
b1.m_linearVelocity.x = (b1.m_linearVelocity.x - (b1.m_invMass * PX));
b1.m_linearVelocity.y = (b1.m_linearVelocity.y - (b1.m_invMass * PY));
b1.m_angularVelocity = (b1.m_angularVelocity - (b1.m_invI * ((r1X * PY) - (r1Y * PX))));
b2.m_linearVelocity.x = (b2.m_linearVelocity.x + (b2.m_invMass * PX));
b2.m_linearVelocity.y = (b2.m_linearVelocity.y + (b2.m_invMass * PY));
b2.m_angularVelocity = (b2.m_angularVelocity + (b2.m_invI * ((r2X * PY) - (r2Y * PX))));
if (((m_enableMotor) && (!((m_limitState == e_equalLimits))))){
motorCdot = ((b2.m_angularVelocity - b1.m_angularVelocity) - m_motorSpeed);
motorForce = ((-(step.inv_dt) * m_motorMass) * motorCdot);
oldMotorForce = m_motorForce;
m_motorForce = b2Math.b2Clamp((m_motorForce + motorForce), -(m_maxMotorTorque), m_maxMotorTorque);
motorForce = (m_motorForce - oldMotorForce);
b1.m_angularVelocity = (b1.m_angularVelocity - ((b1.m_invI * step.dt) * motorForce));
b2.m_angularVelocity = (b2.m_angularVelocity + ((b2.m_invI * step.dt) * motorForce));
};
if (((m_enableLimit) && (!((m_limitState == e_inactiveLimit))))){
limitCdot = (b2.m_angularVelocity - b1.m_angularVelocity);
limitForce = ((-(step.inv_dt) * m_motorMass) * limitCdot);
if (m_limitState == e_equalLimits){
m_limitForce = (m_limitForce + limitForce);
} else {
if (m_limitState == e_atLowerLimit){
oldLimitForce = m_limitForce;
m_limitForce = b2Math.b2Max((m_limitForce + limitForce), 0);
limitForce = (m_limitForce - oldLimitForce);
} else {
if (m_limitState == e_atUpperLimit){
oldLimitForce = m_limitForce;
m_limitForce = b2Math.b2Min((m_limitForce + limitForce), 0);
limitForce = (m_limitForce - oldLimitForce);
};
};
};
b1.m_angularVelocity = (b1.m_angularVelocity - ((b1.m_invI * step.dt) * limitForce));
b2.m_angularVelocity = (b2.m_angularVelocity + ((b2.m_invI * step.dt) * limitForce));
};
}
override public function SolvePositionConstraints():Boolean{
var oldLimitImpulse:Number;
var limitC:Number;
var tMat:b2Mat22;
var angle:Number;
var limitImpulse:Number;
var b1:b2Body = m_body1;
var b2:b2Body = m_body2;
var positionError:Number = 0;
tMat = b1.m_xf.R;
var r1X:Number = (m_localAnchor1.x - b1.m_sweep.localCenter.x);
var r1Y:Number = (m_localAnchor1.y - b1.m_sweep.localCenter.y);
var tX:Number = ((tMat.col1.x * r1X) + (tMat.col2.x * r1Y));
r1Y = ((tMat.col1.y * r1X) + (tMat.col2.y * r1Y));
r1X = tX;
tMat = b2.m_xf.R;
var r2X:Number = (m_localAnchor2.x - b2.m_sweep.localCenter.x);
var r2Y:Number = (m_localAnchor2.y - b2.m_sweep.localCenter.y);
tX = ((tMat.col1.x * r2X) + (tMat.col2.x * r2Y));
r2Y = ((tMat.col1.y * r2X) + (tMat.col2.y * r2Y));
r2X = tX;
var p1X:Number = (b1.m_sweep.c.x + r1X);
var p1Y:Number = (b1.m_sweep.c.y + r1Y);
var p2X:Number = (b2.m_sweep.c.x + r2X);
var p2Y:Number = (b2.m_sweep.c.y + r2Y);
var ptpCX:Number = (p2X - p1X);
var ptpCY:Number = (p2Y - p1Y);
positionError = Math.sqrt(((ptpCX * ptpCX) + (ptpCY * ptpCY)));
var invMass1:Number = b1.m_invMass;
var invMass2:Number = b2.m_invMass;
var invI1:Number = b1.m_invI;
var invI2:Number = b2.m_invI;
K1.col1.x = (invMass1 + invMass2);
K1.col2.x = 0;
K1.col1.y = 0;
K1.col2.y = (invMass1 + invMass2);
K2.col1.x = ((invI1 * r1Y) * r1Y);
K2.col2.x = ((-(invI1) * r1X) * r1Y);
K2.col1.y = ((-(invI1) * r1X) * r1Y);
K2.col2.y = ((invI1 * r1X) * r1X);
K3.col1.x = ((invI2 * r2Y) * r2Y);
K3.col2.x = ((-(invI2) * r2X) * r2Y);
K3.col1.y = ((-(invI2) * r2X) * r2Y);
K3.col2.y = ((invI2 * r2X) * r2X);
K.SetM(K1);
K.AddM(K2);
K.AddM(K3);
K.Solve(tImpulse, -(ptpCX), -(ptpCY));
var impulseX:Number = tImpulse.x;
var impulseY:Number = tImpulse.y;
b1.m_sweep.c.x = (b1.m_sweep.c.x - (b1.m_invMass * impulseX));
b1.m_sweep.c.y = (b1.m_sweep.c.y - (b1.m_invMass * impulseY));
b1.m_sweep.a = (b1.m_sweep.a - (b1.m_invI * ((r1X * impulseY) - (r1Y * impulseX))));
b2.m_sweep.c.x = (b2.m_sweep.c.x + (b2.m_invMass * impulseX));
b2.m_sweep.c.y = (b2.m_sweep.c.y + (b2.m_invMass * impulseY));
b2.m_sweep.a = (b2.m_sweep.a + (b2.m_invI * ((r2X * impulseY) - (r2Y * impulseX))));
b1.SynchronizeTransform();
b2.SynchronizeTransform();
var angularError:Number = 0;
if (((m_enableLimit) && (!((m_limitState == e_inactiveLimit))))){
angle = ((b2.m_sweep.a - b1.m_sweep.a) - m_referenceAngle);
limitImpulse = 0;
if (m_limitState == e_equalLimits){
limitC = b2Math.b2Clamp(angle, -(b2Settings.b2_maxAngularCorrection), b2Settings.b2_maxAngularCorrection);
limitImpulse = (-(m_motorMass) * limitC);
angularError = b2Math.b2Abs(limitC);
} else {
if (m_limitState == e_atLowerLimit){
limitC = (angle - m_lowerAngle);
angularError = b2Math.b2Max(0, -(limitC));
limitC = b2Math.b2Clamp((limitC + b2Settings.b2_angularSlop), -(b2Settings.b2_maxAngularCorrection), 0);
limitImpulse = (-(m_motorMass) * limitC);
oldLimitImpulse = m_limitPositionImpulse;
m_limitPositionImpulse = b2Math.b2Max((m_limitPositionImpulse + limitImpulse), 0);
limitImpulse = (m_limitPositionImpulse - oldLimitImpulse);
} else {
if (m_limitState == e_atUpperLimit){
limitC = (angle - m_upperAngle);
angularError = b2Math.b2Max(0, limitC);
limitC = b2Math.b2Clamp((limitC - b2Settings.b2_angularSlop), 0, b2Settings.b2_maxAngularCorrection);
limitImpulse = (-(m_motorMass) * limitC);
oldLimitImpulse = m_limitPositionImpulse;
m_limitPositionImpulse = b2Math.b2Min((m_limitPositionImpulse + limitImpulse), 0);
limitImpulse = (m_limitPositionImpulse - oldLimitImpulse);
};
};
};
b1.m_sweep.a = (b1.m_sweep.a - (b1.m_invI * limitImpulse));
b2.m_sweep.a = (b2.m_sweep.a + (b2.m_invI * limitImpulse));
b1.SynchronizeTransform();
b2.SynchronizeTransform();
};
return ((((positionError <= b2Settings.b2_linearSlop)) && ((angularError <= b2Settings.b2_angularSlop))));
}
}
}//package Box2D.Dynamics.Joints
Section 64
//b2RevoluteJointDef (Box2D.Dynamics.Joints.b2RevoluteJointDef)
package Box2D.Dynamics.Joints {
import Box2D.Common.Math.*;
import Box2D.Dynamics.*;
public class b2RevoluteJointDef extends b2JointDef {
public var localAnchor1:b2Vec2;
public var localAnchor2:b2Vec2;
public var referenceAngle:Number;
public var enableLimit:Boolean;
public var lowerAngle:Number;
public var upperAngle:Number;
public var enableMotor:Boolean;
public var motorSpeed:Number;
public var maxMotorTorque:Number;
public function b2RevoluteJointDef(){
localAnchor1 = new b2Vec2();
localAnchor2 = new b2Vec2();
super();
type = b2Joint.e_revoluteJoint;
localAnchor1.Set(0, 0);
localAnchor2.Set(0, 0);
referenceAngle = 0;
lowerAngle = 0;
upperAngle = 0;
maxMotorTorque = 0;
motorSpeed = 0;
enableLimit = false;
enableMotor = false;
}
public function Initialize(b1:b2Body, b2:b2Body, anchor:b2Vec2):void{
body1 = b1;
body2 = b2;
localAnchor1 = body1.GetLocalPoint(anchor);
localAnchor2 = body2.GetLocalPoint(anchor);
referenceAngle = (body2.GetAngle() - body1.GetAngle());
}
}
}//package Box2D.Dynamics.Joints
Section 65
//b2Body (Box2D.Dynamics.b2Body)
package Box2D.Dynamics {
import Box2D.Collision.Shapes.*;
import Box2D.Common.Math.*;
import Box2D.Dynamics.Joints.*;
import Box2D.Dynamics.Contacts.*;
public class b2Body {
public var m_flags:uint;
public var m_type:int;
public var m_xf:b2XForm;
public var m_sweep:b2Sweep;
public var m_linearVelocity:b2Vec2;
public var m_angularVelocity:Number;
public var m_force:b2Vec2;
public var m_torque:Number;
public var m_world:b2World;
public var m_prev:b2Body;
public var m_next:b2Body;
public var m_shapeList:b2Shape;
public var m_shapeCount:int;
public var m_jointList:b2JointEdge;
public var m_contactList:b2ContactEdge;
public var m_mass:Number;
public var m_invMass:Number;
public var m_I:Number;
public var m_invI:Number;
public var m_linearDamping:Number;
public var m_angularDamping:Number;
public var m_sleepTime:Number;
public var m_userData;
private static var s_massData:b2MassData = new b2MassData();
private static var s_xf1:b2XForm = new b2XForm();
public static var e_frozenFlag:uint = 2;
public static var e_islandFlag:uint = 4;
public static var e_sleepFlag:uint = 8;
public static var e_allowSleepFlag:uint = 16;
public static var e_bulletFlag:uint = 32;
public static var e_fixedRotationFlag:uint = 64;
public static var e_staticType:uint = 1;
public static var e_dynamicType:uint = 2;
public static var e_maxTypes:uint = 3;
public function b2Body(bd:b2BodyDef, world:b2World){
m_xf = new b2XForm();
m_sweep = new b2Sweep();
m_linearVelocity = new b2Vec2();
m_force = new b2Vec2();
super();
m_flags = 0;
if (bd.isBullet){
m_flags = (m_flags | e_bulletFlag);
};
if (bd.fixedRotation){
m_flags = (m_flags | e_fixedRotationFlag);
};
if (bd.allowSleep){
m_flags = (m_flags | e_allowSleepFlag);
};
if (bd.isSleeping){
m_flags = (m_flags | e_sleepFlag);
};
m_world = world;
m_xf.position.SetV(bd.position);
m_xf.R.Set(bd.angle);
m_sweep.localCenter.SetV(bd.massData.center);
m_sweep.t0 = 1;
m_sweep.a0 = (m_sweep.a = bd.angle);
var tMat:b2Mat22 = m_xf.R;
var tVec:b2Vec2 = m_sweep.localCenter;
m_sweep.c.x = ((tMat.col1.x * tVec.x) + (tMat.col2.x * tVec.y));
m_sweep.c.y = ((tMat.col1.y * tVec.x) + (tMat.col2.y * tVec.y));
m_sweep.c.x = (m_sweep.c.x + m_xf.position.x);
m_sweep.c.y = (m_sweep.c.y + m_xf.position.y);
m_sweep.c0.SetV(m_sweep.c);
m_jointList = null;
m_contactList = null;
m_prev = null;
m_next = null;
m_linearDamping = bd.linearDamping;
m_angularDamping = bd.angularDamping;
m_force.Set(0, 0);
m_torque = 0;
m_linearVelocity.SetZero();
m_angularVelocity = 0;
m_sleepTime = 0;
m_invMass = 0;
m_I = 0;
m_invI = 0;
m_mass = bd.massData.mass;
if (m_mass > 0){
m_invMass = (1 / m_mass);
};
if ((m_flags & b2Body.e_fixedRotationFlag) == 0){
m_I = bd.massData.I;
};
if (m_I > 0){
m_invI = (1 / m_I);
};
if ((((m_invMass == 0)) && ((m_invI == 0)))){
m_type = e_staticType;
} else {
m_type = e_dynamicType;
};
m_userData = bd.userData;
m_shapeList = null;
m_shapeCount = 0;
}
public function CreateShape(def:b2ShapeDef):b2Shape{
var s:b2Shape;
if (m_world.m_lock == true){
return (null);
};
s = b2Shape.Create(def, m_world.m_blockAllocator);
s.m_next = m_shapeList;
m_shapeList = s;
m_shapeCount++;
s.m_body = this;
s.CreateProxy(m_world.m_broadPhase, m_xf);
s.UpdateSweepRadius(m_sweep.localCenter);
return (s);
}
public function DestroyShape(s:b2Shape):void{
if (m_world.m_lock == true){
return;
};
s.DestroyProxy(m_world.m_broadPhase);
var node:b2Shape = m_shapeList;
var ppS:b2Shape;
var found:Boolean;
while (node != null) {
if (node == s){
if (ppS){
ppS.m_next = s.m_next;
} else {
m_shapeList = s.m_next;
};
found = true;
break;
};
ppS = node;
node = node.m_next;
};
s.m_body = null;
s.m_next = null;
m_shapeCount--;
b2Shape.Destroy(s, m_world.m_blockAllocator);
}
public function SetMass(massData:b2MassData):void{
var s:b2Shape;
if (m_world.m_lock == true){
return;
};
m_invMass = 0;
m_I = 0;
m_invI = 0;
m_mass = massData.mass;
if (m_mass > 0){
m_invMass = (1 / m_mass);
};
if ((m_flags & b2Body.e_fixedRotationFlag) == 0){
m_I = massData.I;
};
if (m_I > 0){
m_invI = (1 / m_I);
};
m_sweep.localCenter.SetV(massData.center);
var tMat:b2Mat22 = m_xf.R;
var tVec:b2Vec2 = m_sweep.localCenter;
m_sweep.c.x = ((tMat.col1.x * tVec.x) + (tMat.col2.x * tVec.y));
m_sweep.c.y = ((tMat.col1.y * tVec.x) + (tMat.col2.y * tVec.y));
m_sweep.c.x = (m_sweep.c.x + m_xf.position.x);
m_sweep.c.y = (m_sweep.c.y + m_xf.position.y);
m_sweep.c0.SetV(m_sweep.c);
s = m_shapeList;
while (s) {
s.UpdateSweepRadius(m_sweep.localCenter);
s = s.m_next;
};
var oldType:int = m_type;
if ((((m_invMass == 0)) && ((m_invI == 0)))){
m_type = e_staticType;
} else {
m_type = e_dynamicType;
};
if (oldType != m_type){
s = m_shapeList;
while (s) {
s.RefilterProxy(m_world.m_broadPhase, m_xf);
s = s.m_next;
};
};
}
public function SetMassFromShapes():void{
var s:b2Shape;
if (m_world.m_lock == true){
return;
};
m_mass = 0;
m_invMass = 0;
m_I = 0;
m_invI = 0;
var centerX:Number = 0;
var centerY:Number = 0;
var massData:b2MassData = s_massData;
s = m_shapeList;
while (s) {
s.ComputeMass(massData);
m_mass = (m_mass + massData.mass);
centerX = (centerX + (massData.mass * massData.center.x));
centerY = (centerY + (massData.mass * massData.center.y));
m_I = (m_I + massData.I);
s = s.m_next;
};
if (m_mass > 0){
m_invMass = (1 / m_mass);
centerX = (centerX * m_invMass);
centerY = (centerY * m_invMass);
};
if ((((m_I > 0)) && (((m_flags & e_fixedRotationFlag) == 0)))){
m_I = (m_I - (m_mass * ((centerX * centerX) + (centerY * centerY))));
m_invI = (1 / m_I);
} else {
m_I = 0;
m_invI = 0;
};
m_sweep.localCenter.Set(centerX, centerY);
var tMat:b2Mat22 = m_xf.R;
var tVec:b2Vec2 = m_sweep.localCenter;
m_sweep.c.x = ((tMat.col1.x * tVec.x) + (tMat.col2.x * tVec.y));
m_sweep.c.y = ((tMat.col1.y * tVec.x) + (tMat.col2.y * tVec.y));
m_sweep.c.x = (m_sweep.c.x + m_xf.position.x);
m_sweep.c.y = (m_sweep.c.y + m_xf.position.y);
m_sweep.c0.SetV(m_sweep.c);
s = m_shapeList;
while (s) {
s.UpdateSweepRadius(m_sweep.localCenter);
s = s.m_next;
};
var oldType:int = m_type;
if ((((m_invMass == 0)) && ((m_invI == 0)))){
m_type = e_staticType;
} else {
m_type = e_dynamicType;
};
if (oldType != m_type){
s = m_shapeList;
while (s) {
s.RefilterProxy(m_world.m_broadPhase, m_xf);
s = s.m_next;
};
};
}
public function SetXForm(position:b2Vec2, angle:Number):Boolean{
var s:b2Shape;
var inRange:Boolean;
if (m_world.m_lock == true){
return (true);
};
if (IsFrozen()){
return (false);
};
m_xf.R.Set(angle);
m_xf.position.SetV(position);
var tMat:b2Mat22 = m_xf.R;
var tVec:b2Vec2 = m_sweep.localCenter;
m_sweep.c.x = ((tMat.col1.x * tVec.x) + (tMat.col2.x * tVec.y));
m_sweep.c.y = ((tMat.col1.y * tVec.x) + (tMat.col2.y * tVec.y));
m_sweep.c.x = (m_sweep.c.x + m_xf.position.x);
m_sweep.c.y = (m_sweep.c.y + m_xf.position.y);
m_sweep.c0.SetV(m_sweep.c);
m_sweep.a0 = (m_sweep.a = angle);
var freeze:Boolean;
s = m_shapeList;
while (s) {
inRange = s.Synchronize(m_world.m_broadPhase, m_xf, m_xf);
if (inRange == false){
freeze = true;
break;
};
s = s.m_next;
};
if (freeze == true){
m_flags = (m_flags | e_frozenFlag);
m_linearVelocity.SetZero();
m_angularVelocity = 0;
s = m_shapeList;
while (s) {
s.DestroyProxy(m_world.m_broadPhase);
s = s.m_next;
};
return (false);
};
m_world.m_broadPhase.Commit();
return (true);
}
public function GetXForm():b2XForm{
return (m_xf);
}
public function GetPosition():b2Vec2{
return (m_xf.position);
}
public function GetAngle():Number{
return (m_sweep.a);
}
public function GetWorldCenter():b2Vec2{
return (m_sweep.c);
}
public function GetLocalCenter():b2Vec2{
return (m_sweep.localCenter);
}
public function SetLinearVelocity(v:b2Vec2):void{
m_linearVelocity.SetV(v);
}
public function GetLinearVelocity():b2Vec2{
return (m_linearVelocity);
}
public function SetAngularVelocity(omega:Number):void{
m_angularVelocity = omega;
}
public function GetAngularVelocity():Number{
return (m_angularVelocity);
}
public function ApplyForce(force:b2Vec2, point:b2Vec2):void{
if (IsSleeping()){
WakeUp();
};
m_force.x = (m_force.x + force.x);
m_force.y = (m_force.y + force.y);
m_torque = (m_torque + (((point.x - m_sweep.c.x) * force.y) - ((point.y - m_sweep.c.y) * force.x)));
}
public function ApplyTorque(torque:Number):void{
if (IsSleeping()){
WakeUp();
};
m_torque = (m_torque + torque);
}
public function ApplyImpulse(impulse:b2Vec2, point:b2Vec2):void{
if (IsSleeping()){
WakeUp();
};
m_linearVelocity.x = (m_linearVelocity.x + (m_invMass * impulse.x));
m_linearVelocity.y = (m_linearVelocity.y + (m_invMass * impulse.y));
m_angularVelocity = (m_angularVelocity + (m_invI * (((point.x - m_sweep.c.x) * impulse.y) - ((point.y - m_sweep.c.y) * impulse.x))));
}
public function GetMass():Number{
return (m_mass);
}
public function GetInertia():Number{
return (m_I);
}
public function GetWorldPoint(localPoint:b2Vec2):b2Vec2{
var A:b2Mat22 = m_xf.R;
var u:b2Vec2 = new b2Vec2(((A.col1.x * localPoint.x) + (A.col2.x * localPoint.y)), ((A.col1.y * localPoint.x) + (A.col2.y * localPoint.y)));
u.x = (u.x + m_xf.position.x);
u.y = (u.y + m_xf.position.y);
return (u);
}
public function GetWorldVector(localVector:b2Vec2):b2Vec2{
return (b2Math.b2MulMV(m_xf.R, localVector));
}
public function GetLocalPoint(worldPoint:b2Vec2):b2Vec2{
return (b2Math.b2MulXT(m_xf, worldPoint));
}
public function GetLocalVector(worldVector:b2Vec2):b2Vec2{
return (b2Math.b2MulTMV(m_xf.R, worldVector));
}
public function GetLinearVelocityFromWorldPoint(worldPoint:b2Vec2):b2Vec2{
return (new b2Vec2((m_linearVelocity.x - (m_angularVelocity * (worldPoint.y - m_sweep.c.y))), (m_linearVelocity.y + (m_angularVelocity * (worldPoint.x - m_sweep.c.x)))));
}
public function GetLinearVelocityFromLocalPoint(localPoint:b2Vec2):b2Vec2{
var A:b2Mat22 = m_xf.R;
var worldPoint:b2Vec2 = new b2Vec2(((A.col1.x * localPoint.x) + (A.col2.x * localPoint.y)), ((A.col1.y * localPoint.x) + (A.col2.y * localPoint.y)));
worldPoint.x = (worldPoint.x + m_xf.position.x);
worldPoint.y = (worldPoint.y + m_xf.position.y);
return (new b2Vec2((m_linearVelocity.x + (m_angularVelocity * (worldPoint.y - m_sweep.c.y))), (m_linearVelocity.x - (m_angularVelocity * (worldPoint.x - m_sweep.c.x)))));
}
public function IsBullet():Boolean{
return (((m_flags & e_bulletFlag) == e_bulletFlag));
}
public function SetBullet(flag:Boolean):void{
if (flag){
m_flags = (m_flags | e_bulletFlag);
} else {
m_flags = (m_flags & ~(e_bulletFlag));
};
}
public function IsStatic():Boolean{
return ((m_type == e_staticType));
}
public function IsDynamic():Boolean{
return ((m_type == e_dynamicType));
}
public function IsFrozen():Boolean{
return (((m_flags & e_frozenFlag) == e_frozenFlag));
}
public function IsSleeping():Boolean{
return (((m_flags & e_sleepFlag) == e_sleepFlag));
}
public function AllowSleeping(flag:Boolean):void{
if (flag){
m_flags = (m_flags | e_allowSleepFlag);
} else {
m_flags = (m_flags & ~(e_allowSleepFlag));
WakeUp();
};
}
public function WakeUp():void{
m_flags = (m_flags & ~(e_sleepFlag));
m_sleepTime = 0;
}
public function PutToSleep():void{
m_flags = (m_flags | e_sleepFlag);
m_sleepTime = 0;
m_linearVelocity.SetZero();
m_angularVelocity = 0;
m_force.SetZero();
m_torque = 0;
}
public function GetShapeList():b2Shape{
return (m_shapeList);
}
public function GetJointList():b2JointEdge{
return (m_jointList);
}
public function GetNext():b2Body{
return (m_next);
}
public function GetUserData(){
return (m_userData);
}
public function SetUserData(data):void{
m_userData = data;
}
public function GetWorld():b2World{
return (m_world);
}
public function SynchronizeShapes():Boolean{
var s:b2Shape;
var xf1:b2XForm = s_xf1;
xf1.R.Set(m_sweep.a0);
var tMat:b2Mat22 = xf1.R;
var tVec:b2Vec2 = m_sweep.localCenter;
xf1.position.x = (m_sweep.c0.x - ((tMat.col1.x * tVec.x) + (tMat.col2.x * tVec.y)));
xf1.position.y = (m_sweep.c0.y - ((tMat.col1.y * tVec.x) + (tMat.col2.y * tVec.y)));
var inRange:Boolean;
s = m_shapeList;
while (s) {
inRange = s.Synchronize(m_world.m_broadPhase, xf1, m_xf);
if (inRange == false){
break;
};
s = s.m_next;
};
if (inRange == false){
m_flags = (m_flags | e_frozenFlag);
m_linearVelocity.SetZero();
m_angularVelocity = 0;
s = m_shapeList;
while (s) {
s.DestroyProxy(m_world.m_broadPhase);
s = s.m_next;
};
return (false);
};
return (true);
}
public function SynchronizeTransform():void{
m_xf.R.Set(m_sweep.a);
var tMat:b2Mat22 = m_xf.R;
var tVec:b2Vec2 = m_sweep.localCenter;
m_xf.position.x = (m_sweep.c.x - ((tMat.col1.x * tVec.x) + (tMat.col2.x * tVec.y)));
m_xf.position.y = (m_sweep.c.y - ((tMat.col1.y * tVec.x) + (tMat.col2.y * tVec.y)));
}
public function IsConnected(other:b2Body):Boolean{
var jn:b2JointEdge = m_jointList;
while (jn) {
if (jn.other == other){
return ((jn.joint.m_collideConnected == false));
};
jn = jn.next;
};
return (false);
}
public function Advance(t:Number):void{
m_sweep.Advance(t);
m_sweep.c.SetV(m_sweep.c0);
m_sweep.a = m_sweep.a0;
SynchronizeTransform();
}
}
}//package Box2D.Dynamics
Section 66
//b2BodyDef (Box2D.Dynamics.b2BodyDef)
package Box2D.Dynamics {
import Box2D.Collision.Shapes.*;
import Box2D.Common.Math.*;
public class b2BodyDef {
public var massData:b2MassData;
public var userData;
public var position:b2Vec2;
public var angle:Number;
public var linearDamping:Number;
public var angularDamping:Number;
public var allowSleep:Boolean;
public var isSleeping:Boolean;
public var fixedRotation:Boolean;
public var isBullet:Boolean;
public function b2BodyDef(){
massData = new b2MassData();
position = new b2Vec2();
super();
massData.center.SetZero();
massData.mass = 0;
massData.I = 0;
userData = null;
position.Set(0, 0);
angle = 0;
linearDamping = 0;
angularDamping = 0;
allowSleep = true;
isSleeping = false;
fixedRotation = false;
isBullet = false;
}
}
}//package Box2D.Dynamics
Section 67
//b2BoundaryListener (Box2D.Dynamics.b2BoundaryListener)
package Box2D.Dynamics {
public class b2BoundaryListener {
public function Violation(body:b2Body):void{
}
}
}//package Box2D.Dynamics
Section 68
//b2ContactFilter (Box2D.Dynamics.b2ContactFilter)
package Box2D.Dynamics {
import Box2D.Collision.Shapes.*;
public class b2ContactFilter {
public static var b2_defaultFilter:b2ContactFilter = new (b2ContactFilter);
;
public function ShouldCollide(shape1:b2Shape, shape2:b2Shape):Boolean{
var filter1:b2FilterData = shape1.GetFilterData();
var filter2:b2FilterData = shape2.GetFilterData();
if ((((filter1.groupIndex == filter2.groupIndex)) && (!((filter1.groupIndex == 0))))){
return ((filter1.groupIndex > 0));
};
var collide:Boolean = ((!(((filter1.maskBits & filter2.categoryBits) == 0))) && (!(((filter1.categoryBits & filter2.maskBits) == 0))));
return (collide);
}
}
}//package Box2D.Dynamics
Section 69
//b2ContactListener (Box2D.Dynamics.b2ContactListener)
package Box2D.Dynamics {
import Box2D.Collision.*;
import Box2D.Dynamics.Contacts.*;
public class b2ContactListener {
public function Add(point:b2ContactPoint):void{
}
public function Persist(point:b2ContactPoint):void{
}
public function Remove(point:b2ContactPoint):void{
}
public function Result(point:b2ContactResult):void{
}
}
}//package Box2D.Dynamics
Section 70
//b2ContactManager (Box2D.Dynamics.b2ContactManager)
package Box2D.Dynamics {
import Box2D.Collision.Shapes.*;
import Box2D.Common.Math.*;
import Box2D.Collision.*;
import Box2D.Dynamics.Contacts.*;
import Box2D.Common.*;
public class b2ContactManager extends b2PairCallback {
public var m_world:b2World;
public var m_nullContact:b2NullContact;
public var m_destroyImmediate:Boolean;
private static const s_evalCP:b2ContactPoint = new b2ContactPoint();
public function b2ContactManager(){
m_nullContact = new b2NullContact();
super();
m_world = null;
m_destroyImmediate = false;
}
override public function PairAdded(proxyUserData1, proxyUserData2){
var shape1:b2Shape = (proxyUserData1 as b2Shape);
var shape2:b2Shape = (proxyUserData2 as b2Shape);
var body1:b2Body = shape1.m_body;
var body2:b2Body = shape2.m_body;
if (((body1.IsStatic()) && (body2.IsStatic()))){
return (m_nullContact);
};
if (shape1.m_body == shape2.m_body){
return (m_nullContact);
};
if (body2.IsConnected(body1)){
return (m_nullContact);
};
if (((!((m_world.m_contactFilter == null))) && ((m_world.m_contactFilter.ShouldCollide(shape1, shape2) == false)))){
return (m_nullContact);
};
var c:b2Contact = b2Contact.Create(shape1, shape2, m_world.m_blockAllocator);
if (c == null){
return (m_nullContact);
};
shape1 = c.m_shape1;
shape2 = c.m_shape2;
body1 = shape1.m_body;
body2 = shape2.m_body;
c.m_prev = null;
c.m_next = m_world.m_contactList;
if (m_world.m_contactList != null){
m_world.m_contactList.m_prev = c;
};
m_world.m_contactList = c;
c.m_node1.contact = c;
c.m_node1.other = body2;
c.m_node1.prev = null;
c.m_node1.next = body1.m_contactList;
if (body1.m_contactList != null){
body1.m_contactList.prev = c.m_node1;
};
body1.m_contactList = c.m_node1;
c.m_node2.contact = c;
c.m_node2.other = body1;
c.m_node2.prev = null;
c.m_node2.next = body2.m_contactList;
if (body2.m_contactList != null){
body2.m_contactList.prev = c.m_node2;
};
body2.m_contactList = c.m_node2;
m_world.m_contactCount++;
return (c);
}
override public function PairRemoved(proxyUserData1, proxyUserData2, pairUserData):void{
if (pairUserData == null){
return;
};
var c:b2Contact = (pairUserData as b2Contact);
if (c == m_nullContact){
return;
};
Destroy(c);
}
public function Destroy(c:b2Contact):void{
var b1:b2Body;
var b2:b2Body;
var manifolds:Array;
var cp:b2ContactPoint;
var i:int;
var manifold:b2Manifold;
var j:int;
var mp:b2ManifoldPoint;
var v1:b2Vec2;
var v2:b2Vec2;
var shape1:b2Shape = c.m_shape1;
var shape2:b2Shape = c.m_shape2;
var manifoldCount:int = c.m_manifoldCount;
if ((((manifoldCount > 0)) && (m_world.m_contactListener))){
b1 = shape1.m_body;
b2 = shape2.m_body;
manifolds = c.GetManifolds();
cp = s_evalCP;
cp.shape1 = c.m_shape1;
cp.shape2 = c.m_shape2;
cp.friction = c.m_friction;
cp.restitution = c.m_restitution;
i = 0;
while (i < manifoldCount) {
manifold = manifolds[i];
cp.normal.SetV(manifold.normal);
j = 0;
while (j < manifold.pointCount) {
mp = manifold.points[j];
cp.position = b1.GetWorldPoint(mp.localPoint1);
v1 = b1.GetLinearVelocityFromLocalPoint(mp.localPoint1);
v2 = b2.GetLinearVelocityFromLocalPoint(mp.localPoint2);
cp.velocity.Set((v2.x - v1.x), (v2.y - v1.y));
cp.separation = mp.separation;
cp.id.key = mp.id._key;
m_world.m_contactListener.Remove(cp);
j++;
};
i++;
};
};
if (c.m_prev){
c.m_prev.m_next = c.m_next;
};
if (c.m_next){
c.m_next.m_prev = c.m_prev;
};
if (c == m_world.m_contactList){
m_world.m_contactList = c.m_next;
};
var body1:b2Body = shape1.m_body;
var body2:b2Body = shape2.m_body;
if (c.m_node1.prev){
c.m_node1.prev.next = c.m_node1.next;
};
if (c.m_node1.next){
c.m_node1.next.prev = c.m_node1.prev;
};
if (c.m_node1 == body1.m_contactList){
body1.m_contactList = c.m_node1.next;
};
if (c.m_node2.prev){
c.m_node2.prev.next = c.m_node2.next;
};
if (c.m_node2.next){
c.m_node2.next.prev = c.m_node2.prev;
};
if (c.m_node2 == body2.m_contactList){
body2.m_contactList = c.m_node2.next;
};
b2Contact.Destroy(c, m_world.m_blockAllocator);
m_world.m_contactCount--;
}
public function Collide():void{
var body1:b2Body;
var body2:b2Body;
var c:b2Contact = m_world.m_contactList;
while (c) {
body1 = c.m_shape1.m_body;
body2 = c.m_shape2.m_body;
if (((body1.IsSleeping()) && (body2.IsSleeping()))){
} else {
c.Update(m_world.m_contactListener);
};
c = c.m_next;
};
}
}
}//package Box2D.Dynamics
Section 71
//b2DebugDraw (Box2D.Dynamics.b2DebugDraw)
package Box2D.Dynamics {
import flash.display.*;
import Box2D.Collision.Shapes.*;
import Box2D.Common.Math.*;
import Box2D.Collision.*;
import Box2D.Dynamics.Contacts.*;
import Box2D.Common.*;
public class b2DebugDraw {
public var m_drawFlags:uint;
public var m_sprite:Sprite;
public var m_drawScale:Number;// = 1
public var m_lineThickness:Number;// = 1
public var m_alpha:Number;// = 1
public var m_fillAlpha:Number;// = 1
public var m_xformScale:Number;// = 1
public static var e_shapeBit:uint = 1;
public static var e_jointBit:uint = 2;
public static var e_coreShapeBit:uint = 4;
public static var e_aabbBit:uint = 8;
public static var e_obbBit:uint = 16;
public static var e_pairBit:uint = 32;
public static var e_centerOfMassBit:uint = 64;
public function b2DebugDraw(){
super();
m_drawFlags = 0;
}
public function SetFlags(flags:uint):void{
m_drawFlags = flags;
}
public function GetFlags():uint{
return (m_drawFlags);
}
public function AppendFlags(flags:uint):void{
m_drawFlags = (m_drawFlags | flags);
}
public function ClearFlags(flags:uint):void{
m_drawFlags = (m_drawFlags & ~(flags));
}
public function DrawPolygon(vertices:Array, vertexCount:int, color:b2Color):void{
m_sprite.graphics.lineStyle(m_lineThickness, color.color, m_alpha);
m_sprite.graphics.moveTo((vertices[0].x * m_drawScale), (vertices[0].y * m_drawScale));
var i = 1;
while (i < vertexCount) {
m_sprite.graphics.lineTo((vertices[i].x * m_drawScale), (vertices[i].y * m_drawScale));
i++;
};
m_sprite.graphics.lineTo((vertices[0].x * m_drawScale), (vertices[0].y * m_drawScale));
}
public function DrawSolidPolygon(vertices:Array, vertexCount:int, color:b2Color):void{
m_sprite.graphics.lineStyle(m_lineThickness, color.color, m_alpha);
m_sprite.graphics.moveTo((vertices[0].x * m_drawScale), (vertices[0].y * m_drawScale));
m_sprite.graphics.beginFill(color.color, m_fillAlpha);
var i = 1;
while (i < vertexCount) {
m_sprite.graphics.lineTo((vertices[i].x * m_drawScale), (vertices[i].y * m_drawScale));
i++;
};
m_sprite.graphics.lineTo((vertices[0].x * m_drawScale), (vertices[0].y * m_drawScale));
m_sprite.graphics.endFill();
}
public function DrawCircle(center:b2Vec2, radius:Number, color:b2Color):void{
m_sprite.graphics.lineStyle(m_lineThickness, color.color, m_alpha);
m_sprite.graphics.drawCircle((center.x * m_drawScale), (center.y * m_drawScale), (radius * m_drawScale));
}
public function DrawSolidCircle(center:b2Vec2, radius:Number, axis:b2Vec2, color:b2Color):void{
m_sprite.graphics.lineStyle(m_lineThickness, color.color, m_alpha);
m_sprite.graphics.moveTo(0, 0);
m_sprite.graphics.beginFill(color.color, m_fillAlpha);
m_sprite.graphics.drawCircle((center.x * m_drawScale), (center.y * m_drawScale), (radius * m_drawScale));
m_sprite.graphics.endFill();
m_sprite.graphics.moveTo((center.x * m_drawScale), (center.y * m_drawScale));
m_sprite.graphics.lineTo(((center.x + (axis.x * radius)) * m_drawScale), ((center.y + (axis.y * radius)) * m_drawScale));
}
public function DrawSegment(p1:b2Vec2, p2:b2Vec2, color:b2Color):void{
m_sprite.graphics.lineStyle(m_lineThickness, color.color, m_alpha);
m_sprite.graphics.moveTo((p1.x * m_drawScale), (p1.y * m_drawScale));
m_sprite.graphics.lineTo((p2.x * m_drawScale), (p2.y * m_drawScale));
}
public function DrawXForm(xf:b2XForm):void{
m_sprite.graphics.lineStyle(m_lineThickness, 0xFF0000, m_alpha);
m_sprite.graphics.moveTo((xf.position.x * m_drawScale), (xf.position.y * m_drawScale));
m_sprite.graphics.lineTo(((xf.position.x + (m_xformScale * xf.R.col1.x)) * m_drawScale), ((xf.position.y + (m_xformScale * xf.R.col1.y)) * m_drawScale));
m_sprite.graphics.lineStyle(m_lineThickness, 0xFF00, m_alpha);
m_sprite.graphics.moveTo((xf.position.x * m_drawScale), (xf.position.y * m_drawScale));
m_sprite.graphics.lineTo(((xf.position.x + (m_xformScale * xf.R.col2.x)) * m_drawScale), ((xf.position.y + (m_xformScale * xf.R.col2.y)) * m_drawScale));
}
}
}//package Box2D.Dynamics
Section 72
//b2DestructionListener (Box2D.Dynamics.b2DestructionListener)
package Box2D.Dynamics {
import Box2D.Collision.Shapes.*;
import Box2D.Dynamics.Joints.*;
public class b2DestructionListener {
public function SayGoodbyeJoint(joint:b2Joint):void{
}
public function SayGoodbyeShape(shape:b2Shape):void{
}
}
}//package Box2D.Dynamics
Section 73
//b2Island (Box2D.Dynamics.b2Island)
package Box2D.Dynamics {
import Box2D.Common.Math.*;
import Box2D.Dynamics.Joints.*;
import Box2D.Collision.*;
import Box2D.Dynamics.Contacts.*;
import Box2D.Common.*;
public class b2Island {
public var m_allocator;
public var m_listener:b2ContactListener;
public var m_bodies:Array;
public var m_contacts:Array;
public var m_joints:Array;
public var m_bodyCount:int;
public var m_jointCount:int;
public var m_contactCount:int;
public var m_bodyCapacity:int;
public var m_contactCapacity:int;
public var m_jointCapacity:int;
public var m_positionIterationCount:int;
private static var s_reportCR:b2ContactResult = new b2ContactResult();
public function b2Island(bodyCapacity:int, contactCapacity:int, jointCapacity:int, allocator, listener:b2ContactListener){
var i:int;
super();
m_bodyCapacity = bodyCapacity;
m_contactCapacity = contactCapacity;
m_jointCapacity = jointCapacity;
m_bodyCount = 0;
m_contactCount = 0;
m_jointCount = 0;
m_allocator = allocator;
m_listener = listener;
m_bodies = new Array(bodyCapacity);
i = 0;
while (i < bodyCapacity) {
m_bodies[i] = null;
i++;
};
m_contacts = new Array(contactCapacity);
i = 0;
while (i < contactCapacity) {
m_contacts[i] = null;
i++;
};
m_joints = new Array(jointCapacity);
i = 0;
while (i < jointCapacity) {
m_joints[i] = null;
i++;
};
m_positionIterationCount = 0;
}
public function Clear():void{
m_bodyCount = 0;
m_contactCount = 0;
m_jointCount = 0;
}
public function Solve(step:b2TimeStep, gravity:b2Vec2, correctPositions:Boolean, allowSleep:Boolean):void{
var i:int;
var b:b2Body;
var joint:b2Joint;
var j:int;
var contactsOkay:Boolean;
var jointsOkay:Boolean;
var jointOkay:Boolean;
var minSleepTime:Number;
var linTolSqr:Number;
var angTolSqr:Number;
i = 0;
while (i < m_bodyCount) {
b = m_bodies[i];
if (b.IsStatic()){
} else {
b.m_linearVelocity.x = (b.m_linearVelocity.x + (step.dt * (gravity.x + (b.m_invMass * b.m_force.x))));
b.m_linearVelocity.y = (b.m_linearVelocity.y + (step.dt * (gravity.y + (b.m_invMass * b.m_force.y))));
b.m_angularVelocity = (b.m_angularVelocity + ((step.dt * b.m_invI) * b.m_torque));
b.m_force.SetZero();
b.m_torque = 0;
b.m_linearVelocity.Multiply(b2Math.b2Clamp((1 - (step.dt * b.m_linearDamping)), 0, 1));
b.m_angularVelocity = (b.m_angularVelocity * b2Math.b2Clamp((1 - (step.dt * b.m_angularDamping)), 0, 1));
if (b.m_linearVelocity.LengthSquared() > b2Settings.b2_maxLinearVelocitySquared){
b.m_linearVelocity.Normalize();
b.m_linearVelocity.x = (b.m_linearVelocity.x * b2Settings.b2_maxLinearVelocity);
b.m_linearVelocity.y = (b.m_linearVelocity.y * b2Settings.b2_maxLinearVelocity);
};
if ((b.m_angularVelocity * b.m_angularVelocity) > b2Settings.b2_maxAngularVelocitySquared){
if (b.m_angularVelocity < 0){
b.m_angularVelocity = -(b2Settings.b2_maxAngularVelocity);
} else {
b.m_angularVelocity = b2Settings.b2_maxAngularVelocity;
};
};
};
i++;
};
var contactSolver:b2ContactSolver = new b2ContactSolver(step, m_contacts, m_contactCount, m_allocator);
contactSolver.InitVelocityConstraints(step);
i = 0;
while (i < m_jointCount) {
joint = m_joints[i];
joint.InitVelocityConstraints(step);
i++;
};
i = 0;
while (i < step.maxIterations) {
contactSolver.SolveVelocityConstraints();
j = 0;
while (j < m_jointCount) {
joint = m_joints[j];
joint.SolveVelocityConstraints(step);
j++;
};
i++;
};
contactSolver.FinalizeVelocityConstraints();
i = 0;
while (i < m_bodyCount) {
b = m_bodies[i];
if (b.IsStatic()){
} else {
b.m_sweep.c0.SetV(b.m_sweep.c);
b.m_sweep.a0 = b.m_sweep.a;
b.m_sweep.c.x = (b.m_sweep.c.x + (step.dt * b.m_linearVelocity.x));
b.m_sweep.c.y = (b.m_sweep.c.y + (step.dt * b.m_linearVelocity.y));
b.m_sweep.a = (b.m_sweep.a + (step.dt * b.m_angularVelocity));
b.SynchronizeTransform();
};
i++;
};
if (correctPositions){
i = 0;
while (i < m_jointCount) {
joint = m_joints[i];
joint.InitPositionConstraints();
i++;
};
m_positionIterationCount = 0;
while (m_positionIterationCount < step.maxIterations) {
contactsOkay = contactSolver.SolvePositionConstraints(b2Settings.b2_contactBaumgarte);
jointsOkay = true;
i = 0;
while (i < m_jointCount) {
joint = m_joints[i];
jointOkay = joint.SolvePositionConstraints();
jointsOkay = ((jointsOkay) && (jointOkay));
i++;
};
if (((contactsOkay) && (jointsOkay))){
break;
};
m_positionIterationCount++;
};
};
Report(contactSolver.m_constraints);
if (allowSleep){
minSleepTime = Number.MAX_VALUE;
linTolSqr = (b2Settings.b2_linearSleepTolerance * b2Settings.b2_linearSleepTolerance);
angTolSqr = (b2Settings.b2_angularSleepTolerance * b2Settings.b2_angularSleepTolerance);
i = 0;
while (i < m_bodyCount) {
b = m_bodies[i];
if (b.m_invMass == 0){
} else {
if ((b.m_flags & b2Body.e_allowSleepFlag) == 0){
b.m_sleepTime = 0;
minSleepTime = 0;
};
if (((((((b.m_flags & b2Body.e_allowSleepFlag) == 0)) || (((b.m_angularVelocity * b.m_angularVelocity) > angTolSqr)))) || ((b2Math.b2Dot(b.m_linearVelocity, b.m_linearVelocity) > linTolSqr)))){
b.m_sleepTime = 0;
minSleepTime = 0;
} else {
b.m_sleepTime = (b.m_sleepTime + step.dt);
minSleepTime = b2Math.b2Min(minSleepTime, b.m_sleepTime);
};
};
i++;
};
if (minSleepTime >= b2Settings.b2_timeToSleep){
i = 0;
while (i < m_bodyCount) {
b = m_bodies[i];
b.m_flags = (b.m_flags | b2Body.e_sleepFlag);
b.m_linearVelocity.SetZero();
b.m_angularVelocity = 0;
i++;
};
};
};
}
public function SolveTOI(subStep:b2TimeStep):void{
var i:int;
var b:b2Body;
var contactsOkay:Boolean;
var contactSolver:b2ContactSolver = new b2ContactSolver(subStep, m_contacts, m_contactCount, m_allocator);
i = 0;
while (i < subStep.maxIterations) {
contactSolver.SolveVelocityConstraints();
i++;
};
i = 0;
while (i < m_bodyCount) {
b = m_bodies[i];
if (b.IsStatic()){
} else {
b.m_sweep.c0.SetV(b.m_sweep.c);
b.m_sweep.a0 = b.m_sweep.a;
b.m_sweep.c.x = (b.m_sweep.c.x + (subStep.dt * b.m_linearVelocity.x));
b.m_sweep.c.y = (b.m_sweep.c.y + (subStep.dt * b.m_linearVelocity.y));
b.m_sweep.a = (b.m_sweep.a + (subStep.dt * b.m_angularVelocity));
b.SynchronizeTransform();
};
i++;
};
var k_toiBaumgarte:Number = 0.75;
i = 0;
while (i < subStep.maxIterations) {
contactsOkay = contactSolver.SolvePositionConstraints(k_toiBaumgarte);
if (contactsOkay){
break;
};
i++;
};
Report(contactSolver.m_constraints);
}
public function Report(constraints:Array):void{
var tMat:b2Mat22;
var tVec:b2Vec2;
var c:b2Contact;
var cc:b2ContactConstraint;
var cr:b2ContactResult;
var b1:b2Body;
var manifoldCount:int;
var manifolds:Array;
var j:int;
var manifold:b2Manifold;
var k:int;
var point:b2ManifoldPoint;
var ccp:b2ContactConstraintPoint;
if (m_listener == null){
return;
};
var i:int;
while (i < m_contactCount) {
c = m_contacts[i];
cc = constraints[i];
cr = s_reportCR;
cr.shape1 = c.m_shape1;
cr.shape2 = c.m_shape2;
b1 = cr.shape1.m_body;
manifoldCount = c.m_manifoldCount;
manifolds = c.GetManifolds();
j = 0;
while (j < manifoldCount) {
manifold = manifolds[j];
cr.normal.SetV(manifold.normal);
k = 0;
while (k < manifold.pointCount) {
point = manifold.points[k];
ccp = cc.points[k];
cr.position = b1.GetWorldPoint(point.localPoint1);
cr.normalImpulse = ccp.normalImpulse;
cr.tangentImpulse = ccp.tangentImpulse;
cr.id.key = point.id.key;
m_listener.Result(cr);
k++;
};
j++;
};
i++;
};
}
public function AddBody(body:b2Body):void{
var _local2 = m_bodyCount++;
m_bodies[_local2] = body;
}
public function AddContact(contact:b2Contact):void{
var _local2 = m_contactCount++;
m_contacts[_local2] = contact;
}
public function AddJoint(joint:b2Joint):void{
var _local2 = m_jointCount++;
m_joints[_local2] = joint;
}
}
}//package Box2D.Dynamics
Section 74
//b2TimeStep (Box2D.Dynamics.b2TimeStep)
package Box2D.Dynamics {
public class b2TimeStep {
public var dt:Number;
public var inv_dt:Number;
public var dtRatio:Number;
public var maxIterations:int;
public var warmStarting:Boolean;
public var positionCorrection:Boolean;
}
}//package Box2D.Dynamics
Section 75
//b2World (Box2D.Dynamics.b2World)
package Box2D.Dynamics {
import Box2D.Collision.Shapes.*;
import Box2D.Common.Math.*;
import Box2D.Dynamics.Joints.*;
import Box2D.Collision.*;
import Box2D.Dynamics.Contacts.*;
import Box2D.Common.*;
public class b2World {
public var m_blockAllocator;
public var m_stackAllocator;
public var m_lock:Boolean;
public var m_broadPhase:b2BroadPhase;
public var m_contactManager:b2ContactManager;
public var m_bodyList:b2Body;
public var m_jointList:b2Joint;
public var m_contactList:b2Contact;
public var m_bodyCount:int;
public var m_contactCount:int;
public var m_jointCount:int;
public var m_gravity:b2Vec2;
public var m_allowSleep:Boolean;
public var m_groundBody:b2Body;
public var m_destructionListener:b2DestructionListener;
public var m_boundaryListener:b2BoundaryListener;
public var m_contactFilter:b2ContactFilter;
public var m_contactListener:b2ContactListener;
public var m_debugDraw:b2DebugDraw;
public var m_inv_dt0:Number;
public var m_positionIterationCount:int;
private static var s_jointColor:b2Color = new b2Color(0.5, 0.8, 0.8);
private static var s_coreColor:b2Color = new b2Color(0.9, 0.6, 0.6);
private static var s_xf:b2XForm = new b2XForm();
public static var m_positionCorrection:Boolean;
public static var m_warmStarting:Boolean;
public static var m_continuousPhysics:Boolean;
public function b2World(worldAABB:b2AABB, gravity:b2Vec2, doSleep:Boolean){
m_contactManager = new b2ContactManager();
super();
m_destructionListener = null;
m_boundaryListener = null;
m_contactFilter = b2ContactFilter.b2_defaultFilter;
m_contactListener = null;
m_debugDraw = null;
m_bodyList = null;
m_contactList = null;
m_jointList = null;
m_bodyCount = 0;
m_contactCount = 0;
m_jointCount = 0;
m_positionCorrection = true;
m_warmStarting = true;
m_continuousPhysics = true;
m_allowSleep = doSleep;
m_gravity = gravity;
m_lock = false;
m_inv_dt0 = 0;
m_contactManager.m_world = this;
m_broadPhase = new b2BroadPhase(worldAABB, m_contactManager);
var bd:b2BodyDef = new b2BodyDef();
m_groundBody = CreateBody(bd);
}
public function SetDestructionListener(listener:b2DestructionListener):void{
m_destructionListener = listener;
}
public function SetBoundaryListener(listener:b2BoundaryListener):void{
m_boundaryListener = listener;
}
public function SetContactFilter(filter:b2ContactFilter):void{
m_contactFilter = filter;
}
public function SetContactListener(listener:b2ContactListener):void{
m_contactListener = listener;
}
public function SetDebugDraw(debugDraw:b2DebugDraw):void{
m_debugDraw = debugDraw;
}
public function Validate():void{
m_broadPhase.Validate();
}
public function GetProxyCount():int{
return (m_broadPhase.m_proxyCount);
}
public function GetPairCount():int{
return (m_broadPhase.m_pairManager.m_pairCount);
}
public function CreateBody(def:b2BodyDef):b2Body{
if (m_lock == true){
return (null);
};
var b:b2Body = new b2Body(def, this);
b.m_prev = null;
b.m_next = m_bodyList;
if (m_bodyList){
m_bodyList.m_prev = b;
};
m_bodyList = b;
m_bodyCount++;
return (b);
}
public function DestroyBody(b:b2Body):void{
var jn0:b2JointEdge;
var s0:b2Shape;
if (m_lock == true){
return;
};
var jn:b2JointEdge = b.m_jointList;
while (jn) {
jn0 = jn;
jn = jn.next;
if (m_destructionListener){
m_destructionListener.SayGoodbyeJoint(jn0.joint);
};
DestroyJoint(jn0.joint);
};
var s:b2Shape = b.m_shapeList;
while (s) {
s0 = s;
s = s.m_next;
if (m_destructionListener){
m_destructionListener.SayGoodbyeShape(s0);
};
s0.DestroyProxy(m_broadPhase);
b2Shape.Destroy(s0, m_blockAllocator);
};
if (b.m_prev){
b.m_prev.m_next = b.m_next;
};
if (b.m_next){
b.m_next.m_prev = b.m_prev;
};
if (b == m_bodyList){
m_bodyList = b.m_next;
};
m_bodyCount--;
}
public function CreateJoint(def:b2JointDef):b2Joint{
var b:b2Body;
var s:b2Shape;
var j:b2Joint = b2Joint.Create(def, m_blockAllocator);
j.m_prev = null;
j.m_next = m_jointList;
if (m_jointList){
m_jointList.m_prev = j;
};
m_jointList = j;
m_jointCount++;
j.m_node1.joint = j;
j.m_node1.other = j.m_body2;
j.m_node1.prev = null;
j.m_node1.next = j.m_body1.m_jointList;
if (j.m_body1.m_jointList){
j.m_body1.m_jointList.prev = j.m_node1;
};
j.m_body1.m_jointList = j.m_node1;
j.m_node2.joint = j;
j.m_node2.other = j.m_body1;
j.m_node2.prev = null;
j.m_node2.next = j.m_body2.m_jointList;
if (j.m_body2.m_jointList){
j.m_body2.m_jointList.prev = j.m_node2;
};
j.m_body2.m_jointList = j.m_node2;
if (def.collideConnected == false){
b = ((def.body1.m_shapeCount < def.body2.m_shapeCount)) ? def.body1 : def.body2;
s = b.m_shapeList;
while (s) {
s.RefilterProxy(m_broadPhase, b.m_xf);
s = s.m_next;
};
};
return (j);
}
public function DestroyJoint(j:b2Joint):void{
var b:b2Body;
var s:b2Shape;
var collideConnected:Boolean = j.m_collideConnected;
if (j.m_prev){
j.m_prev.m_next = j.m_next;
};
if (j.m_next){
j.m_next.m_prev = j.m_prev;
};
if (j == m_jointList){
m_jointList = j.m_next;
};
var body1:b2Body = j.m_body1;
var body2:b2Body = j.m_body2;
body1.WakeUp();
body2.WakeUp();
if (j.m_node1.prev){
j.m_node1.prev.next = j.m_node1.next;
};
if (j.m_node1.next){
j.m_node1.next.prev = j.m_node1.prev;
};
if (j.m_node1 == body1.m_jointList){
body1.m_jointList = j.m_node1.next;
};
j.m_node1.prev = null;
j.m_node1.next = null;
if (j.m_node2.prev){
j.m_node2.prev.next = j.m_node2.next;
};
if (j.m_node2.next){
j.m_node2.next.prev = j.m_node2.prev;
};
if (j.m_node2 == body2.m_jointList){
body2.m_jointList = j.m_node2.next;
};
j.m_node2.prev = null;
j.m_node2.next = null;
b2Joint.Destroy(j, m_blockAllocator);
m_jointCount--;
if (collideConnected == false){
b = ((body1.m_shapeCount < body2.m_shapeCount)) ? body1 : body2;
s = b.m_shapeList;
while (s) {
s.RefilterProxy(m_broadPhase, b.m_xf);
s = s.m_next;
};
};
}
public function Refilter(shape:b2Shape):void{
shape.RefilterProxy(m_broadPhase, shape.m_body.m_xf);
}
public function SetWarmStarting(flag:Boolean):void{
m_warmStarting = flag;
}
public function SetPositionCorrection(flag:Boolean):void{
m_positionCorrection = flag;
}
public function SetContinuousPhysics(flag:Boolean):void{
m_continuousPhysics = flag;
}
public function GetBodyCount():int{
return (m_bodyCount);
}
public function GetJointCount():int{
return (m_jointCount);
}
public function GetContactCount():int{
return (m_contactCount);
}
public function SetGravity(gravity:b2Vec2):void{
m_gravity = gravity;
}
public function GetGroundBody():b2Body{
return (m_groundBody);
}
public function Step(dt:Number, iterations:int):void{
m_lock = true;
var step:b2TimeStep = new b2TimeStep();
step.dt = dt;
step.maxIterations = iterations;
if (dt > 0){
step.inv_dt = (1 / dt);
} else {
step.inv_dt = 0;
};
step.dtRatio = (m_inv_dt0 * dt);
step.positionCorrection = m_positionCorrection;
step.warmStarting = m_warmStarting;
m_contactManager.Collide();
if (step.dt > 0){
Solve(step);
};
if (((m_continuousPhysics) && ((step.dt > 0)))){
SolveTOI(step);
};
DrawDebugData();
m_inv_dt0 = step.inv_dt;
m_lock = false;
}
public function Query(aabb:b2AABB, shapes:Array, maxCount:int):int{
var results:Array = new Array(maxCount);
var count:int = m_broadPhase.QueryAABB(aabb, results, maxCount);
var i:int;
while (i < count) {
shapes[i] = results[i];
i++;
};
return (count);
}
public function GetBodyList():b2Body{
return (m_bodyList);
}
public function GetJointList():b2Joint{
return (m_jointList);
}
public function Solve(step:b2TimeStep):void{
var b:b2Body;
var stackCount:int;
var i:int;
var other:b2Body;
var cn:b2ContactEdge;
var jn:b2JointEdge;
var inRange:Boolean;
m_positionIterationCount = 0;
var island:b2Island = new b2Island(m_bodyCount, m_contactCount, m_jointCount, m_stackAllocator, m_contactListener);
b = m_bodyList;
while (b) {
b.m_flags = (b.m_flags & ~(b2Body.e_islandFlag));
b = b.m_next;
};
var c:b2Contact = m_contactList;
while (c) {
c.m_flags = (c.m_flags & ~(b2Contact.e_islandFlag));
c = c.m_next;
};
var j:b2Joint = m_jointList;
while (j) {
j.m_islandFlag = false;
j = j.m_next;
};
var stackSize:int = m_bodyCount;
var stack:Array = new Array(stackSize);
var seed:b2Body = m_bodyList;
while (seed) {
if ((seed.m_flags & ((b2Body.e_islandFlag | b2Body.e_sleepFlag) | b2Body.e_frozenFlag))){
} else {
if (seed.IsStatic()){
} else {
island.Clear();
stackCount = 0;
var _temp1 = stackCount;
stackCount = (stackCount + 1);
var _local15 = _temp1;
stack[_local15] = seed;
seed.m_flags = (seed.m_flags | b2Body.e_islandFlag);
while (stackCount > 0) {
--stackCount;
b = stack[stackCount];
island.AddBody(b);
b.m_flags = (b.m_flags & ~(b2Body.e_sleepFlag));
if (b.IsStatic()){
} else {
cn = b.m_contactList;
while (cn) {
if ((cn.contact.m_flags & (b2Contact.e_islandFlag | b2Contact.e_nonSolidFlag))){
} else {
if (cn.contact.m_manifoldCount == 0){
} else {
island.AddContact(cn.contact);
cn.contact.m_flags = (cn.contact.m_flags | b2Contact.e_islandFlag);
other = cn.other;
if ((other.m_flags & b2Body.e_islandFlag)){
} else {
var _temp2 = stackCount;
stackCount = (stackCount + 1);
var _local16 = _temp2;
stack[_local16] = other;
other.m_flags = (other.m_flags | b2Body.e_islandFlag);
};
};
};
cn = cn.next;
};
jn = b.m_jointList;
while (jn) {
if (jn.joint.m_islandFlag == true){
} else {
island.AddJoint(jn.joint);
jn.joint.m_islandFlag = true;
other = jn.other;
if ((other.m_flags & b2Body.e_islandFlag)){
} else {
var _temp3 = stackCount;
stackCount = (stackCount + 1);
_local16 = _temp3;
stack[_local16] = other;
other.m_flags = (other.m_flags | b2Body.e_islandFlag);
};
};
jn = jn.next;
};
};
};
island.Solve(step, m_gravity, m_positionCorrection, m_allowSleep);
if (island.m_positionIterationCount > m_positionIterationCount){
m_positionIterationCount = island.m_positionIterationCount;
};
i = 0;
while (i < island.m_bodyCount) {
b = island.m_bodies[i];
if (b.IsStatic()){
b.m_flags = (b.m_flags & ~(b2Body.e_islandFlag));
};
i++;
};
};
};
seed = seed.m_next;
};
b = m_bodyList;
while (b) {
if ((b.m_flags & (b2Body.e_sleepFlag | b2Body.e_frozenFlag))){
} else {
if (b.IsStatic()){
} else {
inRange = b.SynchronizeShapes();
if ((((inRange == false)) && (!((m_boundaryListener == null))))){
m_boundaryListener.Violation(b);
};
};
};
b = b.m_next;
};
m_broadPhase.Commit();
}
public function SolveTOI(step:b2TimeStep):void{
var b:b2Body;
var s1:b2Shape;
var s2:b2Shape;
var b1:b2Body;
var b2:b2Body;
var cn:b2ContactEdge;
var c:b2Contact;
var minContact:b2Contact;
var minTOI:Number;
var seed:b2Body;
var stackCount:int;
var subStep:b2TimeStep;
var i:int;
var toi:Number;
var t0:Number;
var other:b2Body;
var inRange:Boolean;
var island:b2Island = new b2Island(m_bodyCount, b2Settings.b2_maxTOIContactsPerIsland, 0, m_stackAllocator, m_contactListener);
var stackSize:int = m_bodyCount;
var stack:Array = new Array(stackSize);
b = m_bodyList;
while (b) {
b.m_flags = (b.m_flags & ~(b2Body.e_islandFlag));
b.m_sweep.t0 = 0;
b = b.m_next;
};
c = m_contactList;
while (c) {
c.m_flags = (c.m_flags & ~((b2Contact.e_toiFlag | b2Contact.e_islandFlag)));
c = c.m_next;
};
while (true) {
minContact = null;
minTOI = 1;
c = m_contactList;
for (;c;(c = c.m_next)) {
if ((c.m_flags & (b2Contact.e_slowFlag | b2Contact.e_nonSolidFlag))){
} else {
toi = 1;
if ((c.m_flags & b2Contact.e_toiFlag)){
toi = c.m_toi;
} else {
s1 = c.m_shape1;
s2 = c.m_shape2;
b1 = s1.m_body;
b2 = s2.m_body;
if (((((b1.IsStatic()) || (b1.IsSleeping()))) && (((b2.IsStatic()) || (b2.IsSleeping()))))){
continue;
};
t0 = b1.m_sweep.t0;
if (b1.m_sweep.t0 < b2.m_sweep.t0){
t0 = b2.m_sweep.t0;
b1.m_sweep.Advance(t0);
} else {
if (b2.m_sweep.t0 < b1.m_sweep.t0){
t0 = b1.m_sweep.t0;
b2.m_sweep.Advance(t0);
};
};
toi = b2TimeOfImpact.TimeOfImpact(c.m_shape1, b1.m_sweep, c.m_shape2, b2.m_sweep);
if ((((toi > 0)) && ((toi < 1)))){
toi = (((1 - toi) * t0) + toi);
if (toi > 1){
toi = 1;
};
};
c.m_toi = toi;
c.m_flags = (c.m_flags | b2Contact.e_toiFlag);
};
if ((((Number.MIN_VALUE < toi)) && ((toi < minTOI)))){
minContact = c;
minTOI = toi;
};
};
};
if ((((minContact == null)) || (((1 - (100 * Number.MIN_VALUE)) < minTOI)))){
break;
};
s1 = minContact.m_shape1;
s2 = minContact.m_shape2;
b1 = s1.m_body;
b2 = s2.m_body;
b1.Advance(minTOI);
b2.Advance(minTOI);
minContact.Update(m_contactListener);
minContact.m_flags = (minContact.m_flags & ~(b2Contact.e_toiFlag));
if (minContact.m_manifoldCount == 0){
} else {
seed = b1;
if (seed.IsStatic()){
seed = b2;
};
island.Clear();
stackCount = 0;
var _temp1 = stackCount;
stackCount = (stackCount + 1);
var _local22 = _temp1;
stack[_local22] = seed;
seed.m_flags = (seed.m_flags | b2Body.e_islandFlag);
while (stackCount > 0) {
--stackCount;
b = stack[stackCount];
island.AddBody(b);
b.m_flags = (b.m_flags & ~(b2Body.e_sleepFlag));
if (b.IsStatic()){
} else {
cn = b.m_contactList;
while (cn) {
if (island.m_contactCount == island.m_contactCapacity){
} else {
if ((cn.contact.m_flags & ((b2Contact.e_islandFlag | b2Contact.e_slowFlag) | b2Contact.e_nonSolidFlag))){
} else {
if (cn.contact.m_manifoldCount == 0){
} else {
island.AddContact(cn.contact);
cn.contact.m_flags = (cn.contact.m_flags | b2Contact.e_islandFlag);
other = cn.other;
if ((other.m_flags & b2Body.e_islandFlag)){
} else {
if (other.IsStatic() == false){
other.Advance(minTOI);
other.WakeUp();
};
var _temp2 = stackCount;
stackCount = (stackCount + 1);
var _local23 = _temp2;
stack[_local23] = other;
other.m_flags = (other.m_flags | b2Body.e_islandFlag);
};
};
};
};
cn = cn.next;
};
};
};
subStep = new b2TimeStep();
subStep.dt = ((1 - minTOI) * step.dt);
subStep.inv_dt = (1 / subStep.dt);
subStep.maxIterations = step.maxIterations;
island.SolveTOI(subStep);
i = 0;
while (i < island.m_bodyCount) {
b = island.m_bodies[i];
b.m_flags = (b.m_flags & ~(b2Body.e_islandFlag));
if ((b.m_flags & (b2Body.e_sleepFlag | b2Body.e_frozenFlag))){
} else {
if (b.IsStatic()){
} else {
inRange = b.SynchronizeShapes();
if ((((inRange == false)) && (!((m_boundaryListener == null))))){
m_boundaryListener.Violation(b);
};
cn = b.m_contactList;
while (cn) {
cn.contact.m_flags = (cn.contact.m_flags & ~(b2Contact.e_toiFlag));
cn = cn.next;
};
};
};
i++;
};
i = 0;
while (i < island.m_contactCount) {
c = island.m_contacts[i];
c.m_flags = (c.m_flags & ~((b2Contact.e_toiFlag | b2Contact.e_islandFlag)));
i++;
};
m_broadPhase.Commit();
};
};
}
public function DrawJoint(joint:b2Joint):void{
var pulley:b2PulleyJoint;
var s1:b2Vec2;
var s2:b2Vec2;
var b1:b2Body = joint.m_body1;
var b2:b2Body = joint.m_body2;
var xf1:b2XForm = b1.m_xf;
var xf2:b2XForm = b2.m_xf;
var x1:b2Vec2 = xf1.position;
var x2:b2Vec2 = xf2.position;
var p1:b2Vec2 = joint.GetAnchor1();
var p2:b2Vec2 = joint.GetAnchor2();
var color:b2Color = s_jointColor;
switch (joint.m_type){
case b2Joint.e_distanceJoint:
m_debugDraw.DrawSegment(p1, p2, color);
break;
case b2Joint.e_pulleyJoint:
pulley = (joint as b2PulleyJoint);
s1 = pulley.GetGroundAnchor1();
s2 = pulley.GetGroundAnchor2();
m_debugDraw.DrawSegment(s1, p1, color);
m_debugDraw.DrawSegment(s2, p2, color);
m_debugDraw.DrawSegment(s1, s2, color);
break;
case b2Joint.e_mouseJoint:
m_debugDraw.DrawSegment(p1, p2, color);
break;
default:
if (b1 != m_groundBody){
m_debugDraw.DrawSegment(x1, p1, color);
};
m_debugDraw.DrawSegment(p1, p2, color);
if (b2 != m_groundBody){
m_debugDraw.DrawSegment(x2, p2, color);
};
};
}
public function DrawShape(shape:b2Shape, xf:b2XForm, color:b2Color, core:Boolean):void{
var circle:b2CircleShape;
var center:b2Vec2;
var radius:Number;
var axis:b2Vec2;
var i:int;
var poly:b2PolygonShape;
var vertexCount:int;
var localVertices:Array;
var vertices:Array;
var localCoreVertices:Array;
var coreColor:b2Color = s_coreColor;
switch (shape.m_type){
case b2Shape.e_circleShape:
circle = (shape as b2CircleShape);
center = b2Math.b2MulX(xf, circle.m_localPosition);
radius = circle.m_radius;
axis = xf.R.col1;
m_debugDraw.DrawSolidCircle(center, radius, axis, color);
if (core){
m_debugDraw.DrawCircle(center, (radius - b2Settings.b2_toiSlop), coreColor);
};
break;
case b2Shape.e_polygonShape:
poly = (shape as b2PolygonShape);
vertexCount = poly.GetVertexCount();
localVertices = poly.GetVertices();
vertices = new Array(b2Settings.b2_maxPolygonVertices);
i = 0;
while (i < vertexCount) {
vertices[i] = b2Math.b2MulX(xf, localVertices[i]);
i++;
};
m_debugDraw.DrawSolidPolygon(vertices, vertexCount, color);
if (core){
localCoreVertices = poly.GetCoreVertices();
i = 0;
while (i < vertexCount) {
vertices[i] = b2Math.b2MulX(xf, localCoreVertices[i]);
i++;
};
m_debugDraw.DrawPolygon(vertices, vertexCount, coreColor);
};
break;
};
}
public function DrawDebugData():void{
var i:int;
var b:b2Body;
var s:b2Shape;
var j:b2Joint;
var bp:b2BroadPhase;
var xf:b2XForm;
var core:Boolean;
var index:uint;
var pair:b2Pair;
var p1:b2Proxy;
var p2:b2Proxy;
var worldLower:b2Vec2;
var worldUpper:b2Vec2;
var p:b2Proxy;
var poly:b2PolygonShape;
var obb:b2OBB;
var h:b2Vec2;
var tMat:b2Mat22;
var tVec:b2Vec2;
var tX:Number;
if (m_debugDraw == null){
return;
};
m_debugDraw.m_sprite.graphics.clear();
var flags:uint = m_debugDraw.GetFlags();
var invQ:b2Vec2 = new b2Vec2();
var x1:b2Vec2 = new b2Vec2();
var x2:b2Vec2 = new b2Vec2();
var color:b2Color = new b2Color(0, 0, 0);
var b1:b2AABB = new b2AABB();
var b2:b2AABB = new b2AABB();
var vs:Array = [new b2Vec2(), new b2Vec2(), new b2Vec2(), new b2Vec2()];
if ((flags & b2DebugDraw.e_shapeBit)){
core = ((flags & b2DebugDraw.e_coreShapeBit) == b2DebugDraw.e_coreShapeBit);
b = m_bodyList;
while (b) {
xf = b.m_xf;
s = b.GetShapeList();
while (s) {
if (b.IsStatic()){
DrawShape(s, xf, new b2Color(0.5, 0.9, 0.5), core);
} else {
if (b.IsSleeping()){
DrawShape(s, xf, new b2Color(0.5, 0.5, 0.9), core);
} else {
DrawShape(s, xf, new b2Color(0.9, 0.9, 0.9), core);
};
};
s = s.m_next;
};
b = b.m_next;
};
};
if ((flags & b2DebugDraw.e_jointBit)){
j = m_jointList;
while (j) {
DrawJoint(j);
j = j.m_next;
};
};
if ((flags & b2DebugDraw.e_pairBit)){
bp = m_broadPhase;
invQ.Set((1 / bp.m_quantizationFactor.x), (1 / bp.m_quantizationFactor.y));
color.Set(0.9, 0.9, 0.3);
i = 0;
while (i < b2Pair.b2_tableCapacity) {
index = bp.m_pairManager.m_hashTable[i];
while (index != b2Pair.b2_nullPair) {
pair = bp.m_pairManager.m_pairs[index];
p1 = bp.m_proxyPool[pair.proxyId1];
p2 = bp.m_proxyPool[pair.proxyId2];
b1.lowerBound.x = (bp.m_worldAABB.lowerBound.x + (invQ.x * bp.m_bounds[0][p1.lowerBounds[0]].value));
b1.lowerBound.y = (bp.m_worldAABB.lowerBound.y + (invQ.y * bp.m_bounds[1][p1.lowerBounds[1]].value));
b1.upperBound.x = (bp.m_worldAABB.lowerBound.x + (invQ.x * bp.m_bounds[0][p1.upperBounds[0]].value));
b1.upperBound.y = (bp.m_worldAABB.lowerBound.y + (invQ.y * bp.m_bounds[1][p1.upperBounds[1]].value));
b2.lowerBound.x = (bp.m_worldAABB.lowerBound.x + (invQ.x * bp.m_bounds[0][p2.lowerBounds[0]].value));
b2.lowerBound.y = (bp.m_worldAABB.lowerBound.y + (invQ.y * bp.m_bounds[1][p2.lowerBounds[1]].value));
b2.upperBound.x = (bp.m_worldAABB.lowerBound.x + (invQ.x * bp.m_bounds[0][p2.upperBounds[0]].value));
b2.upperBound.y = (bp.m_worldAABB.lowerBound.y + (invQ.y * bp.m_bounds[1][p2.upperBounds[1]].value));
x1.x = (0.5 * (b1.lowerBound.x + b1.upperBound.x));
x1.y = (0.5 * (b1.lowerBound.y + b1.upperBound.y));
x2.x = (0.5 * (b2.lowerBound.x + b2.upperBound.x));
x2.y = (0.5 * (b2.lowerBound.y + b2.upperBound.y));
m_debugDraw.DrawSegment(x1, x2, color);
index = pair.next;
};
i++;
};
};
if ((flags & b2DebugDraw.e_aabbBit)){
bp = m_broadPhase;
worldLower = bp.m_worldAABB.lowerBound;
worldUpper = bp.m_worldAABB.upperBound;
invQ.Set((1 / bp.m_quantizationFactor.x), (1 / bp.m_quantizationFactor.y));
color.Set(0.9, 0.3, 0.9);
i = 0;
while (i < b2Settings.b2_maxProxies) {
p = bp.m_proxyPool[i];
if (p.IsValid() == false){
} else {
b1.lowerBound.x = (worldLower.x + (invQ.x * bp.m_bounds[0][p.lowerBounds[0]].value));
b1.lowerBound.y = (worldLower.y + (invQ.y * bp.m_bounds[1][p.lowerBounds[1]].value));
b1.upperBound.x = (worldLower.x + (invQ.x * bp.m_bounds[0][p.upperBounds[0]].value));
b1.upperBound.y = (worldLower.y + (invQ.y * bp.m_bounds[1][p.upperBounds[1]].value));
vs[0].Set(b1.lowerBound.x, b1.lowerBound.y);
vs[1].Set(b1.upperBound.x, b1.lowerBound.y);
vs[2].Set(b1.upperBound.x, b1.upperBound.y);
vs[3].Set(b1.lowerBound.x, b1.upperBound.y);
m_debugDraw.DrawPolygon(vs, 4, color);
};
i++;
};
vs[0].Set(worldLower.x, worldLower.y);
vs[1].Set(worldUpper.x, worldLower.y);
vs[2].Set(worldUpper.x, worldUpper.y);
vs[3].Set(worldLower.x, worldUpper.y);
m_debugDraw.DrawPolygon(vs, 4, new b2Color(0.3, 0.9, 0.9));
};
if ((flags & b2DebugDraw.e_obbBit)){
color.Set(0.5, 0.3, 0.5);
b = m_bodyList;
while (b) {
xf = b.m_xf;
s = b.GetShapeList();
while (s) {
if (s.m_type != b2Shape.e_polygonShape){
} else {
poly = (s as b2PolygonShape);
obb = poly.GetOBB();
h = obb.extents;
vs[0].Set(-(h.x), -(h.y));
vs[1].Set(h.x, -(h.y));
vs[2].Set(h.x, h.y);
vs[3].Set(-(h.x), h.y);
i = 0;
while (i < 4) {
tMat = obb.R;
tVec = vs[i];
tX = (obb.center.x + ((tMat.col1.x * tVec.x) + (tMat.col2.x * tVec.y)));
vs[i].y = (obb.center.y + ((tMat.col1.y * tVec.x) + (tMat.col2.y * tVec.y)));
vs[i].x = tX;
tMat = xf.R;
tX = (xf.position.x + ((tMat.col1.x * tVec.x) + (tMat.col2.x * tVec.y)));
vs[i].y = (xf.position.y + ((tMat.col1.y * tVec.x) + (tMat.col2.y * tVec.y)));
vs[i].x = tX;
i++;
};
m_debugDraw.DrawPolygon(vs, 4, color);
};
s = s.m_next;
};
b = b.m_next;
};
};
if ((flags & b2DebugDraw.e_centerOfMassBit)){
b = m_bodyList;
while (b) {
xf = s_xf;
xf.R = b.m_xf.R;
xf.position = b.GetWorldCenter();
m_debugDraw.DrawXForm(xf);
b = b.m_next;
};
};
}
}
}//package Box2D.Dynamics
Section 76
//AuxFunctions (caurina.transitions.AuxFunctions)
package caurina.transitions {
public class AuxFunctions {
public static function numberToR(p_num:Number):Number{
return (((p_num & 0xFF0000) >> 16));
}
public static function numberToG(p_num:Number):Number{
return (((p_num & 0xFF00) >> 8));
}
public static function numberToB(p_num:Number):Number{
return ((p_num & 0xFF));
}
public static function getObjectLength(p_object:Object):uint{
var pName:String;
var totalProperties:uint;
for (pName in p_object) {
totalProperties++;
};
return (totalProperties);
}
public static function concatObjects(... _args):Object{
var currentObject:Object;
var prop:String;
var finalObject:Object = {};
var i:int;
while (i < _args.length) {
currentObject = _args[i];
for (prop in currentObject) {
if (currentObject[prop] == null){
delete finalObject[prop];
} else {
finalObject[prop] = currentObject[prop];
};
};
i++;
};
return (finalObject);
}
}
}//package caurina.transitions
Section 77
//Equations (caurina.transitions.Equations)
package caurina.transitions {
public class Equations {
public function Equations(){
super();
trace("Equations is a static class and should not be instantiated.");
}
public static function init():void{
Tweener.registerTransition("easenone", easeNone);
Tweener.registerTransition("linear", easeNone);
Tweener.registerTransition("easeinquad", easeInQuad);
Tweener.registerTransition("easeoutquad", easeOutQuad);
Tweener.registerTransition("easeinoutquad", easeInOutQuad);
Tweener.registerTransition("easeoutinquad", easeOutInQuad);
Tweener.registerTransition("easeincubic", easeInCubic);
Tweener.registerTransition("easeoutcubic", easeOutCubic);
Tweener.registerTransition("easeinoutcubic", easeInOutCubic);
Tweener.registerTransition("easeoutincubic", easeOutInCubic);
Tweener.registerTransition("easeinquart", easeInQuart);
Tweener.registerTransition("easeoutquart", easeOutQuart);
Tweener.registerTransition("easeinoutquart", easeInOutQuart);
Tweener.registerTransition("easeoutinquart", easeOutInQuart);
Tweener.registerTransition("easeinquint", easeInQuint);
Tweener.registerTransition("easeoutquint", easeOutQuint);
Tweener.registerTransition("easeinoutquint", easeInOutQuint);
Tweener.registerTransition("easeoutinquint", easeOutInQuint);
Tweener.registerTransition("easeinsine", easeInSine);
Tweener.registerTransition("easeoutsine", easeOutSine);
Tweener.registerTransition("easeinoutsine", easeInOutSine);
Tweener.registerTransition("easeoutinsine", easeOutInSine);
Tweener.registerTransition("easeincirc", easeInCirc);
Tweener.registerTransition("easeoutcirc", easeOutCirc);
Tweener.registerTransition("easeinoutcirc", easeInOutCirc);
Tweener.registerTransition("easeoutincirc", easeOutInCirc);
Tweener.registerTransition("easeinexpo", easeInExpo);
Tweener.registerTransition("easeoutexpo", easeOutExpo);
Tweener.registerTransition("easeinoutexpo", easeInOutExpo);
Tweener.registerTransition("easeoutinexpo", easeOutInExpo);
Tweener.registerTransition("easeinelastic", easeInElastic);
Tweener.registerTransition("easeoutelastic", easeOutElastic);
Tweener.registerTransition("easeinoutelastic", easeInOutElastic);
Tweener.registerTransition("easeoutinelastic", easeOutInElastic);
Tweener.registerTransition("easeinback", easeInBack);
Tweener.registerTransition("easeoutback", easeOutBack);
Tweener.registerTransition("easeinoutback", easeInOutBack);
Tweener.registerTransition("easeoutinback", easeOutInBack);
Tweener.registerTransition("easeinbounce", easeInBounce);
Tweener.registerTransition("easeoutbounce", easeOutBounce);
Tweener.registerTransition("easeinoutbounce", easeInOutBounce);
Tweener.registerTransition("easeoutinbounce", easeOutInBounce);
}
public static function easeNone(t:Number, b:Number, c:Number, d:Number, p_params:Object=null):Number{
return ((((c * t) / d) + b));
}
public static function easeInQuad(t:Number, b:Number, c:Number, d:Number, p_params:Object=null):Number{
t = (t / d);
return ((((c * t) * t) + b));
}
public static function easeOutQuad(t:Number, b:Number, c:Number, d:Number, p_params:Object=null):Number{
t = (t / d);
return ((((-(c) * t) * (t - 2)) + b));
}
public static function easeInOutQuad(t:Number, b:Number, c:Number, d:Number, p_params:Object=null):Number{
t = (t / (d / 2));
if (t < 1){
return (((((c / 2) * t) * t) + b));
};
--t;
return ((((-(c) / 2) * ((t * (t - 2)) - 1)) + b));
}
public static function easeOutInQuad(t:Number, b:Number, c:Number, d:Number, p_params:Object=null):Number{
if (t < (d / 2)){
return (easeOutQuad((t * 2), b, (c / 2), d, p_params));
};
return (easeInQuad(((t * 2) - d), (b + (c / 2)), (c / 2), d, p_params));
}
public static function easeInCubic(t:Number, b:Number, c:Number, d:Number, p_params:Object=null):Number{
t = (t / d);
return (((((c * t) * t) * t) + b));
}
public static function easeOutCubic(t:Number, b:Number, c:Number, d:Number, p_params:Object=null):Number{
t = ((t / d) - 1);
return (((c * (((t * t) * t) + 1)) + b));
}
public static function easeInOutCubic(t:Number, b:Number, c:Number, d:Number, p_params:Object=null):Number{
t = (t / (d / 2));
if (t < 1){
return ((((((c / 2) * t) * t) * t) + b));
};
t = (t - 2);
return ((((c / 2) * (((t * t) * t) + 2)) + b));
}
public static function easeOutInCubic(t:Number, b:Number, c:Number, d:Number, p_params:Object=null):Number{
if (t < (d / 2)){
return (easeOutCubic((t * 2), b, (c / 2), d, p_params));
};
return (easeInCubic(((t * 2) - d), (b + (c / 2)), (c / 2), d, p_params));
}
public static function easeInQuart(t:Number, b:Number, c:Number, d:Number, p_params:Object=null):Number{
t = (t / d);
return ((((((c * t) * t) * t) * t) + b));
}
public static function easeOutQuart(t:Number, b:Number, c:Number, d:Number, p_params:Object=null):Number{
t = ((t / d) - 1);
return (((-(c) * ((((t * t) * t) * t) - 1)) + b));
}
public static function easeInOutQuart(t:Number, b:Number, c:Number, d:Number, p_params:Object=null):Number{
t = (t / (d / 2));
if (t < 1){
return (((((((c / 2) * t) * t) * t) * t) + b));
};
t = (t - 2);
return ((((-(c) / 2) * ((((t * t) * t) * t) - 2)) + b));
}
public static function easeOutInQuart(t:Number, b:Number, c:Number, d:Number, p_params:Object=null):Number{
if (t < (d / 2)){
return (easeOutQuart((t * 2), b, (c / 2), d, p_params));
};
return (easeInQuart(((t * 2) - d), (b + (c / 2)), (c / 2), d, p_params));
}
public static function easeInQuint(t:Number, b:Number, c:Number, d:Number, p_params:Object=null):Number{
t = (t / d);
return (((((((c * t) * t) * t) * t) * t) + b));
}
public static function easeOutQuint(t:Number, b:Number, c:Number, d:Number, p_params:Object=null):Number{
t = ((t / d) - 1);
return (((c * (((((t * t) * t) * t) * t) + 1)) + b));
}
public static function easeInOutQuint(t:Number, b:Number, c:Number, d:Number, p_params:Object=null):Number{
t = (t / (d / 2));
if (t < 1){
return ((((((((c / 2) * t) * t) * t) * t) * t) + b));
};
t = (t - 2);
return ((((c / 2) * (((((t * t) * t) * t) * t) + 2)) + b));
}
public static function easeOutInQuint(t:Number, b:Number, c:Number, d:Number, p_params:Object=null):Number{
if (t < (d / 2)){
return (easeOutQuint((t * 2), b, (c / 2), d, p_params));
};
return (easeInQuint(((t * 2) - d), (b + (c / 2)), (c / 2), d, p_params));
}
public static function easeInSine(t:Number, b:Number, c:Number, d:Number, p_params:Object=null):Number{
return ((((-(c) * Math.cos(((t / d) * (Math.PI / 2)))) + c) + b));
}
public static function easeOutSine(t:Number, b:Number, c:Number, d:Number, p_params:Object=null):Number{
return (((c * Math.sin(((t / d) * (Math.PI / 2)))) + b));
}
public static function easeInOutSine(t:Number, b:Number, c:Number, d:Number, p_params:Object=null):Number{
return ((((-(c) / 2) * (Math.cos(((Math.PI * t) / d)) - 1)) + b));
}
public static function easeOutInSine(t:Number, b:Number, c:Number, d:Number, p_params:Object=null):Number{
if (t < (d / 2)){
return (easeOutSine((t * 2), b, (c / 2), d, p_params));
};
return (easeInSine(((t * 2) - d), (b + (c / 2)), (c / 2), d, p_params));
}
public static function easeInExpo(t:Number, b:Number, c:Number, d:Number, p_params:Object=null):Number{
return (((t)==0) ? b : (((c * Math.pow(2, (10 * ((t / d) - 1)))) + b) - (c * 0.001)));
}
public static function easeOutExpo(t:Number, b:Number, c:Number, d:Number, p_params:Object=null):Number{
return (((t)==d) ? (b + c) : (((c * 1.001) * (-(Math.pow(2, ((-10 * t) / d))) + 1)) + b));
}
public static function easeInOutExpo(t:Number, b:Number, c:Number, d:Number, p_params:Object=null):Number{
if (t == 0){
return (b);
};
if (t == d){
return ((b + c));
};
t = (t / (d / 2));
if (t < 1){
return (((((c / 2) * Math.pow(2, (10 * (t - 1)))) + b) - (c * 0.0005)));
};
--t;
return (((((c / 2) * 1.0005) * (-(Math.pow(2, (-10 * t))) + 2)) + b));
}
public static function easeOutInExpo(t:Number, b:Number, c:Number, d:Number, p_params:Object=null):Number{
if (t < (d / 2)){
return (easeOutExpo((t * 2), b, (c / 2), d, p_params));
};
return (easeInExpo(((t * 2) - d), (b + (c / 2)), (c / 2), d, p_params));
}
public static function easeInCirc(t:Number, b:Number, c:Number, d:Number, p_params:Object=null):Number{
t = (t / d);
return (((-(c) * (Math.sqrt((1 - (t * t))) - 1)) + b));
}
public static function easeOutCirc(t:Number, b:Number, c:Number, d:Number, p_params:Object=null):Number{
t = ((t / d) - 1);
return (((c * Math.sqrt((1 - (t * t)))) + b));
}
public static function easeInOutCirc(t:Number, b:Number, c:Number, d:Number, p_params:Object=null):Number{
t = (t / (d / 2));
if (t < 1){
return ((((-(c) / 2) * (Math.sqrt((1 - (t * t))) - 1)) + b));
};
t = (t - 2);
return ((((c / 2) * (Math.sqrt((1 - (t * t))) + 1)) + b));
}
public static function easeOutInCirc(t:Number, b:Number, c:Number, d:Number, p_params:Object=null):Number{
if (t < (d / 2)){
return (easeOutCirc((t * 2), b, (c / 2), d, p_params));
};
return (easeInCirc(((t * 2) - d), (b + (c / 2)), (c / 2), d, p_params));
}
public static function easeInElastic(t:Number, b:Number, c:Number, d:Number, p_params:Object=null):Number{
var s:Number;
if (t == 0){
return (b);
};
t = (t / d);
if (t == 1){
return ((b + c));
};
var p:Number = (((!(Boolean(p_params))) || (isNaN(p_params.period)))) ? (d * 0.3) : p_params.period;
var a:Number = (((!(Boolean(p_params))) || (isNaN(p_params.amplitude)))) ? 0 : p_params.amplitude;
if (((!(Boolean(a))) || ((a < Math.abs(c))))){
a = c;
s = (p / 4);
} else {
s = ((p / (2 * Math.PI)) * Math.asin((c / a)));
};
--t;
return ((-(((a * Math.pow(2, (10 * t))) * Math.sin(((((t * d) - s) * (2 * Math.PI)) / p)))) + b));
}
public static function easeOutElastic(t:Number, b:Number, c:Number, d:Number, p_params:Object=null):Number{
var s:Number;
if (t == 0){
return (b);
};
t = (t / d);
if (t == 1){
return ((b + c));
};
var p:Number = (((!(Boolean(p_params))) || (isNaN(p_params.period)))) ? (d * 0.3) : p_params.period;
var a:Number = (((!(Boolean(p_params))) || (isNaN(p_params.amplitude)))) ? 0 : p_params.amplitude;
if (((!(Boolean(a))) || ((a < Math.abs(c))))){
a = c;
s = (p / 4);
} else {
s = ((p / (2 * Math.PI)) * Math.asin((c / a)));
};
return (((((a * Math.pow(2, (-10 * t))) * Math.sin(((((t * d) - s) * (2 * Math.PI)) / p))) + c) + b));
}
public static function easeInOutElastic(t:Number, b:Number, c:Number, d:Number, p_params:Object=null):Number{
var s:Number;
if (t == 0){
return (b);
};
t = (t / (d / 2));
if (t == 2){
return ((b + c));
};
var p:Number = (((!(Boolean(p_params))) || (isNaN(p_params.period)))) ? (d * (0.3 * 1.5)) : p_params.period;
var a:Number = (((!(Boolean(p_params))) || (isNaN(p_params.amplitude)))) ? 0 : p_params.amplitude;
if (((!(Boolean(a))) || ((a < Math.abs(c))))){
a = c;
s = (p / 4);
} else {
s = ((p / (2 * Math.PI)) * Math.asin((c / a)));
};
if (t < 1){
--t;
return (((-0.5 * ((a * Math.pow(2, (10 * t))) * Math.sin(((((t * d) - s) * (2 * Math.PI)) / p)))) + b));
};
--t;
return ((((((a * Math.pow(2, (-10 * t))) * Math.sin(((((t * d) - s) * (2 * Math.PI)) / p))) * 0.5) + c) + b));
}
public static function easeOutInElastic(t:Number, b:Number, c:Number, d:Number, p_params:Object=null):Number{
if (t < (d / 2)){
return (easeOutElastic((t * 2), b, (c / 2), d, p_params));
};
return (easeInElastic(((t * 2) - d), (b + (c / 2)), (c / 2), d, p_params));
}
public static function easeInBack(t:Number, b:Number, c:Number, d:Number, p_params:Object=null):Number{
var s:Number = (((!(Boolean(p_params))) || (isNaN(p_params.overshoot)))) ? 1.70158 : p_params.overshoot;
t = (t / d);
return (((((c * t) * t) * (((s + 1) * t) - s)) + b));
}
public static function easeOutBack(t:Number, b:Number, c:Number, d:Number, p_params:Object=null):Number{
var s:Number = (((!(Boolean(p_params))) || (isNaN(p_params.overshoot)))) ? 1.70158 : p_params.overshoot;
t = ((t / d) - 1);
return (((c * (((t * t) * (((s + 1) * t) + s)) + 1)) + b));
}
public static function easeInOutBack(t:Number, b:Number, c:Number, d:Number, p_params:Object=null):Number{
var s:Number = (((!(Boolean(p_params))) || (isNaN(p_params.overshoot)))) ? 1.70158 : p_params.overshoot;
t = (t / (d / 2));
if (t < 1){
s = (s * 1.525);
return ((((c / 2) * ((t * t) * (((s + 1) * t) - s))) + b));
};
t = (t - 2);
s = (s * 1.525);
return ((((c / 2) * (((t * t) * (((s + 1) * t) + s)) + 2)) + b));
}
public static function easeOutInBack(t:Number, b:Number, c:Number, d:Number, p_params:Object=null):Number{
if (t < (d / 2)){
return (easeOutBack((t * 2), b, (c / 2), d, p_params));
};
return (easeInBack(((t * 2) - d), (b + (c / 2)), (c / 2), d, p_params));
}
public static function easeInBounce(t:Number, b:Number, c:Number, d:Number, p_params:Object=null):Number{
return (((c - easeOutBounce((d - t), 0, c, d)) + b));
}
public static function easeOutBounce(t:Number, b:Number, c:Number, d:Number, p_params:Object=null):Number{
t = (t / d);
if (t < (1 / 2.75)){
return (((c * ((7.5625 * t) * t)) + b));
};
if (t < (2 / 2.75)){
t = (t - (1.5 / 2.75));
return (((c * (((7.5625 * t) * t) + 0.75)) + b));
};
if (t < (2.5 / 2.75)){
t = (t - (2.25 / 2.75));
return (((c * (((7.5625 * t) * t) + 0.9375)) + b));
};
t = (t - (2.625 / 2.75));
return (((c * (((7.5625 * t) * t) + 0.984375)) + b));
}
public static function easeInOutBounce(t:Number, b:Number, c:Number, d:Number, p_params:Object=null):Number{
if (t < (d / 2)){
return (((easeInBounce((t * 2), 0, c, d) * 0.5) + b));
};
return ((((easeOutBounce(((t * 2) - d), 0, c, d) * 0.5) + (c * 0.5)) + b));
}
public static function easeOutInBounce(t:Number, b:Number, c:Number, d:Number, p_params:Object=null):Number{
if (t < (d / 2)){
return (easeOutBounce((t * 2), b, (c / 2), d, p_params));
};
return (easeInBounce(((t * 2) - d), (b + (c / 2)), (c / 2), d, p_params));
}
}
}//package caurina.transitions
Section 78
//PropertyInfoObj (caurina.transitions.PropertyInfoObj)
package caurina.transitions {
public class PropertyInfoObj {
public var valueStart:Number;
public var valueComplete:Number;
public var originalValueComplete:Object;
public var arrayIndex:Number;
public var extra:Object;
public var isSpecialProperty:Boolean;
public var hasModifier:Boolean;
public var modifierFunction:Function;
public var modifierParameters:Array;
public function PropertyInfoObj(p_valueStart:Number, p_valueComplete:Number, p_originalValueComplete:Object, p_arrayIndex:Number, p_extra:Object, p_isSpecialProperty:Boolean, p_modifierFunction:Function, p_modifierParameters:Array){
super();
valueStart = p_valueStart;
valueComplete = p_valueComplete;
originalValueComplete = p_originalValueComplete;
arrayIndex = p_arrayIndex;
extra = p_extra;
isSpecialProperty = p_isSpecialProperty;
hasModifier = Boolean(p_modifierFunction);
modifierFunction = p_modifierFunction;
modifierParameters = p_modifierParameters;
}
public function clone():PropertyInfoObj{
var nProperty:PropertyInfoObj = new PropertyInfoObj(valueStart, valueComplete, originalValueComplete, arrayIndex, extra, isSpecialProperty, modifierFunction, modifierParameters);
return (nProperty);
}
public function toString():String{
var returnStr:String = "\n[PropertyInfoObj ";
returnStr = (returnStr + ("valueStart:" + String(valueStart)));
returnStr = (returnStr + ", ");
returnStr = (returnStr + ("valueComplete:" + String(valueComplete)));
returnStr = (returnStr + ", ");
returnStr = (returnStr + ("originalValueComplete:" + String(originalValueComplete)));
returnStr = (returnStr + ", ");
returnStr = (returnStr + ("arrayIndex:" + String(arrayIndex)));
returnStr = (returnStr + ", ");
returnStr = (returnStr + ("extra:" + String(extra)));
returnStr = (returnStr + ", ");
returnStr = (returnStr + ("isSpecialProperty:" + String(isSpecialProperty)));
returnStr = (returnStr + ", ");
returnStr = (returnStr + ("hasModifier:" + String(hasModifier)));
returnStr = (returnStr + ", ");
returnStr = (returnStr + ("modifierFunction:" + String(modifierFunction)));
returnStr = (returnStr + ", ");
returnStr = (returnStr + ("modifierParameters:" + String(modifierParameters)));
returnStr = (returnStr + "]\n");
return (returnStr);
}
}
}//package caurina.transitions
Section 79
//SpecialProperty (caurina.transitions.SpecialProperty)
package caurina.transitions {
public class SpecialProperty {
public var getValue:Function;
public var setValue:Function;
public var parameters:Array;
public var preProcess:Function;
public function SpecialProperty(p_getFunction:Function, p_setFunction:Function, p_parameters:Array=null, p_preProcessFunction:Function=null){
super();
getValue = p_getFunction;
setValue = p_setFunction;
parameters = p_parameters;
preProcess = p_preProcessFunction;
}
public function toString():String{
var value:String = "";
value = (value + "[SpecialProperty ");
value = (value + ("getValue:" + String(getValue)));
value = (value + ", ");
value = (value + ("setValue:" + String(setValue)));
value = (value + ", ");
value = (value + ("parameters:" + String(parameters)));
value = (value + ", ");
value = (value + ("preProcess:" + String(preProcess)));
value = (value + "]");
return (value);
}
}
}//package caurina.transitions
Section 80
//SpecialPropertyModifier (caurina.transitions.SpecialPropertyModifier)
package caurina.transitions {
public class SpecialPropertyModifier {
public var modifyValues:Function;
public var getValue:Function;
public function SpecialPropertyModifier(p_modifyFunction:Function, p_getFunction:Function){
super();
modifyValues = p_modifyFunction;
getValue = p_getFunction;
}
public function toString():String{
var value:String = "";
value = (value + "[SpecialPropertyModifier ");
value = (value + ("modifyValues:" + String(modifyValues)));
value = (value + ", ");
value = (value + ("getValue:" + String(getValue)));
value = (value + "]");
return (value);
}
}
}//package caurina.transitions
Section 81
//SpecialPropertySplitter (caurina.transitions.SpecialPropertySplitter)
package caurina.transitions {
public class SpecialPropertySplitter {
public var parameters:Array;
public var splitValues:Function;
public function SpecialPropertySplitter(p_splitFunction:Function, p_parameters:Array){
super();
splitValues = p_splitFunction;
parameters = p_parameters;
}
public function toString():String{
var value:String = "";
value = (value + "[SpecialPropertySplitter ");
value = (value + ("splitValues:" + String(splitValues)));
value = (value + ", ");
value = (value + ("parameters:" + String(parameters)));
value = (value + "]");
return (value);
}
}
}//package caurina.transitions
Section 82
//Tweener (caurina.transitions.Tweener)
package caurina.transitions {
import flash.events.*;
import flash.display.*;
import flash.utils.*;
public class Tweener {
private static var __tweener_controller__:MovieClip;
private static var _engineExists:Boolean = false;
private static var _inited:Boolean = false;
private static var _currentTime:Number;
private static var _currentTimeFrame:Number;
private static var _tweenList:Array;
private static var _timeScale:Number = 1;
private static var _transitionList:Object;
private static var _specialPropertyList:Object;
private static var _specialPropertyModifierList:Object;
private static var _specialPropertySplitterList:Object;
public static var autoOverwrite:Boolean = true;
public function Tweener(){
super();
trace("Tweener is a static class and should not be instantiated.");
}
public static function addTween(p_scopes:Object=null, p_parameters:Object=null):Boolean{
var i:Number;
var j:Number;
var istr:String;
var rScopes:Array;
var rTransition:Function;
var nProperties:Object;
var nTween:TweenListObj;
var myT:Number;
var splitProperties:Array;
var splitProperties2:Array;
var tempModifiedProperties:Array;
var trans:String;
if (!Boolean(p_scopes)){
return (false);
};
if ((p_scopes is Array)){
rScopes = p_scopes.concat();
} else {
rScopes = [p_scopes];
};
var p_obj:Object = TweenListObj.makePropertiesChain(p_parameters);
if (!_inited){
init();
};
if (((!(_engineExists)) || (!(Boolean(__tweener_controller__))))){
startEngine();
};
var rTime:Number = (isNaN(p_obj.time)) ? 0 : p_obj.time;
var rDelay:Number = (isNaN(p_obj.delay)) ? 0 : p_obj.delay;
var rProperties:Array = new Array();
var restrictedWords:Object = {overwrite:true, time:true, delay:true, useFrames:true, skipUpdates:true, transition:true, transitionParams:true, onStart:true, onUpdate:true, onComplete:true, onOverwrite:true, onError:true, rounded:true, onStartParams:true, onUpdateParams:true, onCompleteParams:true, onOverwriteParams:true, onStartScope:true, onUpdateScope:true, onCompleteScope:true, onOverwriteScope:true, onErrorScope:true};
var modifiedProperties:Object = new Object();
for (istr in p_obj) {
if (!restrictedWords[istr]){
if (_specialPropertySplitterList[istr]){
splitProperties = _specialPropertySplitterList[istr].splitValues(p_obj[istr], _specialPropertySplitterList[istr].parameters);
i = 0;
while (i < splitProperties.length) {
if (_specialPropertySplitterList[splitProperties[i].name]){
splitProperties2 = _specialPropertySplitterList[splitProperties[i].name].splitValues(splitProperties[i].value, _specialPropertySplitterList[splitProperties[i].name].parameters);
j = 0;
while (j < splitProperties2.length) {
rProperties[splitProperties2[j].name] = {valueStart:undefined, valueComplete:splitProperties2[j].value, arrayIndex:splitProperties2[j].arrayIndex, isSpecialProperty:false};
j++;
};
} else {
rProperties[splitProperties[i].name] = {valueStart:undefined, valueComplete:splitProperties[i].value, arrayIndex:splitProperties[i].arrayIndex, isSpecialProperty:false};
};
i++;
};
} else {
if (_specialPropertyModifierList[istr] != undefined){
tempModifiedProperties = _specialPropertyModifierList[istr].modifyValues(p_obj[istr]);
i = 0;
while (i < tempModifiedProperties.length) {
modifiedProperties[tempModifiedProperties[i].name] = {modifierParameters:tempModifiedProperties[i].parameters, modifierFunction:_specialPropertyModifierList[istr].getValue};
i++;
};
} else {
rProperties[istr] = {valueStart:undefined, valueComplete:p_obj[istr]};
};
};
};
};
for (istr in rProperties) {
if (_specialPropertyList[istr] != undefined){
rProperties[istr].isSpecialProperty = true;
} else {
if (rScopes[0][istr] == undefined){
printError((((("The property '" + istr) + "' doesn't seem to be a normal object property of ") + String(rScopes[0])) + " or a registered special property."));
};
};
};
for (istr in modifiedProperties) {
if (rProperties[istr] != undefined){
rProperties[istr].modifierParameters = modifiedProperties[istr].modifierParameters;
rProperties[istr].modifierFunction = modifiedProperties[istr].modifierFunction;
};
};
if (typeof(p_obj.transition) == "string"){
trans = p_obj.transition.toLowerCase();
rTransition = _transitionList[trans];
} else {
rTransition = p_obj.transition;
};
if (!Boolean(rTransition)){
rTransition = _transitionList["easeoutexpo"];
};
i = 0;
while (i < rScopes.length) {
nProperties = new Object();
for (istr in rProperties) {
nProperties[istr] = new PropertyInfoObj(rProperties[istr].valueStart, rProperties[istr].valueComplete, rProperties[istr].valueComplete, rProperties[istr].arrayIndex, {}, rProperties[istr].isSpecialProperty, rProperties[istr].modifierFunction, rProperties[istr].modifierParameters);
};
if (p_obj.useFrames == true){
nTween = new TweenListObj(rScopes[i], (_currentTimeFrame + (rDelay / _timeScale)), (_currentTimeFrame + ((rDelay + rTime) / _timeScale)), true, rTransition, p_obj.transitionParams);
} else {
nTween = new TweenListObj(rScopes[i], (_currentTime + ((rDelay * 1000) / _timeScale)), (_currentTime + (((rDelay * 1000) + (rTime * 1000)) / _timeScale)), false, rTransition, p_obj.transitionParams);
};
nTween.properties = nProperties;
nTween.onStart = p_obj.onStart;
nTween.onUpdate = p_obj.onUpdate;
nTween.onComplete = p_obj.onComplete;
nTween.onOverwrite = p_obj.onOverwrite;
nTween.onError = p_obj.onError;
nTween.onStartParams = p_obj.onStartParams;
nTween.onUpdateParams = p_obj.onUpdateParams;
nTween.onCompleteParams = p_obj.onCompleteParams;
nTween.onOverwriteParams = p_obj.onOverwriteParams;
nTween.onStartScope = p_obj.onStartScope;
nTween.onUpdateScope = p_obj.onUpdateScope;
nTween.onCompleteScope = p_obj.onCompleteScope;
nTween.onOverwriteScope = p_obj.onOverwriteScope;
nTween.onErrorScope = p_obj.onErrorScope;
nTween.rounded = p_obj.rounded;
nTween.skipUpdates = p_obj.skipUpdates;
if (((p_obj.overwrite == undefined)) ? autoOverwrite : p_obj.overwrite){
removeTweensByTime(nTween.scope, nTween.properties, nTween.timeStart, nTween.timeComplete);
};
_tweenList.push(nTween);
if ((((rTime == 0)) && ((rDelay == 0)))){
myT = (_tweenList.length - 1);
updateTweenByIndex(myT);
removeTweenByIndex(myT);
};
i++;
};
return (true);
}
public static function addCaller(p_scopes:Object=null, p_parameters:Object=null):Boolean{
var i:Number;
var rScopes:Array;
var rTransition:Function;
var nTween:TweenListObj;
var myT:Number;
var trans:String;
if (!Boolean(p_scopes)){
return (false);
};
if ((p_scopes is Array)){
rScopes = p_scopes.concat();
} else {
rScopes = [p_scopes];
};
var p_obj:Object = p_parameters;
if (!_inited){
init();
};
if (((!(_engineExists)) || (!(Boolean(__tweener_controller__))))){
startEngine();
};
var rTime:Number = (isNaN(p_obj.time)) ? 0 : p_obj.time;
var rDelay:Number = (isNaN(p_obj.delay)) ? 0 : p_obj.delay;
if (typeof(p_obj.transition) == "string"){
trans = p_obj.transition.toLowerCase();
rTransition = _transitionList[trans];
} else {
rTransition = p_obj.transition;
};
if (!Boolean(rTransition)){
rTransition = _transitionList["easeoutexpo"];
};
i = 0;
while (i < rScopes.length) {
if (p_obj.useFrames == true){
nTween = new TweenListObj(rScopes[i], (_currentTimeFrame + (rDelay / _timeScale)), (_currentTimeFrame + ((rDelay + rTime) / _timeScale)), true, rTransition, p_obj.transitionParams);
} else {
nTween = new TweenListObj(rScopes[i], (_currentTime + ((rDelay * 1000) / _timeScale)), (_currentTime + (((rDelay * 1000) + (rTime * 1000)) / _timeScale)), false, rTransition, p_obj.transitionParams);
};
nTween.properties = null;
nTween.onStart = p_obj.onStart;
nTween.onUpdate = p_obj.onUpdate;
nTween.onComplete = p_obj.onComplete;
nTween.onOverwrite = p_obj.onOverwrite;
nTween.onStartParams = p_obj.onStartParams;
nTween.onUpdateParams = p_obj.onUpdateParams;
nTween.onCompleteParams = p_obj.onCompleteParams;
nTween.onOverwriteParams = p_obj.onOverwriteParams;
nTween.onStartScope = p_obj.onStartScope;
nTween.onUpdateScope = p_obj.onUpdateScope;
nTween.onCompleteScope = p_obj.onCompleteScope;
nTween.onOverwriteScope = p_obj.onOverwriteScope;
nTween.onErrorScope = p_obj.onErrorScope;
nTween.isCaller = true;
nTween.count = p_obj.count;
nTween.waitFrames = p_obj.waitFrames;
_tweenList.push(nTween);
if ((((rTime == 0)) && ((rDelay == 0)))){
myT = (_tweenList.length - 1);
updateTweenByIndex(myT);
removeTweenByIndex(myT);
};
i++;
};
return (true);
}
public static function removeTweensByTime(p_scope:Object, p_properties:Object, p_timeStart:Number, p_timeComplete:Number):Boolean{
var removedLocally:Boolean;
var i:uint;
var pName:String;
var eventScope:Object;
var p_scope = p_scope;
var p_properties = p_properties;
var p_timeStart = p_timeStart;
var p_timeComplete = p_timeComplete;
var removed:Boolean;
var tl:uint = _tweenList.length;
i = 0;
while (i < tl) {
if (((Boolean(_tweenList[i])) && ((p_scope == _tweenList[i].scope)))){
if ((((p_timeComplete > _tweenList[i].timeStart)) && ((p_timeStart < _tweenList[i].timeComplete)))){
removedLocally = false;
for (pName in _tweenList[i].properties) {
if (Boolean(p_properties[pName])){
if (Boolean(_tweenList[i].onOverwrite)){
eventScope = (Boolean(_tweenList[i].onOverwriteScope)) ? _tweenList[i].onOverwriteScope : _tweenList[i].scope;
_tweenList[i].onOverwrite.apply(eventScope, _tweenList[i].onOverwriteParams);
//unresolved jump
var _slot1 = e;
handleError(_tweenList[i], _slot1, "onOverwrite");
};
_tweenList[i].properties[pName] = undefined;
delete _tweenList[i].properties[pName];
removedLocally = true;
removed = true;
};
};
if (removedLocally){
if (AuxFunctions.getObjectLength(_tweenList[i].properties) == 0){
removeTweenByIndex(i);
};
};
};
};
i = (i + 1);
};
return (removed);
}
public static function removeTweens(p_scope:Object, ... _args):Boolean{
var i:uint;
var sps:SpecialPropertySplitter;
var specialProps:Array;
var j:uint;
var properties:Array = new Array();
i = 0;
while (i < _args.length) {
if ((((typeof(_args[i]) == "string")) && ((properties.indexOf(_args[i]) == -1)))){
if (_specialPropertySplitterList[_args[i]]){
sps = _specialPropertySplitterList[_args[i]];
specialProps = sps.splitValues(p_scope, null);
j = 0;
while (j < specialProps.length) {
properties.push(specialProps[j].name);
j++;
};
} else {
properties.push(_args[i]);
};
};
i++;
};
return (affectTweens(removeTweenByIndex, p_scope, properties));
}
public static function removeAllTweens():Boolean{
var i:uint;
if (!Boolean(_tweenList)){
return (false);
};
var removed:Boolean;
i = 0;
while (i < _tweenList.length) {
removeTweenByIndex(i);
removed = true;
i++;
};
return (removed);
}
public static function pauseTweens(p_scope:Object, ... _args):Boolean{
var i:uint;
var properties:Array = new Array();
i = 0;
while (i < _args.length) {
if ((((typeof(_args[i]) == "string")) && ((properties.indexOf(_args[i]) == -1)))){
properties.push(_args[i]);
};
i++;
};
return (affectTweens(pauseTweenByIndex, p_scope, properties));
}
public static function pauseAllTweens():Boolean{
var i:uint;
if (!Boolean(_tweenList)){
return (false);
};
var paused:Boolean;
i = 0;
while (i < _tweenList.length) {
pauseTweenByIndex(i);
paused = true;
i++;
};
return (paused);
}
public static function resumeTweens(p_scope:Object, ... _args):Boolean{
var i:uint;
var properties:Array = new Array();
i = 0;
while (i < _args.length) {
if ((((typeof(_args[i]) == "string")) && ((properties.indexOf(_args[i]) == -1)))){
properties.push(_args[i]);
};
i++;
};
return (affectTweens(resumeTweenByIndex, p_scope, properties));
}
public static function resumeAllTweens():Boolean{
var i:uint;
if (!Boolean(_tweenList)){
return (false);
};
var resumed:Boolean;
i = 0;
while (i < _tweenList.length) {
resumeTweenByIndex(i);
resumed = true;
i++;
};
return (resumed);
}
private static function affectTweens(p_affectFunction:Function, p_scope:Object, p_properties:Array):Boolean{
var i:uint;
var affectedProperties:Array;
var j:uint;
var objectProperties:uint;
var slicedTweenIndex:uint;
var affected:Boolean;
if (!Boolean(_tweenList)){
return (false);
};
i = 0;
while (i < _tweenList.length) {
if (((_tweenList[i]) && ((_tweenList[i].scope == p_scope)))){
if (p_properties.length == 0){
p_affectFunction(i);
affected = true;
} else {
affectedProperties = new Array();
j = 0;
while (j < p_properties.length) {
if (Boolean(_tweenList[i].properties[p_properties[j]])){
affectedProperties.push(p_properties[j]);
};
j++;
};
if (affectedProperties.length > 0){
objectProperties = AuxFunctions.getObjectLength(_tweenList[i].properties);
if (objectProperties == affectedProperties.length){
p_affectFunction(i);
affected = true;
} else {
slicedTweenIndex = splitTweens(i, affectedProperties);
p_affectFunction(slicedTweenIndex);
affected = true;
};
};
};
};
i++;
};
return (affected);
}
public static function splitTweens(p_tween:Number, p_properties:Array):uint{
var i:uint;
var pName:String;
var found:Boolean;
var originalTween:TweenListObj = _tweenList[p_tween];
var newTween:TweenListObj = originalTween.clone(false);
i = 0;
while (i < p_properties.length) {
pName = p_properties[i];
if (Boolean(originalTween.properties[pName])){
originalTween.properties[pName] = undefined;
delete originalTween.properties[pName];
};
i++;
};
for (pName in newTween.properties) {
found = false;
i = 0;
while (i < p_properties.length) {
if (p_properties[i] == pName){
found = true;
break;
};
i++;
};
if (!found){
newTween.properties[pName] = undefined;
delete newTween.properties[pName];
};
};
_tweenList.push(newTween);
return ((_tweenList.length - 1));
}
private static function updateTweens():Boolean{
var i:int;
if (_tweenList.length == 0){
return (false);
};
i = 0;
while (i < _tweenList.length) {
if ((((_tweenList[i] == undefined)) || (!(_tweenList[i].isPaused)))){
if (!updateTweenByIndex(i)){
removeTweenByIndex(i);
};
if (_tweenList[i] == null){
removeTweenByIndex(i, true);
i--;
};
};
i++;
};
return (true);
}
public static function removeTweenByIndex(i:Number, p_finalRemoval:Boolean=false):Boolean{
_tweenList[i] = null;
if (p_finalRemoval){
_tweenList.splice(i, 1);
};
return (true);
}
public static function pauseTweenByIndex(p_tween:Number):Boolean{
var tTweening:TweenListObj = _tweenList[p_tween];
if ((((tTweening == null)) || (tTweening.isPaused))){
return (false);
};
tTweening.timePaused = getCurrentTweeningTime(tTweening);
tTweening.isPaused = true;
return (true);
}
public static function resumeTweenByIndex(p_tween:Number):Boolean{
var tTweening:TweenListObj = _tweenList[p_tween];
if ((((tTweening == null)) || (!(tTweening.isPaused)))){
return (false);
};
var cTime:Number = getCurrentTweeningTime(tTweening);
tTweening.timeStart = (tTweening.timeStart + (cTime - tTweening.timePaused));
tTweening.timeComplete = (tTweening.timeComplete + (cTime - tTweening.timePaused));
tTweening.timePaused = undefined;
tTweening.isPaused = false;
return (true);
}
private static function updateTweenByIndex(i:Number):Boolean{
var tTweening:TweenListObj;
var mustUpdate:Boolean;
var nv:Number;
var t:Number;
var b:Number;
var c:Number;
var d:Number;
var pName:String;
var eventScope:Object;
var tScope:Object;
var tProperty:Object;
var pv:Number;
var i = i;
tTweening = _tweenList[i];
if ((((tTweening == null)) || (!(Boolean(tTweening.scope))))){
return (false);
};
var isOver:Boolean;
var cTime:Number = getCurrentTweeningTime(tTweening);
if (cTime >= tTweening.timeStart){
tScope = tTweening.scope;
if (tTweening.isCaller){
do {
t = (((tTweening.timeComplete - tTweening.timeStart) / tTweening.count) * (tTweening.timesCalled + 1));
b = tTweening.timeStart;
c = (tTweening.timeComplete - tTweening.timeStart);
d = (tTweening.timeComplete - tTweening.timeStart);
nv = tTweening.transition(t, b, c, d);
//unresolved if
if (Boolean(tTweening.onUpdate)){
eventScope = (Boolean(tTweening.onUpdateScope)) ? tTweening.onUpdateScope : tScope;
tTweening.onUpdate.apply(eventScope, tTweening.onUpdateParams);
continue;
var _slot1 = e1;
handleError(tTweening, _slot1, "onUpdate");
};
} while (tTweening.timesCalled++, !(tTweening.timesCalled >= tTweening.count));
} else {
mustUpdate = (((((tTweening.skipUpdates < 1)) || (!(tTweening.skipUpdates)))) || ((tTweening.updatesSkipped >= tTweening.skipUpdates)));
if (cTime >= tTweening.timeComplete){
isOver = true;
mustUpdate = true;
};
if (!tTweening.hasStarted){
if (Boolean(tTweening.onStart)){
eventScope = (Boolean(tTweening.onStartScope)) ? tTweening.onStartScope : tScope;
tTweening.onStart.apply(eventScope, tTweening.onStartParams);
//unresolved jump
var _slot1 = e2;
handleError(tTweening, _slot1, "onStart");
};
for (pName in tTweening.properties) {
if (tTweening.properties[pName].isSpecialProperty){
if (Boolean(_specialPropertyList[pName].preProcess)){
tTweening.properties[pName].valueComplete = _specialPropertyList[pName].preProcess(tScope, _specialPropertyList[pName].parameters, tTweening.properties[pName].originalValueComplete, tTweening.properties[pName].extra);
};
pv = _specialPropertyList[pName].getValue(tScope, _specialPropertyList[pName].parameters, tTweening.properties[pName].extra);
} else {
pv = tScope[pName];
};
tTweening.properties[pName].valueStart = (isNaN(pv)) ? tTweening.properties[pName].valueComplete : pv;
};
mustUpdate = true;
tTweening.hasStarted = true;
};
if (mustUpdate){
for (pName in tTweening.properties) {
tProperty = tTweening.properties[pName];
if (isOver){
nv = tProperty.valueComplete;
} else {
if (tProperty.hasModifier){
t = (cTime - tTweening.timeStart);
d = (tTweening.timeComplete - tTweening.timeStart);
nv = tTweening.transition(t, 0, 1, d, tTweening.transitionParams);
nv = tProperty.modifierFunction(tProperty.valueStart, tProperty.valueComplete, nv, tProperty.modifierParameters);
} else {
t = (cTime - tTweening.timeStart);
b = tProperty.valueStart;
c = (tProperty.valueComplete - tProperty.valueStart);
d = (tTweening.timeComplete - tTweening.timeStart);
nv = tTweening.transition(t, b, c, d, tTweening.transitionParams);
};
};
if (tTweening.rounded){
nv = Math.round(nv);
};
if (tProperty.isSpecialProperty){
_specialPropertyList[pName].setValue(tScope, nv, _specialPropertyList[pName].parameters, tTweening.properties[pName].extra);
} else {
tScope[pName] = nv;
};
};
tTweening.updatesSkipped = 0;
if (Boolean(tTweening.onUpdate)){
eventScope = (Boolean(tTweening.onUpdateScope)) ? tTweening.onUpdateScope : tScope;
tTweening.onUpdate.apply(eventScope, tTweening.onUpdateParams);
//unresolved jump
var _slot1 = e3;
handleError(tTweening, _slot1, "onUpdate");
};
} else {
tTweening.updatesSkipped++;
};
};
if (((isOver) && (Boolean(tTweening.onComplete)))){
eventScope = (Boolean(tTweening.onCompleteScope)) ? tTweening.onCompleteScope : tScope;
tTweening.onComplete.apply(eventScope, tTweening.onCompleteParams);
//unresolved jump
var _slot1 = e4;
handleError(tTweening, _slot1, "onComplete");
};
return (!(isOver));
};
return (true);
}
public static function init(... _args):void{
_inited = true;
_transitionList = new Object();
Equations.init();
_specialPropertyList = new Object();
_specialPropertyModifierList = new Object();
_specialPropertySplitterList = new Object();
}
public static function registerTransition(p_name:String, p_function:Function):void{
if (!_inited){
init();
};
_transitionList[p_name] = p_function;
}
public static function registerSpecialProperty(p_name:String, p_getFunction:Function, p_setFunction:Function, p_parameters:Array=null, p_preProcessFunction:Function=null):void{
if (!_inited){
init();
};
var sp:SpecialProperty = new SpecialProperty(p_getFunction, p_setFunction, p_parameters, p_preProcessFunction);
_specialPropertyList[p_name] = sp;
}
public static function registerSpecialPropertyModifier(p_name:String, p_modifyFunction:Function, p_getFunction:Function):void{
if (!_inited){
init();
};
var spm:SpecialPropertyModifier = new SpecialPropertyModifier(p_modifyFunction, p_getFunction);
_specialPropertyModifierList[p_name] = spm;
}
public static function registerSpecialPropertySplitter(p_name:String, p_splitFunction:Function, p_parameters:Array=null):void{
if (!_inited){
init();
};
var sps:SpecialPropertySplitter = new SpecialPropertySplitter(p_splitFunction, p_parameters);
_specialPropertySplitterList[p_name] = sps;
}
private static function startEngine():void{
_engineExists = true;
_tweenList = new Array();
__tweener_controller__ = new MovieClip();
__tweener_controller__.addEventListener(Event.ENTER_FRAME, Tweener.onEnterFrame);
_currentTimeFrame = 0;
updateTime();
}
private static function stopEngine():void{
_engineExists = false;
_tweenList = null;
_currentTime = 0;
_currentTimeFrame = 0;
__tweener_controller__.removeEventListener(Event.ENTER_FRAME, Tweener.onEnterFrame);
__tweener_controller__ = null;
}
public static function updateTime():void{
_currentTime = getTimer();
}
public static function updateFrame():void{
_currentTimeFrame++;
}
public static function onEnterFrame(e:Event):void{
updateTime();
updateFrame();
var hasUpdated:Boolean;
hasUpdated = updateTweens();
if (!hasUpdated){
stopEngine();
};
}
public static function setTimeScale(p_time:Number):void{
var i:Number;
var cTime:Number;
if (isNaN(p_time)){
p_time = 1;
};
if (p_time < 1E-5){
p_time = 1E-5;
};
if (p_time != _timeScale){
if (_tweenList != null){
i = 0;
while (i < _tweenList.length) {
cTime = getCurrentTweeningTime(_tweenList[i]);
_tweenList[i].timeStart = (cTime - (((cTime - _tweenList[i].timeStart) * _timeScale) / p_time));
_tweenList[i].timeComplete = (cTime - (((cTime - _tweenList[i].timeComplete) * _timeScale) / p_time));
if (_tweenList[i].timePaused != undefined){
_tweenList[i].timePaused = (cTime - (((cTime - _tweenList[i].timePaused) * _timeScale) / p_time));
};
i++;
};
};
_timeScale = p_time;
};
}
public static function isTweening(p_scope:Object):Boolean{
var i:uint;
if (!Boolean(_tweenList)){
return (false);
};
i = 0;
while (i < _tweenList.length) {
if (((Boolean(_tweenList[i])) && ((_tweenList[i].scope == p_scope)))){
return (true);
};
i++;
};
return (false);
}
public static function getTweens(p_scope:Object):Array{
var i:uint;
var pName:String;
if (!Boolean(_tweenList)){
return ([]);
};
var tList:Array = new Array();
i = 0;
while (i < _tweenList.length) {
if (((Boolean(_tweenList[i])) && ((_tweenList[i].scope == p_scope)))){
for (pName in _tweenList[i].properties) {
tList.push(pName);
};
};
i++;
};
return (tList);
}
public static function getTweenCount(p_scope:Object):Number{
var i:uint;
if (!Boolean(_tweenList)){
return (0);
};
var c:Number = 0;
i = 0;
while (i < _tweenList.length) {
if (((Boolean(_tweenList[i])) && ((_tweenList[i].scope == p_scope)))){
c = (c + AuxFunctions.getObjectLength(_tweenList[i].properties));
};
i++;
};
return (c);
}
private static function handleError(pTweening:TweenListObj, pError:Error, pCallBackName:String):void{
var eventScope:Object;
var pTweening = pTweening;
var pError = pError;
var pCallBackName = pCallBackName;
if (((Boolean(pTweening.onError)) && ((pTweening.onError is Function)))){
eventScope = (Boolean(pTweening.onErrorScope)) ? pTweening.onErrorScope : pTweening.scope;
pTweening.onError.apply(eventScope, [pTweening.scope, pError]);
//unresolved jump
var _slot1 = metaError;
printError(((((String(pTweening.scope) + " raised an error while executing the 'onError' handler. Original error:\n ") + pError.getStackTrace()) + "\nonError error: ") + _slot1.getStackTrace()));
} else {
if (!Boolean(pTweening.onError)){
printError(((((String(pTweening.scope) + " raised an error while executing the '") + pCallBackName) + "'handler. \n") + pError.getStackTrace()));
};
};
}
public static function getCurrentTweeningTime(p_tweening:Object):Number{
return ((p_tweening.useFrames) ? _currentTimeFrame : _currentTime);
}
public static function getVersion():String{
return ("AS3 1.33.74");
}
public static function printError(p_message:String):void{
trace(("## [Tweener] Error: " + p_message));
}
}
}//package caurina.transitions
Section 83
//TweenListObj (caurina.transitions.TweenListObj)
package caurina.transitions {
public class TweenListObj {
public var scope:Object;
public var properties:Object;
public var timeStart:Number;
public var timeComplete:Number;
public var useFrames:Boolean;
public var transition:Function;
public var transitionParams:Object;
public var onStart:Function;
public var onUpdate:Function;
public var onComplete:Function;
public var onOverwrite:Function;
public var onError:Function;
public var onStartParams:Array;
public var onUpdateParams:Array;
public var onCompleteParams:Array;
public var onOverwriteParams:Array;
public var onStartScope:Object;
public var onUpdateScope:Object;
public var onCompleteScope:Object;
public var onOverwriteScope:Object;
public var onErrorScope:Object;
public var rounded:Boolean;
public var isPaused:Boolean;
public var timePaused:Number;
public var isCaller:Boolean;
public var count:Number;
public var timesCalled:Number;
public var waitFrames:Boolean;
public var skipUpdates:Number;
public var updatesSkipped:Number;
public var hasStarted:Boolean;
public function TweenListObj(p_scope:Object, p_timeStart:Number, p_timeComplete:Number, p_useFrames:Boolean, p_transition:Function, p_transitionParams:Object){
super();
scope = p_scope;
timeStart = p_timeStart;
timeComplete = p_timeComplete;
useFrames = p_useFrames;
transition = p_transition;
transitionParams = p_transitionParams;
properties = new Object();
isPaused = false;
timePaused = undefined;
isCaller = false;
updatesSkipped = 0;
timesCalled = 0;
skipUpdates = 0;
hasStarted = false;
}
public function clone(omitEvents:Boolean):TweenListObj{
var pName:String;
var nTween:TweenListObj = new TweenListObj(scope, timeStart, timeComplete, useFrames, transition, transitionParams);
nTween.properties = new Array();
for (pName in properties) {
nTween.properties[pName] = properties[pName].clone();
};
nTween.skipUpdates = skipUpdates;
nTween.updatesSkipped = updatesSkipped;
if (!omitEvents){
nTween.onStart = onStart;
nTween.onUpdate = onUpdate;
nTween.onComplete = onComplete;
nTween.onOverwrite = onOverwrite;
nTween.onError = onError;
nTween.onStartParams = onStartParams;
nTween.onUpdateParams = onUpdateParams;
nTween.onCompleteParams = onCompleteParams;
nTween.onOverwriteParams = onOverwriteParams;
nTween.onStartScope = onStartScope;
nTween.onUpdateScope = onUpdateScope;
nTween.onCompleteScope = onCompleteScope;
nTween.onOverwriteScope = onOverwriteScope;
nTween.onErrorScope = onErrorScope;
};
nTween.rounded = rounded;
nTween.isPaused = isPaused;
nTween.timePaused = timePaused;
nTween.isCaller = isCaller;
nTween.count = count;
nTween.timesCalled = timesCalled;
nTween.waitFrames = waitFrames;
nTween.hasStarted = hasStarted;
return (nTween);
}
public function toString():String{
var i:String;
var returnStr:String = "\n[TweenListObj ";
returnStr = (returnStr + ("scope:" + String(scope)));
returnStr = (returnStr + ", properties:");
var isFirst:Boolean;
for (i in properties) {
if (!isFirst){
returnStr = (returnStr + ",");
};
returnStr = (returnStr + ("[name:" + properties[i].name));
returnStr = (returnStr + (",valueStart:" + properties[i].valueStart));
returnStr = (returnStr + (",valueComplete:" + properties[i].valueComplete));
returnStr = (returnStr + "]");
isFirst = false;
};
returnStr = (returnStr + (", timeStart:" + String(timeStart)));
returnStr = (returnStr + (", timeComplete:" + String(timeComplete)));
returnStr = (returnStr + (", useFrames:" + String(useFrames)));
returnStr = (returnStr + (", transition:" + String(transition)));
returnStr = (returnStr + (", transitionParams:" + String(transitionParams)));
if (skipUpdates){
returnStr = (returnStr + (", skipUpdates:" + String(skipUpdates)));
};
if (updatesSkipped){
returnStr = (returnStr + (", updatesSkipped:" + String(updatesSkipped)));
};
if (Boolean(onStart)){
returnStr = (returnStr + (", onStart:" + String(onStart)));
};
if (Boolean(onUpdate)){
returnStr = (returnStr + (", onUpdate:" + String(onUpdate)));
};
if (Boolean(onComplete)){
returnStr = (returnStr + (", onComplete:" + String(onComplete)));
};
if (Boolean(onOverwrite)){
returnStr = (returnStr + (", onOverwrite:" + String(onOverwrite)));
};
if (Boolean(onError)){
returnStr = (returnStr + (", onError:" + String(onError)));
};
if (onStartParams){
returnStr = (returnStr + (", onStartParams:" + String(onStartParams)));
};
if (onUpdateParams){
returnStr = (returnStr + (", onUpdateParams:" + String(onUpdateParams)));
};
if (onCompleteParams){
returnStr = (returnStr + (", onCompleteParams:" + String(onCompleteParams)));
};
if (onOverwriteParams){
returnStr = (returnStr + (", onOverwriteParams:" + String(onOverwriteParams)));
};
if (onStartScope){
returnStr = (returnStr + (", onStartScope:" + String(onStartScope)));
};
if (onUpdateScope){
returnStr = (returnStr + (", onUpdateScope:" + String(onUpdateScope)));
};
if (onCompleteScope){
returnStr = (returnStr + (", onCompleteScope:" + String(onCompleteScope)));
};
if (onOverwriteScope){
returnStr = (returnStr + (", onOverwriteScope:" + String(onOverwriteScope)));
};
if (onErrorScope){
returnStr = (returnStr + (", onErrorScope:" + String(onErrorScope)));
};
if (rounded){
returnStr = (returnStr + (", rounded:" + String(rounded)));
};
if (isPaused){
returnStr = (returnStr + (", isPaused:" + String(isPaused)));
};
if (timePaused){
returnStr = (returnStr + (", timePaused:" + String(timePaused)));
};
if (isCaller){
returnStr = (returnStr + (", isCaller:" + String(isCaller)));
};
if (count){
returnStr = (returnStr + (", count:" + String(count)));
};
if (timesCalled){
returnStr = (returnStr + (", timesCalled:" + String(timesCalled)));
};
if (waitFrames){
returnStr = (returnStr + (", waitFrames:" + String(waitFrames)));
};
if (hasStarted){
returnStr = (returnStr + (", hasStarted:" + String(hasStarted)));
};
returnStr = (returnStr + "]\n");
return (returnStr);
}
public static function makePropertiesChain(p_obj:Object):Object{
var chainedObject:Object;
var chain:Object;
var currChainObj:Object;
var len:Number;
var i:Number;
var k:Number;
var baseObject:Object = p_obj.base;
if (baseObject){
chainedObject = {};
if ((baseObject is Array)){
chain = [];
k = 0;
while (k < baseObject.length) {
chain.push(baseObject[k]);
k++;
};
} else {
chain = [baseObject];
};
chain.push(p_obj);
len = chain.length;
i = 0;
while (i < len) {
if (chain[i]["base"]){
currChainObj = AuxFunctions.concatObjects(makePropertiesChain(chain[i]["base"]), chain[i]);
} else {
currChainObj = chain[i];
};
chainedObject = AuxFunctions.concatObjects(chainedObject, currChainObj);
i++;
};
if (chainedObject["base"]){
delete chainedObject["base"];
};
return (chainedObject);
//unresolved jump
};
return (p_obj);
}
}
}//package caurina.transitions
Section 84
//BaseBridge (Element.BaseBridge)
package Element {
import flash.display.*;
import UserdefinedClass.*;
import flash.geom.*;
import Box2D.Common.Math.*;
import BaseClass.*;
public class BaseBridge extends MovieClip {
public var basestage:BaseStage;
public var lu:MovieClip;
public var str:String;
public var len:int;
public var sp:MovieClip;
public var ep:MovieClip;
public function BaseBridge(bs:BaseStage, m:MovieClip, s:String, l:int){
super();
basestage = bs;
lu = m;
str = s;
len = l;
initbridge();
}
public function initbridge():void{
var p:Point;
var tempmc:MovieClip;
sp = (lu.getChildByName(str.concat(1)) as MovieClip);
ep = (lu.getChildByName(str.concat(2)) as MovieClip);
p = MyMath.LtoG(basestage.frontroad, sp);
sp.x = p.x;
sp.y = p.y;
var angle:Number = ((sp.rotation / 180) * Math.PI);
Box2dFactory.getInstance().addToWorld((sp.x / 30), (sp.y / 30), angle, 0, 0, 0, sp, false, "p");
basestage.frontroad.addChild(sp);
p = MyMath.LtoG(basestage.frontroad, ep);
ep.x = p.x;
ep.y = p.y;
angle = ((ep.rotation / 180) * Math.PI);
Box2dFactory.getInstance().addToWorld((ep.x / 30), (ep.y / 30), angle, 0, 0, 0, ep, false, "p");
var mcCache:Array = new Array();
var i:int;
while (i < len) {
if (i == 0){
tempmc = makeAnchor(sp, (lu.getChildByName(str.concat((3 + i))) as MovieClip), basestage.frontroad);
} else {
if (i < (len - 1)){
tempmc = makeAnchor(tempmc, (lu.getChildByName(str.concat((3 + i))) as MovieClip), basestage.frontroad);
} else {
makeAnchor(tempmc, ep, basestage.frontroad);
};
};
mcCache.push(tempmc);
i++;
};
}
private function makeAnchor(lastbox:MovieClip, nextbox:MovieClip, container:DisplayObjectContainer):MovieClip{
var p:Point;
var tempAnchor:MovieClip = nextbox;
var lastAnchor:MovieClip = lastbox;
p = MyMath.LtoG(container, tempAnchor);
tempAnchor.x = p.x;
tempAnchor.y = p.y;
container.addChild(tempAnchor);
var angle:Number = ((tempAnchor.rotation / 180) * Math.PI);
Box2dFactory.getInstance().addToWorld((tempAnchor.x / 30), (tempAnchor.y / 30), angle, 10, 1, 0, tempAnchor, false, "road");
p = MyMath.LtoG(container, lastAnchor.anchor2);
var anchorpx:Number = (p.x / 30);
var anchorpy:Number = (p.y / 30);
Box2dFactory.getInstance().createRevoluteJoint(tempAnchor.bd, lastAnchor.bd, new b2Vec2(anchorpx, anchorpy));
lastAnchor = tempAnchor;
return (lastAnchor);
}
}
}//package Element
Section 85
//BaseCar (Element.BaseCar)
package Element {
import flash.display.*;
import UserdefinedClass.*;
import flash.geom.*;
import Box2D.Common.Math.*;
import Box2D.Dynamics.Joints.*;
import Box2D.Dynamics.*;
import flash.utils.*;
import BaseClass.*;
public class BaseCar extends MovieClip {
public var world:Box2dFactory;
public var main:Main;
public var lun1:MovieClip;
public var lun2:MovieClip;
public var lun3:MovieClip;
public var lun4:MovieClip;
public var motor1:b2RevoluteJoint;
public var motor2:b2RevoluteJoint;
public var Carbodystr:Array;
public var Carheadstr:Array;
public var carF:Number;// = 0.1
public var carD:Number;// = 1
public var carR:Number;// = 0
public var lunF:Number;// = 30
public var lunD:Number;// = 1.5
public var lunR:Number;// = 0
public var speedup:Number;// = 200
public var addspeed:Number;// = 0
public var spin:Number;// = 0
public var lunbrake:Number;// = 0
public var power:Number;// = 0
public var lunspeed:Number;// = 0
public var basestage:BaseStage;
public var carkind:int;
public var protect:int;
public var Flight:int;
public var lunscale:Number;// = 1.70555555555556
public var flight:MovieClip;
public var superadd:Number;// = 1
public var yanArr:Array;
public var playing:Boolean;// = false
public var carMc:MovieClip;
public var boxMc:MovieClip;
public var hitmc:MovieClip;
public var cargohitmc:MovieClip;
public var marklight:MovieClip;
public var makeyan:MovieClip;
public function BaseCar(b:BaseStage, boxkind:int=0, container:DisplayObjectContainer=null, x:Number=0, y:Number=0){
Carbodystr = new Array("Carbody1", "Carbody2", "Carbody3", "Carbody4", "Carbody5");
Carheadstr = new Array("Carhead1", "Carhead2");
yanArr = new Array();
super();
basestage = b;
carkind = boxkind;
world = Box2dFactory.getInstance();
loaddata();
buildcar(container, x, y);
}
private function loaddata():void{
addspeed = ((((MyData.getInstance().addv[2] + 1) * 2) * 2) + MyData.getInstance().materialcar.addspeed);
spin = (((MyData.getInstance().addv[1] * 6) * 2) + MyData.getInstance().materialcar.spin);
lunbrake = (((MyData.getInstance().addv[0] * 5) * 2) + MyData.getInstance().materialcar.power);
power = (((MyData.getInstance().addv[0] * 5) * 2) + MyData.getInstance().materialcar.power);
lunspeed = ((((MyData.getInstance().addv[0] * 2) * Math.PI) * 0.3) + MyData.getInstance().materialcar.lunspeed);
protect = MyData.getInstance().caritem[0];
Flight = MyData.getInstance().caritem[1];
}
private function worklight(){
if ((((((((basestage.lv == 2)) || ((basestage.lv == 3)))) || ((basestage.lv == 7)))) || ((basestage.lv == 8)))){
basestage.canlight = true;
basestage.light.addChild(marklight);
} else {
if (marklight.parent){
marklight.parent.removeChild(marklight);
};
};
}
private function setcar(mc:MovieClip){
mc.car.guan.gotoAndStop((MyData.getInstance().addv[1] + 1));
mc.car.yan.gotoAndStop((MyData.getInstance().addv[2] + 1));
}
private function setwheel(){
lun1.gotoAndStop((MyData.getInstance().addv[0] + 1));
lun2.gotoAndStop((MyData.getInstance().addv[0] + 1));
}
private function buildcar(con:DisplayObjectContainer, x:Number, y:Number):void{
var tempAnchor:MovieClip;
var carclass:* = getDefinitionByName(Carheadstr[protect].toString());
carMc = (new (carclass) as MovieClip);
carMc.x = x;
carMc.y = y;
setcar(carMc);
makeyan = (carMc.car.yan.getChildByName("yan3") as MovieClip);
marklight = (carMc.getChildByName("lightmark") as MovieClip);
worklight();
world.addToWorld((carMc.x / 30), (carMc.y / 30), carMc.rotation, carF, carD, carR, carMc, false, "head");
lun1 = (carMc.getChildByName("lun1") as MovieClip);
lun2 = (carMc.getChildByName("lun2") as MovieClip);
hitmc = (carMc.getChildByName("head") as MovieClip);
setwheel();
var tempD1:MovieClip = (carMc.getChildByName("d1") as MovieClip);
var tempD2:MovieClip = (carMc.getChildByName("d2") as MovieClip);
var zhou1:MovieClip = (carMc.getChildByName("z1") as MovieClip);
var zhou2:MovieClip = (carMc.getChildByName("z2") as MovieClip);
flight = (carMc.car.light as MovieClip);
flight.alpha = Flight;
var p:Point = MyMath.LtoG(con, lun1);
lun1.x = p.x;
lun1.y = p.y;
p = MyMath.LtoG(con, lun2);
lun2.x = p.x;
lun2.y = p.y;
p = MyMath.LtoG(con, hitmc);
hitmc.x = p.x;
hitmc.y = p.y;
p = MyMath.LtoG(con, zhou1);
zhou1.x = p.x;
zhou1.y = p.y;
p = MyMath.LtoG(con, zhou2);
zhou2.x = p.x;
zhou2.y = p.y;
p = MyMath.LtoG(con, tempD1);
tempD1.x = p.x;
tempD1.y = p.y;
p = MyMath.LtoG(con, tempD2);
tempD2.x = p.x;
tempD2.y = p.y;
world.addToWorld((zhou1.x / 30), (zhou1.y / 30), zhou1.rotation, carF, carD, carR, zhou1, false, "zhou");
world.addToWorld((zhou2.x / 30), (zhou2.y / 30), zhou2.rotation, carF, carD, carR, zhou2, false, "zhou");
world.makeBodyByYuanInside((hitmc.x / 30), (hitmc.y / 30), hitmc, 0.1, 0, 0, false, "hit");
(world.createRevoluteJoint(hitmc.bd, carMc.bd, (hitmc.bd as b2Body).GetWorldCenter(), false, 0, 0, false, 0, 0) as b2RevoluteJoint);
world.makeBodyByYuanInside((lun1.x / 30), (lun1.y / 30), lun1, lunD, lunF, lunR, false, "lun");
world.makeBodyByYuanInside((lun2.x / 30), (lun2.y / 30), lun2, lunD, lunF, lunR, false, "lun");
world.addToWorld((tempD1.x / 30), (tempD1.y / 30), tempD1.rotation, carF, carD, carR, tempD1, false, "sd");
world.addToWorld((tempD2.x / 30), (tempD2.y / 30), tempD2.rotation, carF, carD, carR, tempD2, false, "sd");
(lun1.bd as b2Body).AllowSleeping(false);
(lun2.bd as b2Body).AllowSleeping(false);
motor1 = (world.createRevoluteJoint(lun1.bd, zhou1.bd, (lun1.bd as b2Body).GetWorldCenter(), false, 0, 0, false, 0, power) as b2RevoluteJoint);
motor2 = (world.createRevoluteJoint(lun2.bd, zhou2.bd, (lun2.bd as b2Body).GetWorldCenter(), false, 0, 0, false, 0, power) as b2RevoluteJoint);
world.prismatiocJoint(carMc, zhou1, Math.cos((Math.PI / 2)), Math.sin((Math.PI / 2)), 0, -0.1);
world.prismatiocJoint(carMc, zhou2, -(Math.cos((Math.PI / 2))), Math.sin((Math.PI / 2)), 0, -0.1);
p = MyMath.LtoG(con, tempD1.anchor);
var vec:b2Vec2 = (tempD1.bd as b2Body).GetWorldCenter();
vec.y = (vec.y - (7 / 30));
world.createRevoluteJoint(carMc.bd, tempD1.bd, vec);
p = MyMath.LtoG(con, tempD2.anchor);
vec = (tempD2.bd as b2Body).GetWorldCenter();
vec.y = (vec.y - (7 / 30));
world.createRevoluteJoint(carMc.bd, tempD2.bd, vec);
con.addChild(carMc);
con.addChild(lun1);
con.addChild(lun2);
con.addChild(tempD1);
con.addChild(tempD2);
tempAnchor = makeAnchor(carMc, 1, con);
makebox(tempAnchor, con);
con.addChild(tempAnchor);
}
private function makeAnchor(box1:MovieClip, num:uint, container:DisplayObjectContainer):MovieClip{
var tempAnchor:MovieClip;
var anchorpx:Number;
var anchorpy:Number;
var lastAnchor:MovieClip = box1;
var i:int;
while (i < num) {
tempAnchor = new anchor();
tempAnchor.x = ((lastAnchor.x + lastAnchor.anchor2.x) - tempAnchor.anchor1.x);
tempAnchor.y = ((lastAnchor.y + lastAnchor.anchor2.y) - tempAnchor.anchor2.y);
container.addChild(tempAnchor);
world.addToWorld((tempAnchor.x / 30), (tempAnchor.y / 30), 0, 0, 3, 0, tempAnchor, false, "head");
(tempAnchor.bd as b2Body).m_angularDamping = 10000;
anchorpx = ((lastAnchor.x + lastAnchor.anchor2.x) / 30);
anchorpy = ((lastAnchor.y + lastAnchor.anchor2.y) / 30);
world.createRevoluteJoint(lastAnchor.bd, tempAnchor.bd, new b2Vec2(anchorpx, anchorpy));
lastAnchor = tempAnchor;
i++;
};
return (lastAnchor);
}
public function makebox(prevBox:MovieClip, container:DisplayObjectContainer):MovieClip{
var l1:MovieClip;
var l2:MovieClip;
var tempd1:MovieClip;
var tempd2:MovieClip;
var vec:b2Vec2;
var boxclass:* = getDefinitionByName(Carbodystr[carkind].toString());
var tb:MovieClip = (new (boxclass) as MovieClip);
tb.x = ((prevBox.x + prevBox.anchor2.x) - tb.anchor1.x);
tb.y = ((prevBox.y + prevBox.anchor2.y) - tb.anchor1.y);
world.addToWorld((tb.x / 30), (tb.y / 30), 0, carF, carD, carR, tb, false, "head");
l1 = (tb.getChildByName("lun1") as MovieClip);
l2 = (tb.getChildByName("lun2") as MovieClip);
cargohitmc = (tb.getChildByName("hit") as MovieClip);
var p:Point = MyMath.LtoG(container, l1);
l1.x = p.x;
l1.y = p.y;
p = MyMath.LtoG(container, l2);
l2.x = p.x;
l2.y = p.y;
world.makeBodyByYuanInside((l1.x / 30), (l1.y / 30), l1, lunD, lunF, lunR, false, "lun");
world.makeBodyByYuanInside((l2.x / 30), (l2.y / 30), l2, lunD, lunF, lunR, false, "lun");
world.createRevoluteJoint(l1.bd, tb.bd, (l1.bd as b2Body).GetWorldCenter(), false, 0, 0, false, 0, 150);
world.createRevoluteJoint(l2.bd, tb.bd, (l2.bd as b2Body).GetWorldCenter(), false, 0, 0, false, 0, 150);
world.createRevoluteJoint(prevBox.bd, tb.bd, new b2Vec2(((prevBox.x + prevBox.anchor2.x) / 30), ((prevBox.y + prevBox.anchor2.y) / 30)), true, ((-30 * Math.PI) / 180), ((30 * Math.PI) / 180));
container.addChild(tb);
container.addChild(l1);
container.addChild(l2);
if (carkind >= 3){
tempd1 = (tb.getChildByName("d1") as MovieClip);
tempd2 = (tb.getChildByName("d2") as MovieClip);
p = MyMath.LtoG(container, tempd1);
tempd1.x = p.x;
tempd1.y = p.y;
p = MyMath.LtoG(container, tempd2);
tempd2.x = p.x;
tempd2.y = p.y;
world.addToWorld((tempd1.x / 30), (tempd1.y / 30), 0, carF, carD, carR, tempd1, false, "sd");
world.addToWorld((tempd2.x / 30), (tempd2.y / 30), 0, carF, carD, carR, tempd2, false, "sd");
p = MyMath.LtoG(container, tempd1.anchor);
vec = (tempd1.bd as b2Body).GetWorldCenter();
vec.y = (vec.y - (7 / 30));
world.createRevoluteJoint(tb.bd, tempd1.bd, vec);
p = MyMath.LtoG(container, tempd2.anchor);
vec = (tempd2.bd as b2Body).GetWorldCenter();
vec.y = (vec.y - (7 / 30));
world.createRevoluteJoint(tb.bd, tempd2.bd, vec);
container.addChild(tempd1);
container.addChild(tempd2);
};
return (tb);
}
public function getSpeed():Number{
return ((carMc.bd as b2Body).GetLinearVelocity().x);
}
public function moveL():void{
var b:b2Body = (carMc.bd as b2Body);
b.ApplyTorque(-(spin));
}
public function moveR():void{
var b:b2Body = (carMc.bd as b2Body);
b.ApplyTorque(spin);
}
public function lunMoveR():void{
basestage.showchimney();
if (!playing){
playing = true;
};
motor1.EnableMotor(true);
motor2.EnableMotor(true);
motor2.SetMotorSpeed((-(lunspeed) * superadd));
motor2.SetMaxMotorTorque((power * superadd));
motor1.SetMotorSpeed(((-(lunspeed) * lunscale) * superadd));
motor1.SetMaxMotorTorque((power * superadd));
}
public function lunMoveL():void{
basestage.showchimney();
if (!playing){
playing = true;
};
motor1.EnableMotor(true);
motor2.EnableMotor(true);
motor2.SetMotorSpeed(lunspeed);
motor2.SetMaxMotorTorque(lunbrake);
motor1.SetMotorSpeed((lunspeed * lunscale));
motor1.SetMaxMotorTorque(lunbrake);
}
public function accelerate():void{
basestage.showchimney();
var b:b2Body = (carMc.bd as b2Body);
b.ApplyForce(new b2Vec2((Math.cos(((carMc.rotation * Math.PI) / 180)) * speedup), (Math.sin(((carMc.rotation * Math.PI) / 180)) * speedup)), b.GetWorldCenter());
superadd = 1.5;
}
public function common(){
superadd = 1;
}
public function release():void{
playing = false;
motor1.EnableMotor(false);
motor2.EnableMotor(false);
}
public function brake():void{
var v:b2Vec2 = (carMc.bd as b2Body).GetLinearVelocity();
(carMc.bd as b2Body).SetLinearVelocity(new b2Vec2(0, v.y));
}
public function stopcar(){
(carMc.bd as b2Body).m_linearDamping = 3000;
(lun1.bd as b2Body).m_angularDamping = 3000;
(lun2.bd as b2Body).m_angularDamping = 3000;
}
public function unbreak():void{
(lun1.bd as b2Body).m_angularDamping = 0;
(lun2.bd as b2Body).m_angularDamping = 0;
(carMc.bd as b2Body).m_linearDamping = 0;
}
public function breakDown():void{
release();
world.world.DestroyJoint(motor1);
world.world.DestroyJoint(motor2);
}
public function destroy(){
world.world.DestroyJoint(motor1);
world.world.DestroyJoint(motor2);
world.world.DestroyBody((carMc.bd as b2Body));
world.world.DestroyBody((lun1.bd as b2Body));
world.world.DestroyBody((lun2.bd as b2Body));
}
}
}//package Element
Section 86
//BaseCarry (Element.BaseCarry)
package Element {
import flash.display.*;
import UserdefinedClass.*;
import flash.geom.*;
import Box2D.Dynamics.Joints.*;
import Box2D.Dynamics.*;
import BaseClass.*;
public class BaseCarry {
public var carrymc:MovieClip;
public var carrylun:MovieClip;
public var carryp1:MovieClip;
public var carryp2:MovieClip;
public var blight:MovieClip;
public var slight1:MovieClip;
public var slight2:MovieClip;
public var carrymotor:b2RevoluteJoint;
public var carrypower:Number;// = 3000
public var carryway:int;// = 1
public var str:String;
public var lu:MovieClip;
public var basestage:BaseStage;
public function BaseCarry(bs:BaseStage, m:MovieClip, s:String, way:int=1){
super();
str = s;
lu = m;
basestage = bs;
carryway = way;
initmc();
jumpframe();
}
public function initmc(){
var g:Point;
carrymc = (lu.getChildByName(str) as MovieClip);
g = MyMath.LtoG(basestage.frontroad, carrymc);
carrymc.x = g.x;
carrymc.y = g.y;
Box2dFactory.getInstance().addToWorld((carrymc.x / 30), (carrymc.y / 30), carrymc.rotation, 10, 0.1, 0, carrymc, false, "carry", false);
carrylun = (lu.getChildByName(str.concat(0)) as MovieClip);
g = MyMath.LtoG(basestage.frontroad, carrylun);
carrylun.x = g.x;
carrylun.y = g.y;
Box2dFactory.getInstance().makeBodyByYuanInside((carrylun.x / 30), (carrylun.y / 30), carrylun, 0, 0, 0, false, "p");
carrymotor = (Box2dFactory.getInstance().createRevoluteJoint(carrylun.bd, carrymc.bd, (carrylun.bd as b2Body).GetWorldCenter(), false, 0, 0, false, 0, carrypower) as b2RevoluteJoint);
basestage.frontroad.addChild(carrymc);
basestage.frontroad.addChild(carrylun);
carrymotor.EnableMotor(true);
carrymotor.SetMotorSpeed(((carryway * Math.PI) * 0.2));
carrymotor.SetMaxMotorTorque(carrypower);
carryp1 = (lu.getChildByName(str.concat(1)) as MovieClip);
g = MyMath.LtoG(basestage.frontroad, carryp1);
carryp1.x = g.x;
carryp1.y = g.y;
Box2dFactory.getInstance().makeBodyByYuanInside((carryp1.x / 30), (carryp1.y / 30), carryp1, 0, 0, 0, false, "p");
carryp2 = (lu.getChildByName(str.concat(2)) as MovieClip);
g = MyMath.LtoG(basestage.frontroad, carryp2);
carryp2.x = g.x;
carryp2.y = g.y;
Box2dFactory.getInstance().makeBodyByYuanInside((carryp2.x / 30), (carryp2.y / 30), carryp2, 0, 0, 0, false, "p");
blight = (lu.getChildByName(str.concat(3)) as MovieClip);
slight1 = (lu.getChildByName(str.concat(4)) as MovieClip);
slight2 = (lu.getChildByName(str.concat(5)) as MovieClip);
}
public function jumpframe(){
var tempNum:int;
if ((carryway > 0)){
tempNum = 1;
} else {
tempNum = 2;
};
blight.gotoAndStop(tempNum);
slight1.gotoAndStop(tempNum);
slight2.gotoAndStop(tempNum);
}
public function changeway(){
carrymotor.EnableMotor(true);
carryway = (carryway * -1);
carrymotor.SetMotorSpeed(((carryway * Math.PI) * 0.4));
carrymotor.SetMaxMotorTorque(carrypower);
var tempNum:int;
if ((carryway > 0)){
tempNum = 1;
} else {
tempNum = 2;
};
blight.gotoAndStop(tempNum);
slight1.gotoAndStop(tempNum);
slight2.gotoAndStop(tempNum);
}
}
}//package Element
Section 87
//MyContactFilter (Element.MyContactFilter)
package Element {
import Box2D.Collision.Shapes.*;
import Box2D.Dynamics.*;
public class MyContactFilter extends b2ContactFilter {
public function MyContactFilter(){
super();
}
override public function ShouldCollide(fixtureA:b2Shape, fixtureB:b2Shape):Boolean{
var b1:b2Body = fixtureA.GetBody();
var b2:b2Body = fixtureB.GetBody();
var u1:Object = b1.GetUserData();
var u2:Object = b2.GetUserData();
if (((u1) && (u2))){
if ((((u1.type == "head")) && ((u2.type == "lun")))){
return (false);
};
if ((((u2.type == "head")) && ((u1.type == "lun")))){
return (false);
};
if ((((u1.type == "road")) && ((u2.type == "carry")))){
return (false);
};
if ((((u2.type == "road")) && ((u1.type == "carry")))){
return (false);
};
if ((((u1.type == "p")) && ((u2.type == "head")))){
return (false);
};
if ((((u2.type == "p")) && ((u1.type == "head")))){
return (false);
};
if ((((u1.type == "p")) && ((u2.type == "lun")))){
return (false);
};
if ((((u2.type == "p")) && ((u1.type == "lun")))){
return (false);
};
if ((((u1.type == "p")) && ((u2.type == "zhou")))){
return (false);
};
if ((((u2.type == "p")) && ((u1.type == "zhou")))){
return (false);
};
if ((((u1.type == "p")) && ((u2.type == "sd")))){
return (false);
};
if ((((u2.type == "p")) && ((u1.type == "sd")))){
return (false);
};
if ((((u1.type == "p")) && ((u2.type == "hit")))){
return (false);
};
if ((((u2.type == "p")) && ((u1.type == "hit")))){
return (false);
};
if ((((u1.type == "lun")) && ((u2.type == "item")))){
return (false);
};
if ((((u2.type == "lun")) && ((u1.type == "item")))){
return (false);
};
return (true);
//unresolved jump
};
return (true);
}
}
}//package Element
Section 88
//MyContactListener (Element.MyContactListener)
package Element {
import flash.display.*;
import Box2D.Dynamics.*;
import Box2D.Collision.*;
import BaseClass.*;
public class MyContactListener extends b2ContactListener {
public static var basestage:BaseStage;
public function MyContactListener(){
super();
}
override public function Add(point:b2ContactPoint):void{
var tempmc:MovieClip;
var b1:* = point.shape1.GetBody().GetUserData();
var b2:* = point.shape2.GetBody().GetUserData();
var body1:b2Body = point.shape1.GetBody();
var body2:b2Body = point.shape2.GetBody();
if (((b1) && (b2))){
if (((b1.type) && (b2.type))){
if ((((b1.type == "road")) && ((b2.type == "hit")))){
basestage.die((point.position.x * 30), (point.position.y * 30));
} else {
if ((((b2.type == "road")) && ((b1.type == "hit")))){
basestage.die((point.position.x * 30), (point.position.y * 30));
};
};
if ((((b1.type == "road")) && ((b2.type == "head")))){
MyData.die = true;
} else {
if ((((b2.type == "road")) && ((b1.type == "head")))){
MyData.die = true;
};
};
if ((((b1.type == "carry")) && ((b2.type == "hit")))){
basestage.die((point.position.x * 30), (point.position.y * 30));
} else {
if ((((b2.type == "carry")) && ((b1.type == "hit")))){
basestage.die((point.position.x * 30), (point.position.y * 30));
};
};
if ((((b1.type == "item")) && ((b2.type == "hit")))){
basestage.die((point.position.x * 30), (point.position.y * 30));
} else {
if ((((b2.type == "item")) && ((b1.type == "hit")))){
basestage.die((point.position.x * 30), (point.position.y * 30));
};
};
if ((((b1.type == "road")) && ((b2.type == "lun")))){
MyContactListener.basestage.showyan((body2.GetUserData().element as MovieClip));
} else {
if ((((b2.type == "road")) && ((b1.type == "lun")))){
MyContactListener.basestage.showyan((body2.GetUserData().element as MovieClip));
};
};
};
};
}
}
}//package Element
Section 89
//MyData (Element.MyData)
package Element {
import Gamestage.*;
public class MyData {
public var gamedata1:mydata;
public var gamedata2:mydata;
public var gamedata3:mydata;
public var gamedata4:mydata;
public var gamedata5:mydata;
public var gamedata6:mydata;
public var gamedata7:mydata;
public var gamedata8:mydata;
public var gamedata9:mydata;
public var gamedata10:mydata;
private var _gamedataground:Array;
private var _stageclassground:Array;
public var highscore:Array;
private var _cardata:Array;
private var _carvalue:Array;
public var caritemnum:Array;
private var _addvv:Array;
private var _itemnum:Array;
private var _cargo:Array;
private var _cargoprice:Array;
private var _itemprice:Array;
private var _succeed:Array;
private var _character:Array;
private var _addv:Array;
private var _material:Array;
private var _caritem:Array;
private var _charv:Array;
private var _BGB:Array;
private var _MaxCargoNum:Array;
private var _car1:Traindata;
private var _car2:Traindata;
private var _car3:Traindata;
private var _car4:Traindata;
public var cargoNUM:Array;
public var stagecargo:Array;
private var _materialcar:Traindata;
private var _car:Array;
public var stageunlock:Array;
public static var _instance:MyData;
public static var die:Boolean = false;
public function MyData(){
gamedata1 = new mydata();
gamedata2 = new mydata();
gamedata3 = new mydata();
gamedata4 = new mydata();
gamedata5 = new mydata();
gamedata6 = new mydata();
gamedata7 = new mydata();
gamedata8 = new mydata();
gamedata9 = new mydata();
gamedata10 = new mydata();
_gamedataground = new Array(gamedata1, gamedata2, gamedata3, gamedata4, gamedata5, gamedata6, gamedata7, gamedata8, gamedata9, gamedata10);
_stageclassground = new Array(GameStage1, GameStage2, GameStage3, GameStage4, GameStage5, GameStage6, GameStage7, GameStage8, GameStage9, GameStage10);
highscore = new Array(0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0);
_cardata = new Array(3, 0, 0, 0, 0);
_carvalue = new Array(300, 600, 900, 1200);
caritemnum = new Array([1, 1, 1, 1, 1], [1, 1, 1, 1, 1], [2, 2, 2, 2, 2], [3, 3, 3, 3, 3]);
_addvv = new Array(300, 600, 1200);
_itemnum = new Array([[1, 1, 1, 1, 1], [1, 1, 1, 1, 1], [3, 3, 3, 3, 3]], [[1, 1, 1, 1, 1], [1, 1, 1, 1, 1], [3, 3, 3, 3, 3]], [[1, 1, 1, 1, 1], [1, 1, 1, 1, 1], [3, 3, 3, 3, 3]]);
_cargo = new Array(100, 80, 80, 160, 200, 160, 260, 260, 700, 300, 500, 900, 600, 1700, 2000);
_cargoprice = new Array(0, 20, 40, 50, 20, 60, 80, 100, 120, 150);
_itemprice = new Array(30, 60, 90, 120, 150, 180, 210, 240, 270, 300, 0, 0, 0, 0, 0, 0);
_succeed = new Array();
_character = new Array();
_addv = new Array(0, 0, 0);
_material = new Array(0, 0, 0, 0, 0);
_caritem = new Array(0, 0, 0);
_charv = new Array(100, 200, 300, 400, 500, 600, 700, 800, 900);
_BGB = new Array("BG1", "BG2", "BG3", "BG4");
_MaxCargoNum = new Array([5, 3, 3, 2], [9, 6, 5, 4], [12, 8, 6, 6], [18, 12, 10, 10]);
_car1 = new Traindata();
_car2 = new Traindata();
_car3 = new Traindata();
_car4 = new Traindata();
cargoNUM = new Array(4, 4, 4, 4, 4, 4, 4, 2, 4, 4);
stagecargo = new Array("Item1", "Item2", "Item3", "Item4", "Item5", "Item6", "Item7", "Item8", "Item9", "Item10");
_materialcar = new Traindata();
_car = new Array(_car1, _car2, _car3, _car4);
stageunlock = new Array(1, 0, 0, 0, 0, 0, 0, 0, 0, 0);
super();
gamedata1.gameroad = new Array("r11", "r12", "r13");
gamedata1.frontroad = new Array("i11", "i12", "i13");
gamedata1.mission = 1;
gamedata1.gametime = 60;
gamedata1.JYTcargo = new Array(2, 6, 7);
gamedata1.JYTtime = new Array(55, 55, 45);
gamedata1.carry = new Array([["carry1", 1]], [], []);
gamedata1.bridge = new Array([["bridge1", 8]], [], [["bridge2", 6]]);
gamedata1.itemdrop = new Array([["item1", 14]], [["item1", 20]], [["item1", 11]]);
gamedata2.gameroad = new Array("r21", "r22", "r23");
gamedata2.frontroad = new Array("i21", "i22", "i23");
gamedata2.mission = 2;
gamedata2.gametime = 60;
gamedata2.JYTcargo = new Array(3, 4, 5);
gamedata2.JYTtime = new Array(45, 55, 45);
gamedata2.carry = new Array([["carry1", 1], ["carry2", 1], ["carry3", 1]], [["carry1", 1], ["carry2", 1]], [["carry1", 1]]);
gamedata2.bridge = new Array([], [["bridge1", 8]], []);
gamedata2.itemdrop = new Array([["item1", 10]], [["item1", 12]], [["item1", 15]]);
gamedata3.gameroad = new Array("r31", "r32", "r33");
gamedata3.frontroad = new Array("i31", "i32", "i33");
gamedata3.mission = 3;
gamedata3.gametime = 70;
gamedata3.JYTcargo = new Array(4, 10, 14);
gamedata3.JYTtime = new Array(60, 55, 45);
gamedata3.carry = new Array([["carry1", 1]], [["carry1", 1]], [["carry2", 1], ["carry3", 1]]);
gamedata3.bridge = new Array([["bridge1", 7], ["bridge2", 7]], [["bridge1", 14]], []);
gamedata3.itemdrop = new Array([["item1", 12]], [["item1", 14], ["item2", 13]], [["item1", 11], ["item2", 11], ["item3", 11]]);
gamedata4.gameroad = new Array("r41", "r42", "r43");
gamedata4.frontroad = new Array("i41", "i42", "i43");
gamedata4.mission = 4;
gamedata4.gametime = 80;
gamedata4.JYTcargo = new Array(4, 8, 10);
gamedata4.JYTtime = new Array(70, 55, 45);
gamedata4.carry = new Array([["carry1", 1]], [["carry1", 1], ["carry2", 1], ["carry3", 1]], []);
gamedata4.bridge = new Array([], [], [["bridge1", 8]]);
gamedata4.itemdrop = new Array([["item1", 10], ["item2", 10]], [["item1", 10], ["item2", 16]], [["item1", 12], ["item3", 19]]);
gamedata5.gameroad = new Array("r51", "r52", "r53", "r54");
gamedata5.frontroad = new Array("i51", "i52", "i53", "i54");
gamedata5.mission = 5;
gamedata5.gametime = 90;
gamedata5.JYTcargo = new Array(5, 8, 10);
gamedata5.JYTtime = new Array(75, 85, 80);
gamedata5.carry = new Array([["carry1", 1]], [["carry1", 1], ["carry2", 1]], [["carry1", 1], ["carry2", 1]], []);
gamedata5.bridge = new Array([["bridge1", 8]], [["bridge1", 12]], [], []);
gamedata5.itemdrop = new Array([["item1", 12], ["item2", 12]], [["item1", 13], ["item2", 13]], [["item1", 14], ["item2", 14]], [["item1", 10]]);
gamedata6.gameroad = new Array("r61", "r62", "r63", "r64");
gamedata6.frontroad = new Array("i61", "i62", "i63", "i64");
gamedata6.mission = 6;
gamedata6.gametime = 100;
gamedata6.JYTcargo = new Array(5, 7, 9);
gamedata6.JYTtime = new Array(80, 65, 60);
gamedata6.carry = new Array([["carry1", 1], ["carry2", 1]], [], [["carry1", 1], ["carry2", 1]], [["carry1", 1], ["carry2", 1]]);
gamedata6.bridge = new Array([], [["bridge1", 5]], [], []);
gamedata6.itemdrop = new Array([["item1", 14], ["item2", 14]], [["item1", 14], ["item2", 14]], [["item1", 17], ["item2", 13], ["item3", 11]], [["item1", 13], ["item2", 10]]);
gamedata7.gameroad = new Array("r71", "r72", "r73", "r74");
gamedata7.frontroad = new Array("i71", "i72", "i73", "i74");
gamedata7.mission = 7;
gamedata7.gametime = 120;
gamedata7.JYTcargo = new Array(5, 8, 10);
gamedata7.JYTtime = new Array(65, 60, 50);
gamedata7.carry = new Array([["carry1", 1]], [["carry1", 1], ["carry2", 1]], [["carry2", 1]], [["carry1", 1], ["carry2", 1]]);
gamedata7.bridge = new Array([], [["bridge1", 11]], [["bridge1", 10]], []);
gamedata7.itemdrop = new Array([["item1", 13]], [["item1", 12], ["item2", 12]], [["item1", 10], ["item2", 11]], [["item1", 13]]);
gamedata8.gameroad = new Array("r81", "r82", "r83", "r84");
gamedata8.frontroad = new Array("i81", "i82", "i83", "i84");
gamedata8.mission = 8;
gamedata8.gametime = 120;
gamedata8.JYTcargo = new Array(5, 2, 3);
gamedata8.JYTtime = new Array(85, 85, 80);
gamedata8.carry = new Array([["carry1", 1]], [["carry1", 1], ["carry2", 1], ["carry3", 1]], [["carry1", 1]], [["carry1", 1]]);
gamedata8.bridge = new Array([], [["bridge1", 7]], [["bridge1", 11]], []);
gamedata8.itemdrop = new Array([["item1", 10], ["item2", 10]], [["item1", 12], ["item2", 12]], [["item1", 11], ["item2", 11]], [["item1", 18], ["item2", 14]]);
gamedata9.gameroad = new Array("r91", "r92", "r93", "r94");
gamedata9.frontroad = new Array("i91", "i92", "i93", "i94");
gamedata9.mission = 9;
gamedata9.gametime = 120;
gamedata9.JYTcargo = new Array(6, 2, 2);
gamedata9.JYTtime = new Array(65, 75, 60);
gamedata9.carry = new Array([], [["carry1", 1], ["carry2", 1]], [["carry1", 1], ["carry2", 1], ["carry3", 1]], [["carry2", 1]]);
gamedata9.bridge = new Array([["bridge1", 9]], [], [], [["bridge1", 9]]);
gamedata9.itemdrop = new Array([], [["item1", 10], ["item2", 13], ["item3", 11]], [["item1", 12], ["item2", 14]], [["item1", 14], ["item2", 11]]);
gamedata10.gameroad = new Array("r101", "r102", "r103", "r104");
gamedata10.frontroad = new Array("i101", "i102", "i103", "i104");
gamedata10.mission = 10;
gamedata10.gametime = 120;
gamedata10.JYTcargo = new Array(6, 8, 10);
gamedata10.JYTtime = new Array(85, 90, 80);
gamedata10.carry = new Array([["carry1", 1], ["carry2", 1]], [["carry2", 1]], [["carry1", 1], ["carry2", 1], ["carry3", 1]], [["carry3", 1]]);
gamedata10.bridge = new Array([], [["bridge1", 10]], [], []);
gamedata10.itemdrop = new Array([["item1", 14], ["item2", 12]], [["item1", 13], ["item2", 10]], [["item1", 14], ["item2", 11], ["item3", 10]], [["item1", 12], ["item2", 13]]);
var i:int;
while (i < 20) {
succeed.push(false);
i++;
};
materialcar.addspeed = 3;
materialcar.spin = 25;
materialcar.brake = 50;
materialcar.power = 100;
materialcar.lunspeed = 15;
}
public function get gamedataground():Array{
return (_gamedataground);
}
public function get stageclassground():Array{
return (_stageclassground);
}
public function get cardata():Array{
return (_cardata);
}
public function set cardata(value:Array):void{
_cardata = value;
}
public function get carvalue():Array{
return (_carvalue);
}
public function set carvalue(value:Array):void{
_carvalue = value;
}
public function get addvv():Array{
return (_addvv);
}
public function set addvv(value:Array):void{
_addvv = value;
}
public function get cargo():Array{
return (_cargo);
}
public function set cargo(value:Array):void{
_cargo = value;
}
public function get cargoprice():Array{
return (_cargoprice);
}
public function set cargoprice(value:Array):void{
_cargoprice = value;
}
public function get succeed():Array{
return (_succeed);
}
public function set succeed(value:Array):void{
_succeed = value;
}
public function get character():Array{
return (_character);
}
public function set character(value:Array):void{
_character = value;
}
public function get addv():Array{
return (_addv);
}
public function set addv(value:Array):void{
_addv = value;
}
public function get charv():Array{
return (_charv);
}
public function set charv(value:Array):void{
_charv = value;
}
public function get BGB():Array{
return (_BGB);
}
public function set BGB(value:Array):void{
_BGB = value;
}
public function get car1():Traindata{
return (_car1);
}
public function set car1(value:Traindata):void{
_car1 = value;
}
public function get car2():Traindata{
return (_car2);
}
public function set car2(value:Traindata):void{
_car2 = value;
}
public function get car3():Traindata{
return (_car3);
}
public function set car3(value:Traindata):void{
_car3 = value;
}
public function get car4():Traindata{
return (_car4);
}
public function set car4(value:Traindata):void{
_car4 = value;
}
public function get car():Array{
return (_car);
}
public function set car(value:Array):void{
_car = value;
}
public function get MaxCargoNum():Array{
return (_MaxCargoNum);
}
public function get itemprice():Array{
return (_itemprice);
}
public function get material():Array{
return (_material);
}
public function set material(value:Array):void{
_material = value;
}
public function get caritem():Array{
return (_caritem);
}
public function set caritem(value:Array):void{
_caritem = value;
}
public function get itemnum():Array{
return (_itemnum);
}
public function get materialcar():Traindata{
return (_materialcar);
}
public function set materialcar(value:Traindata):void{
_materialcar = value;
}
public static function clear(){
_instance = null;
}
public static function getInstance():MyData{
if (_instance == null){
_instance = new (MyData);
};
return (_instance);
}
}
}//package Element
class mydata {
private var _gameroad:Array;
private var _frontroad:Array;
private var _gametime:int;
private var _mission:int;
private var _JYTcargo:Array;
private var _JYTtime:Array;
private var _carry:Array;
private var _itemdrop:Array;
private var _bridge:Array;
private function mydata(){
}
public function get gameroad():Array{
return (_gameroad);
}
public function set gameroad(value:Array):void{
_gameroad = value;
}
public function get gametime():int{
return (_gametime);
}
public function set gametime(value:int):void{
_gametime = value;
}
public function get mission():int{
return (_mission);
}
public function set mission(value:int):void{
_mission = value;
}
public function get frontroad():Array{
return (_frontroad);
}
public function set frontroad(value:Array):void{
_frontroad = value;
}
public function get JYTcargo():Array{
return (_JYTcargo);
}
public function set JYTcargo(value:Array):void{
_JYTcargo = value;
}
public function get JYTtime():Array{
return (_JYTtime);
}
public function set JYTtime(value:Array):void{
_JYTtime = value;
}
public function get carry():Array{
return (_carry);
}
public function set carry(value:Array):void{
_carry = value;
}
public function get itemdrop():Array{
return (_itemdrop);
}
public function set itemdrop(value:Array):void{
_itemdrop = value;
}
public function get bridge():Array{
return (_bridge);
}
public function set bridge(value:Array):void{
_bridge = value;
}
}
Section 90
//Traindata (Element.Traindata)
package Element {
public class Traindata {
private var _addspeed:int;
private var _spin:int;
private var _brake:int;
private var _power:int;
private var _lunspeed:int;
private var _MaxS:int;
private var _MaxB:int;
private var _MaxA:int;
private var _isBuy:Boolean;// = false
private var _count:int;// = 0
public function Traindata(){
super();
}
public function get addspeed():int{
return (_addspeed);
}
public function set addspeed(value:int):void{
_addspeed = value;
}
public function get spin():int{
return (_spin);
}
public function set spin(value:int):void{
_spin = value;
}
public function get brake():int{
return (_brake);
}
public function set brake(value:int):void{
_brake = value;
}
public function get power():int{
return (_power);
}
public function set power(value:int):void{
_power = value;
}
public function get lunspeed():int{
return (_lunspeed);
}
public function set lunspeed(value:int):void{
_lunspeed = value;
}
}
}//package Element
Section 91
//Base64 (fog.as3.utils.Base64)
package fog.as3.utils {
import flash.utils.*;
public class Base64 {
private static const BASE64_CHARS:String = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=";
public static const version:String = "1.1.0";
public function Base64(){
super();
throw (new Error("Base64 class is static container only"));
}
public static function encode(data:String):String{
var bytes:ByteArray = new ByteArray();
bytes.writeUTFBytes(data);
return (encodeByteArray(bytes));
}
public static function encodeByteArray(data:ByteArray):String{
var dataBuffer:Array;
var i:uint;
var j:uint;
var k:uint;
var output:String = "";
var outputBuffer:Array = new Array(4);
data.position = 0;
while (data.bytesAvailable > 0) {
dataBuffer = new Array();
i = 0;
while ((((i < 3)) && ((data.bytesAvailable > 0)))) {
dataBuffer[i] = data.readUnsignedByte();
i++;
};
outputBuffer[0] = ((dataBuffer[0] & 252) >> 2);
outputBuffer[1] = (((dataBuffer[0] & 3) << 4) | (dataBuffer[1] >> 4));
outputBuffer[2] = (((dataBuffer[1] & 15) << 2) | (dataBuffer[2] >> 6));
outputBuffer[3] = (dataBuffer[2] & 63);
j = dataBuffer.length;
while (j < 3) {
outputBuffer[(j + 1)] = 64;
j++;
};
k = 0;
while (k < outputBuffer.length) {
output = (output + BASE64_CHARS.charAt(outputBuffer[k]));
k++;
};
};
return (output);
}
public static function decode(data:String):String{
var bytes:ByteArray = decodeToByteArray(data);
return (bytes.readUTFBytes(bytes.length));
}
public static function decodeToByteArray(data:String):ByteArray{
var j:uint;
var k:uint;
var output:ByteArray = new ByteArray();
var dataBuffer:Array = new Array(4);
var outputBuffer:Array = new Array(3);
var i:uint;
while (i < data.length) {
j = 0;
while ((((j < 4)) && (((i + j) < data.length)))) {
dataBuffer[j] = BASE64_CHARS.indexOf(data.charAt((i + j)));
j++;
};
outputBuffer[0] = ((dataBuffer[0] << 2) + ((dataBuffer[1] & 48) >> 4));
outputBuffer[1] = (((dataBuffer[1] & 15) << 4) + ((dataBuffer[2] & 60) >> 2));
outputBuffer[2] = (((dataBuffer[2] & 3) << 6) + dataBuffer[3]);
k = 0;
while (k < outputBuffer.length) {
if (dataBuffer[(k + 1)] == 64){
break;
};
output.writeByte(outputBuffer[k]);
k++;
};
i = (i + 4);
};
output.position = 0;
return (output);
}
}
}//package fog.as3.utils
Section 92
//Debug (fog.as3.utils.Debug)
package fog.as3.utils {
public class Debug {
public static var Enabled:Boolean = true;
public static function log(s, s1="", s2="", s3="", s4="", s5="", s6=""):void{
if (!Debug.Enabled){
return;
};
var i = 1;
while (i < arguments.length) {
s = (s + (" " + arguments[i]));
i++;
};
trace(s);
}
}
}//package fog.as3.utils
Section 93
//JSON (fog.as3.utils.JSON)
package fog.as3.utils {
public class JSON {
public static function decode(source:String){
var at:Number;
var ch:String;
var _isDigit:Function;
var _isHexDigit:Function;
var _white:Function;
var _string:Function;
var _next:Function;
var _array:Function;
var _object:Function;
var _number:Function;
var _word:Function;
var _value:Function;
var _error:Function;
var source = source;
source = new String(source);
at = 0;
ch = " ";
_isDigit = function (c:String){
return (((("0" <= c)) && ((c <= "9"))));
};
_isHexDigit = function (c:String){
return (((((_isDigit(c)) || (((("A" <= c)) && ((c <= "F")))))) || (((("a" <= c)) && ((c <= "f"))))));
};
_error = function (m:String):void{
throw (new Error(m, (at - 1)));
};
_next = function (){
ch = source.charAt(at);
at = (at + 1);
return (ch);
};
_white = function ():void{
while (ch) {
if (ch <= " "){
_next();
} else {
if (ch == "/"){
switch (_next()){
case "/":
do {
} while (((((_next()) && (!((ch == "\n"))))) && (!((ch == "\r")))));
break;
case "*":
_next();
while (true) {
if (ch){
if (ch == "*"){
if (_next() == "/"){
_next();
break;
};
} else {
_next();
};
} else {
_error("Unterminated Comment");
};
};
break;
default:
_error("Syntax Error");
};
} else {
break;
};
};
};
};
_string = function (){
var t:*;
var u:*;
var i:* = "";
var s:* = "";
var outer:Boolean;
if (ch == "\""){
while (_next()) {
if (ch == "\""){
_next();
return (s);
};
if (ch == "\\"){
switch (_next()){
case "b":
s = (s + "\b");
break;
case "f":
s = (s + "\f");
break;
case "n":
s = (s + "\n");
break;
case "r":
s = (s + "\r");
break;
case "t":
s = (s + "\t");
break;
case "u":
u = 0;
i = 0;
while (i < 4) {
t = parseInt(_next(), 16);
if (!isFinite(t)){
outer = true;
break;
};
u = ((u * 16) + t);
i = (i + 1);
};
if (outer){
outer = false;
break;
};
s = (s + String.fromCharCode(u));
break;
default:
s = (s + ch);
};
} else {
s = (s + ch);
};
};
};
_error("Bad String");
return (null);
};
_array = function (){
var a:Array = [];
if (ch == "["){
_next();
_white();
if (ch == "]"){
_next();
return (a);
};
while (ch) {
a.push(_value());
_white();
if (ch == "]"){
_next();
return (a);
};
if (ch != ","){
break;
};
_next();
_white();
};
};
_error("Bad Array");
return (null);
};
_object = function (){
var k:* = {};
var o:* = {};
if (ch == "{"){
_next();
_white();
if (ch == "}"){
_next();
return (o);
};
while (ch) {
k = _string();
_white();
if (ch != ":"){
break;
};
_next();
o[k] = _value();
_white();
if (ch == "}"){
_next();
return (o);
};
if (ch != ","){
break;
};
_next();
_white();
};
};
_error("Bad Object");
};
_number = function (){
var v:*;
var n:* = "";
var hex:String = "";
var sign:String = "";
if (ch == "-"){
n = "-";
sign = n;
_next();
};
if (ch == "0"){
_next();
if ((((ch == "x")) || ((ch == "X")))){
_next();
while (_isHexDigit(ch)) {
hex = (hex + ch);
_next();
};
if (hex == ""){
_error("mal formed Hexadecimal");
} else {
return (Number(((sign + "0x") + hex)));
};
} else {
n = (n + "0");
};
};
while (_isDigit(ch)) {
n = (n + ch);
_next();
};
if (ch == "."){
n = (n + ".");
while (((((_next()) && ((ch >= "0")))) && ((ch <= "9")))) {
n = (n + ch);
};
};
v = (1 * n);
if (!isFinite(v)){
_error("Bad Number");
} else {
return (v);
};
return (NaN);
};
_word = function (){
switch (ch){
case "t":
if ((((((_next() == "r")) && ((_next() == "u")))) && ((_next() == "e")))){
_next();
return (true);
};
break;
case "f":
if ((((((((_next() == "a")) && ((_next() == "l")))) && ((_next() == "s")))) && ((_next() == "e")))){
_next();
return (false);
};
break;
case "n":
if ((((((_next() == "u")) && ((_next() == "l")))) && ((_next() == "l")))){
_next();
return (null);
};
break;
};
_error("Syntax Error");
return (null);
};
_value = function (){
_white();
switch (ch){
case "{":
return (_object());
case "[":
return (_array());
case "\"":
return (_string());
case "-":
return (_number());
default:
return (((((ch >= "0")) && ((ch <= "9")))) ? _number() : _word());
};
};
return (_value());
}
public static function encode(o):String{
var c:String;
var i:Number;
var l:Number;
var v:*;
var prop:String;
var _local8:Number;
var s:String = "";
switch (typeof(o)){
case "object":
if (o){
if ((o is Array)){
l = o.length;
i = 0;
while (i < l) {
v = encode(o[i]);
if (s){
s = (s + ",");
};
s = (s + v);
i++;
};
return ((("[" + s) + "]"));
} else {
if (typeof(o.toString) != "undefined"){
for (prop in o) {
v = o[prop];
if (((!((typeof(v) == "undefined"))) && (!((typeof(v) == "function"))))){
v = encode(v);
if (s){
s = (s + ",");
};
s = (s + ((encode(prop) + ":") + v));
};
};
return ((("{" + s) + "}"));
};
};
};
return ("null");
case "number":
return ((isFinite(o)) ? String(o) : "null");
case "string":
l = o.length;
s = "\"";
i = 0;
while (i < l) {
c = o.charAt(i);
if (c >= " "){
if ((((c == "\\")) || ((c == "\"")))){
s = (s + "\\");
};
s = (s + c);
} else {
switch (c){
case "\b":
s = (s + "\\b");
break;
case "\f":
s = (s + "\\f");
break;
case "\n":
s = (s + "\\n");
break;
case "\r":
s = (s + "\\r");
break;
case "\t":
s = (s + "\\t");
break;
default:
_local8 = c.charCodeAt();
s = (s + (("\\u00" + Math.floor((_local8 / 16)).toString(16)) + (_local8 % 16).toString(16)));
};
};
i = (i + 1);
};
return ((s + "\""));
case "boolean":
return (String(o));
default:
return ("null");
};
}
}
}//package fog.as3.utils
Section 94
//FogDevAPI (fog.as3.FogDevAPI)
package fog.as3 {
import flash.events.*;
import flash.display.*;
import fog.as3.utils.*;
import flash.ui.*;
public class FogDevAPI extends MovieClip {
public var Events:FogDevEvents;
public var Preloader:FogDevPreloader;
public var Tracking:FogDevTracking;
public var Assets:FogDevAssets;
public var Social:FogDevSocial;
public var Storage:FogDevStorage;
public var Clip:Object;
public var Options:Object;
public var Sandbox:Boolean;// = false
public var Width:int;
public var Height:int;
public var Version:String;// = "2.2"
public var Build:String;// = "0.16.0.1"
private var TestID:String;// = "4d4018e4964ac"
public var ID:String;// = ""
public var Game:Object;
public var Locked:Boolean;// = false
public function FogDevAPI(opt:Object){
var opt = opt;
Clip = new Object();
Options = new Object();
Game = new Object();
super();
var defaults:Object = {};
Options = parseOptions(opt, defaults);
Clip = Options.root;
Game.URL = "";
Game.Tag = "";
Game.Title = "";
Game.Related = new Array();
ID = (Options.id) ? Options.id : "";
Sandbox = (Options.sandbox) ? true : false;
if (ID == "YOUR_ID_HERE"){
ID = TestID;
};
Clip.stage.addChild(this);
Width = (Options.width) ? Options.width : Clip.stage.stageWidth;
Height = (Options.height) ? Options.height : Clip.stage.stageHeight;
this.Events = new FogDevEvents(this);
this.Preloader = new FogDevPreloader(this);
this.Tracking = new FogDevTracking(this);
this.Assets = new FogDevAssets(this);
this.Social = new FogDevSocial(this);
this.Storage = new FogDevStorage(this);
var ctxMenu:ContextMenu = new ContextMenu();
ctxMenu.hideBuiltInItems();
var ctx1:ContextMenuItem = new ContextMenuItem("Play More Games");
ctx1.addEventListener(ContextMenuEvent.MENU_ITEM_SELECT, function (e:ContextMenuEvent):void{
Tracking.GotoURL();
});
var ctx2:ContextMenuItem = new ContextMenuItem("Free Games For Your Website");
ctx2.addEventListener(ContextMenuEvent.MENU_ITEM_SELECT, function (e:ContextMenuEvent):void{
Tracking.GotoURL("http://www.freegamesforyourwebsite.com/");
});
var ctx3:ContextMenuItem = new ContextMenuItem("Copyright © Free Online Games");
ctx3.separatorBefore = true;
var ctx4:ContextMenuItem = new ContextMenuItem(("FOG API Version " + Version));
ctx4.addEventListener(ContextMenuEvent.MENU_ITEM_SELECT, function (e:ContextMenuEvent):void{
Tracking.GotoURL(Tracking.DevURL);
});
ctxMenu.customItems.push(ctx1, ctx2, ctx3, ctx4);
Clip.contextMenu = ctxMenu;
Debug.log(" ");
Debug.log("- *", " ", (((("Welcome to FogDevAPI v" + this.Version) + " (Build ") + this.Build) + ")"));
Debug.log("- *", " ", "If you need assistance or examples for this API, please visit:");
Debug.log("- *", " ", "; http://www.marcqualie.com/projects/fogdev/");
Debug.log("- *");
Debug.log("- *", " ", "ID:", ID, (Sandbox) ? " (This Game is running in Sandbox Mode)" : "");
Debug.log("- *", " ", "Domain:", (((Tracking.Info.domain + " (") + (Tracking.isFogDomain()) ? "Internal" : "External") + ")"));
Debug.log("- *", " ", "Resolution:", Width, " x ", Height);
if (ID == TestID){
Debug.log(" ");
Debug.log("- *", " ", "=| This is a Demo ID. Please update your ID as soon as possible! |=");
};
}
public function debug(s:String):void{
return (Debug.log(s));
}
private function parseOptions(options:Object, defaults:Object):Object{
var k:String;
var optcopy:Object = {};
for (k in defaults) {
optcopy[k] = defaults[k];
};
if (options){
for (k in options) {
optcopy[k] = options[k];
};
};
return (optcopy);
}
public function LibraryCall(f:String, o:Object){
var f = f;
var o = o;
if (Tracking.Library[f]){
return (Tracking.Library[f](o));
} else {
trace((("> Library Error: " + f) + " function not found"));
};
//unresolved jump
var _slot1 = e;
trace(("> Fatal Library Error: " + _slot1.message));
}
public function SiteLock():void{
Locked = true;
}
}
}//package fog.as3
Section 95
//FogDevAssets (fog.as3.FogDevAssets)
package fog.as3 {
import flash.display.*;
public class FogDevAssets extends MovieClip {
private var Core:FogDevAPI;
private var MiniLogoClass:Class;
public function FogDevAssets(C:FogDevAPI){
MiniLogoClass = FogDevAssets_MiniLogoClass;
super();
Core = C;
}
public function MiniLogo():MovieClip{
var m:MovieClip = (new MiniLogoClass() as MovieClip);
return (m);
}
}
}//package fog.as3
Section 96
//FogDevAssets_MiniLogoClass (fog.as3.FogDevAssets_MiniLogoClass)
package fog.as3 {
import mx.core.*;
public class FogDevAssets_MiniLogoClass extends MovieClipAsset {
public function FogDevAssets_MiniLogoClass(){
super();
}
}
}//package fog.as3
Section 97
//FogDevEvents (fog.as3.FogDevEvents)
package fog.as3 {
public class FogDevEvents {
private var Core:FogDevAPI;
public var TrackingComplete:String;// = "trackingComplete"
public var StorageLoaded:String;// = "storageLoaded"
public function FogDevEvents(C:FogDevAPI){
super();
Core = C;
}
}
}//package fog.as3
Section 98
//FogDevPreloader (fog.as3.FogDevPreloader)
package fog.as3 {
import flash.events.*;
import flash.display.*;
import flash.utils.*;
public class FogDevPreloader extends MovieClip {
public const LogoSpin:Class;
public const LogoStill:Class;
public const PreloaderHolder:Class;
public const ProgressBar:Class;
public const ProgressText:Class;
public const VoiceOver:Class;
public var Core:FogDevAPI;
public var IDE:String;
public var Background:Sprite;
public var Logo:MovieClip;
public var Logo2:MovieClip;
public var PreloaderClip:MovieClip;
public var ProgBar:MovieClip;
public var ProgText:MovieClip;
public var Button:MovieClip;
public var TimerStart:int;
public var PreloaderSize:int;// = 0
public var Density:int;// = 10
public var Duration:int;// = 5000
public var DurationFade:int;// = 1000
public var DurationWait:int;// = 2000
public var FadeSteps:int;// = 50
public var Percent:int;
public var PercentGame:Number;
public var PercentDura:Number;
public var FlyingFogDisabled:Boolean;// = false
private var g:Graphics;
public function FogDevPreloader(C:FogDevAPI){
LogoSpin = FogDevPreloader_LogoSpin;
LogoStill = FogDevPreloader_LogoStill;
PreloaderHolder = FogDevPreloader_PreloaderHolder;
ProgressBar = FogDevPreloader_ProgressBar;
ProgressText = FogDevPreloader_ProgressText;
VoiceOver = FogDevPreloader_VoiceOver;
Background = new Sprite();
super();
Core = C;
SetBackgroundColor(0);
}
public function SetBackground(mv:MovieClip):void{
Background.addChild(mv);
}
public function SetBackgroundColor(cl:int):void{
g = Background.graphics;
g.clear();
g.beginFill(cl);
g.drawRect(0, 0, Core.Width, Core.Height);
g.endFill();
}
public function Start(F=null):void{
var F = F;
if (typeof(F) == "function"){
Core.addEventListener("loaded", F);
} else {
Core.addEventListener("loaded", function (e:Event):void{
Core.Clip.play();
});
};
TimerStart = getTimer();
Core.Tracking.Ping();
Core.addChild(this);
PreloaderSize = root.loaderInfo.bytesLoaded;
if (PreloaderSize == root.loaderInfo.bytesTotal){
PreloaderSize = 0;
};
addChild(Background);
Logo = (new LogoStill() as MovieClip);
Logo.x = (Core.Width / 2);
Logo.y = ((Core.Height / 2) - (Logo.height / 4));
addChild(Logo);
PreloaderClip = (new PreloaderHolder() as MovieClip);
PreloaderClip.x = Logo.x;
PreloaderClip.y = ((Logo.y + (Logo.height / 2)) + (PreloaderClip.height / 2));
addChild(PreloaderClip);
ProgBar = (new ProgressBar() as MovieClip);
ProgBar.x = -39;
ProgBar.y = -8.1;
PreloaderClip.addChild(ProgBar);
ProgText = (new ProgressText() as MovieClip);
ProgText.stop();
ProgText.x = -62.8;
ProgText.y = -14.1;
ProgText.width = 17.6;
ProgText.height = 21.1;
PreloaderClip.addChild(ProgText);
Button = new MovieClip();
Button.buttonMode = true;
g = Button.graphics;
g.beginFill(0);
g.drawRect(0, 0, Core.Width, Core.Height);
g.endFill();
Button.alpha = 0;
Button.GotoURL = Core.Tracking.HomeURL;
Button.addEventListener(MouseEvent.CLICK, Core.Tracking.Click);
addChild(Button);
if (DurationFade > Duration){
Duration = DurationFade;
};
Core.Clip.stop();
FadeIn();
stage.addEventListener(Event.ENTER_FRAME, showProgress);
}
private function showProgress(e:Event):void{
PercentGame = Math.floor((((root.loaderInfo.bytesLoaded - PreloaderSize) / (root.loaderInfo.bytesTotal - PreloaderSize)) * 100));
PercentDura = Math.floor((((getTimer() - TimerStart) / Duration) * 100));
Percent = Math.round(Math.min(Math.min(PercentGame, PercentDura), 100));
ProgText.gotoAndStop((Percent + 1));
ProgBar.width = (Percent * 0.98);
if (Percent > 99){
stage.removeEventListener(Event.ENTER_FRAME, showProgress);
SpinLogo();
Wait();
};
loadingBar(e);
}
public function SpinLogo():void{
Logo2 = (new LogoSpin() as MovieClip);
Logo2.x = Logo.x;
Logo2.y = Logo.y;
addChild(Logo2);
Logo2.play();
removeChild(Logo);
swapChildren(Button, Logo2);
}
private function loadingBar(e:Event):void{
if (FlyingFogDisabled){
return;
};
if ((getTimer() % Math.round((root.stage.frameRate / Density))) === 0){
};
}
public function addObject(o):void{
addChild(o);
}
private function Wait():void{
setTimeout(Unload, DurationWait);
}
private function Unload():void{
if (Core.Game.Disabled){
trace("> Game will never start! :)");
} else {
if (Core.Tracking.Library){
Core.Tracking.LibraryCall("LoadHandle", {});
} else {
FadeOut();
};
};
}
private function FadeIn():void{
var i:int;
if (DurationFade < 1){
return;
};
alpha = 0;
var l:int = FadeSteps;
while (i < l) {
setTimeout(function (t:DisplayObject):void{
if (t){
t.alpha = (t.alpha + (1 / FadeSteps));
};
}, ((DurationFade / FadeSteps) * i), this);
i = (i + 1);
};
}
public function FadeOut():void{
var i:int;
setTimeout(Clean, 1000);
Core.dispatchEvent(new Event("loaded"));
if (DurationWait < 1){
return;
};
alpha = 1;
var l:int = FadeSteps;
while (i < l) {
setTimeout(function (t:DisplayObject):void{
if (t){
t.alpha = (t.alpha - (1 / FadeSteps));
};
}, ((DurationFade / FadeSteps) * i), this);
i = (i + 1);
};
}
public function Clean(force:Boolean=false):void{
Button.removeEventListener(MouseEvent.CLICK, Core.Tracking.Click);
var i:int;
while (i < numChildren) {
removeChildAt(0);
i++;
};
Core.removeChild(this);
Core.dispatchEvent(new Event("cleaned"));
}
public function DisableFlyingFog():void{
FlyingFogDisabled = true;
}
}
}//package fog.as3
Section 99
//FogDevPreloader_LogoSpin (fog.as3.FogDevPreloader_LogoSpin)
package fog.as3 {
import flash.display.*;
import mx.core.*;
public class FogDevPreloader_LogoSpin extends MovieClipAsset {
public var DisplayText:DisplayObject;
public function FogDevPreloader_LogoSpin(){
super();
}
}
}//package fog.as3
Section 100
//FogDevPreloader_LogoStill (fog.as3.FogDevPreloader_LogoStill)
package fog.as3 {
import mx.core.*;
public class FogDevPreloader_LogoStill extends MovieClipAsset {
public function FogDevPreloader_LogoStill(){
super();
}
}
}//package fog.as3
Section 101
//FogDevPreloader_PreloaderHolder (fog.as3.FogDevPreloader_PreloaderHolder)
package fog.as3 {
import mx.core.*;
public class FogDevPreloader_PreloaderHolder extends MovieClipAsset {
public function FogDevPreloader_PreloaderHolder(){
super();
}
}
}//package fog.as3
Section 102
//FogDevPreloader_ProgressBar (fog.as3.FogDevPreloader_ProgressBar)
package fog.as3 {
import flash.display.*;
import mx.core.*;
public class FogDevPreloader_ProgressBar extends MovieClipAsset {
public var DisplayText:DisplayObject;
public function FogDevPreloader_ProgressBar(){
super();
}
}
}//package fog.as3
Section 103
//FogDevPreloader_ProgressText (fog.as3.FogDevPreloader_ProgressText)
package fog.as3 {
import flash.display.*;
import mx.core.*;
public class FogDevPreloader_ProgressText extends MovieClipAsset {
public var DisplayText:DisplayObject;
public function FogDevPreloader_ProgressText(){
super();
}
}
}//package fog.as3
Section 104
//FogDevPreloader_VoiceOver (fog.as3.FogDevPreloader_VoiceOver)
package fog.as3 {
import flash.display.*;
import mx.core.*;
public class FogDevPreloader_VoiceOver extends SoundAsset {
public var DisplayText:DisplayObject;
public function FogDevPreloader_VoiceOver(){
super();
}
}
}//package fog.as3
Section 105
//FogDevSocial (fog.as3.FogDevSocial)
package fog.as3 {
import flash.events.*;
import flash.net.*;
import flash.display.*;
import fog.as3.utils.*;
public class FogDevSocial extends MovieClip {
private var Core:FogDevAPI;
private var fakeauth:Boolean;// = false
private var restserver:String;// = "http://master.freeonlinegames.com/api/rest"
public var uid:int;// = 0
public var user:Object;
private var reqCache:Object;
private var anonFunc:Function;
public function FogDevSocial(C:FogDevAPI):void{
user = new Object();
reqCache = new Object();
anonFunc = function ():void{
};
super();
Core = C;
user = {id:0, token:"", name:"guest", nick:"Guest", score:0, highscore:0, thumb:""};
Core.addEventListener(Core.Events.TrackingComplete, init);
}
public function init(e:Event=null):void{
call("auth");
}
public function call(m:String="", d:String="", cb:Function=null):void{
var sp2:Array;
var r:URLRequest = new URLRequest(((restserver + "/") + m));
r.method = "POST";
r.data = d;
var sp:Array = d.split("&");
var v:Object = new Object();
var i:int;
var l2:int = sp.length;
while (i < l2) {
sp2 = sp[i].split("=");
v[sp2[0]] = sp2[1];
i++;
};
var l:URLLoader = new URLLoader();
l.addEventListener(Event.COMPLETE, (v.raw) ? bindVars(cb, m, responseRaw) : bindVars(cb, m, response));
l.addEventListener(IOErrorEvent.IO_ERROR, callerror);
l.load(r);
}
private function bindVars(cb:Function, m:String, ex:Function):Function{
var cb = cb;
var m = m;
var ex = ex;
return (function (e:Event):void{
ex(e, cb, m);
});
}
private function response(e:Event, cb:Function, m:String):void{
var j:Object;
var e = e;
var cb = cb;
var m = m;
var data:String = e.target.data;
j = JSON.decode(data);
if (j.uid){
uid = j.uid;
user.id = uid;
user.nick = j.nick;
user.name = j.name;
};
if (typeof(cb) == "function"){
cb(j);
};
//unresolved jump
var _slot1 = e;
Core.debug(("JSON Error: " + _slot1.message));
}
private function responseRaw(e:Event=null, cb:Function=null, m:String=null):void{
var data:String = e.target.data;
if (typeof(cb) == "function"){
cb(data);
};
}
private function callerror(e:IOErrorEvent):void{
Core.debug("> Social Request Error");
Core.debug(("> " + e.text));
}
public function fakeUser(fu:Object):void{
var key:String;
fakeauth = true;
for (key in fu) {
user[key] = fu[key];
};
}
public function getUser():Object{
return (user);
}
public function doLogin(user:String, pass:String, cacllback:Function):void{
}
public function doSignup(user:String, email:String):void{
}
public function getBadges():Object{
var o:Object = new Object();
return (o);
}
}
}//package fog.as3
Section 106
//FogDevStorage (fog.as3.FogDevStorage)
package fog.as3 {
import flash.net.*;
import fog.as3.utils.*;
public class FogDevStorage {
public var Core:FogDevAPI;
public var DataID:String;// = ""
public var Data:SharedObject;
public var Locals:Array;
public var CurrentData:String;// = ""
public var LastSave:String;// = ""
public var Connected:Boolean;// = false
private var callback:Function;
public function FogDevStorage(C:FogDevAPI):void{
Locals = new Array();
callback = function ():void{
};
super();
Core = C;
if (!Core.Social){
throw (new Error("You cannot use FogAPI.Storage Plugin without loading FogAPI.Social Plugin first"));
};
DataID = ((Core.Game.ID + ".") + Core.Social.uid);
Data = SharedObject.getLocal(DataID);
}
public function GetLocal(Name:String=""):SharedObject{
var l:SharedObject = SharedObject.getLocal(((DataID + ".") + Name));
Locals.push([Name, l]);
return (l);
}
public function Sync():void{
var i:int;
var ii:int = Locals.length;
while (i < ii) {
Set(("_" + Locals[i][0]), Locals[i][1].data, false);
i++;
};
Save();
}
public function Clear(LiveSave:Boolean=true):void{
var i:int;
var ii:int = Locals.length;
while (i < ii) {
Locals[i][1].clear();
i++;
};
Data.clear();
if (LiveSave){
Save();
};
}
public function Get(Key:String){
return (Data.data[Key]);
}
public function Set(Key, Value=true, Sync:Boolean=true):Boolean{
var k:*;
if (typeof(Key) == "object"){
for (k in Key) {
Key[k] = Set(k, Key[k]);
};
return (Key);
};
Data.data[Key] = Value;
if (Sync){
Save();
};
return (true);
}
public function Save():Boolean{
if (!Connected){
throw (new Error("You can't save data to the server when the game is not synced. Please use FogAPI.Storage.Load() to Initialize Sync"));
};
CurrentData = Encode(Data.data);
Core.debug((("Saving " + CurrentData.length) + " bytes of data"));
if (!Core.Social.uid){
Core.debug("> to Flash Local");
return (false);
};
Core.debug("> to FogAPI Server");
if (CurrentData != LastSave){
LastSave = CurrentData;
return ((Core.Social.call("storage.save", ((("guq=" + Core.ID) + "&data=") + CurrentData))) ? true : false);
//unresolved jump
};
return (true);
}
public function Encode(raw):String{
var d:* = raw;
d = JSON.encode(d);
d = Base64.encode(d);
return (d);
}
public function Load(cb:Function=null):void{
callback = cb;
Connected = true;
Core.debug(" ");
Core.debug("Attempting to load Storage");
if (!Core.Social.uid){
LoadResponse();
} else {
Core.Social.call("storage.load", (("guq=" + Core.ID) + "&raw=1"), LoadResponse);
};
}
public function LoadResponse(data:String=""):void{
var d:Object;
var k:String;
var l:SharedObject;
var o:*;
trace(" ");
trace("Server Storage Load Response");
var raw:String = data;
if (!raw){
Clear(false);
Core.debug("> No server storage. Reverting to local flash storage");
Core.debug((("> Loaded " + Data.size) + " bytes from local memory"));
} else {
Core.debug((("> Loaded " + raw.length) + " bytes of data from FogAPI Server"));
Clear(false);
d = Decode(raw);
for (k in d) {
if (k.indexOf("_") === 0){
l = GetLocal(k.substr(1));
for (o in d[k]) {
l.data[o] = d[k][o];
};
} else {
Data.data[k] = d[k];
};
};
};
if (callback != null){
callback();
};
}
public function Decode(raw:String):Object{
var r:String = raw;
var d:String = Base64.decode(r);
var j:Object = JSON.decode(d);
return (j);
}
}
}//package fog.as3
Section 107
//FogDevTracking (fog.as3.FogDevTracking)
package fog.as3 {
import flash.events.*;
import flash.net.*;
import flash.display.*;
import fog.as3.utils.*;
import flash.system.*;
public class FogDevTracking {
private var Core:FogDevAPI;
public var HomeURL:String;// = "http://www.freeonlinegames.com/"
public var GameURL:String;// = "http://www.freeonlinegames.com/game/{game.url}.html"
public var TagURL:String;// = "http://www.freeonlinegames.com/tag/{game.tag}/"
public var DevURL:String;// = "http://www.fogdev.com/"
public var FGFYWURL:String;// = "http://www.freegamesforyourwebsite.com/game/{game.url}/"
public var WalkthroughURL:String;// = "http://www.freeonlinegames.com/walkthrough/{game.url}.html"
public var Info:Object;
public var LocalMode:Boolean;// = false
public var Server:String;// = "x.fogdev.com"
private var LibFile:String;// = "api/library-v2.swf"
private var LibPath:String;// = ""
public var Library:MovieClip;
private var rLoader:Loader;
private var rRequest:URLRequest;
public function FogDevTracking(C:FogDevAPI){
Info = new Object();
super();
Core = C;
Info = GetUrlInfo(Core.root.loaderInfo.url);
}
public function Click(e:MouseEvent):void{
var u:String = e.currentTarget.GotoURL;
GotoURL(u);
}
public function GotoURL(u:String=""):void{
var base:String = (u) ? u : HomeURL;
if (base.indexOf("{game.url}") > -1){
if (Core.Game.URL.length > 0){
base = base.replace("{game.url}", Core.Game.URL);
base = base.replace("{game.tag}", Core.Game.Tag);
} else {
trace("> Tracking Error: FogAPI.Game.URL is not defined");
base = base.replace("{game.url}", Core.ID);
};
};
if (base.indexOf("{game.tag}") > -1){
if (Core.Game.Tag.length > 0){
trace(("Tag: " + Core.Game.Tag));
base = base.replace("{game.tag}", Core.Game.Tag);
} else {
trace("> Tracking Error: FogAPI.Game.Tag is not defined");
base = base.replace("{game.tag}", "misc-games");
};
};
var pars:String = ((("?utm_source=" + Info.domain) + "&utm_medium=api-game&utm_campaign=") + Core.ID);
if (isFogDomain()){
pars = "";
};
var url:String = (base + pars);
trace(" ");
trace("Tracking: ", url);
var LibCallSuccess:Boolean = (Core.ID) ? Core.LibraryCall("GotoURL", {url:url}) : false;
if (!LibCallSuccess){
trace(("GotoURL (Local): " + url));
if (Core.Sandbox){
return;
};
navigateToURL(new URLRequest(url), "_blank");
};
}
public function Ping(t:String=""):void{
var t = t;
Debug.log(" ");
Debug.log("Remote Tracking");
if (Core.Sandbox){
Debug.log("> Disabled due Sandbox. Try correcting your ID?");
return;
};
Security.allowDomain(Server);
Security.loadPolicyFile((("http://" + Server) + "/crossdomain.xml"));
LibPath = ((((((("http://" + Server) + "/") + LibFile) + "?v=") + Core.Version) + "&c=") + Math.random());
Debug.log(("> SWF: " + LibPath));
rLoader = new Loader();
rRequest = new URLRequest(LibPath);
rLoader.contentLoaderInfo.addEventListener(Event.COMPLETE, function (e:Event):void{
var e = e;
Library = MovieClip(e.target.content);
Library.Connect(Core);
//unresolved jump
var _slot1 = e;
Library = null;
Debug.log("> Corrupt Library: ", e.message);
});
rLoader.contentLoaderInfo.addEventListener(IOErrorEvent.IO_ERROR, function (e:IOErrorEvent):void{
Debug.log(("> IO Error (SWF): " + e.text));
});
rLoader.contentLoaderInfo.addEventListener(HTTPStatusEvent.HTTP_STATUS, function (e:HTTPStatusEvent):void{
});
rLoader.load(rRequest);
}
public function LibraryCall(f:String, o:Object){
return (Core.LibraryCall(f, o));
}
private function GetUrlInfo(url:String):Object{
var urlStart:Number;
var urlEnd:Number;
var LastDot:Number;
var domEnd:Number;
LocalMode = new RegExp("file://").test(url);
var domain:String = "";
var uri = "";
if (LocalMode){
domain = "local";
uri = "";
} else {
urlStart = (url.indexOf("://") + 3);
urlEnd = url.indexOf("/", urlStart);
domain = url.substring(urlStart, urlEnd);
LastDot = (domain.lastIndexOf(".") - 1);
domEnd = (domain.lastIndexOf(".", LastDot) + 1);
uri = url.substr(urlEnd);
};
return ({domain:domain, uri:uri});
}
public function isFogDomain():Boolean{
return (((((((((Info.domain.indexOf("freeonlinegames.com") > -1)) || ((Info.domain.indexOf("fog.com") > -1)))) || ((Info.domain.indexOf("fogdev.com") > -1)))) || ((Info.domain.indexOf("freegamesforyourwebsite.com") > -1)))) ? true : false);
}
}
}//package fog.as3
Section 108
//GameStage1 (Gamestage.GameStage1)
package Gamestage {
import BaseClass.*;
public class GameStage1 extends BaseStage {
public function GameStage1(mainobj:Object){
super(mainobj);
}
override public function setcarxy():void{
carxy = new Array(462, 428);
}
}
}//package Gamestage
Section 109
//GameStage10 (Gamestage.GameStage10)
package Gamestage {
import BaseClass.*;
public class GameStage10 extends BaseStage {
public function GameStage10(mainobj:Object){
super(mainobj);
}
override public function setcarxy():void{
carxy = new Array(478, 954);
}
}
}//package Gamestage
Section 110
//GameStage2 (Gamestage.GameStage2)
package Gamestage {
import BaseClass.*;
public class GameStage2 extends BaseStage {
public function GameStage2(mainobj:Object){
super(mainobj);
}
override public function setcarxy():void{
carxy = new Array(532, 481);
}
}
}//package Gamestage
Section 111
//GameStage3 (Gamestage.GameStage3)
package Gamestage {
import BaseClass.*;
public class GameStage3 extends BaseStage {
public function GameStage3(mainobj:Object){
super(mainobj);
}
override public function setcarxy():void{
carxy = new Array(427, 0x0101);
}
}
}//package Gamestage
Section 112
//GameStage4 (Gamestage.GameStage4)
package Gamestage {
import BaseClass.*;
public class GameStage4 extends BaseStage {
public function GameStage4(mainobj:Object){
super(mainobj);
}
override public function setcarxy():void{
carxy = new Array(470, 676);
}
}
}//package Gamestage
Section 113
//GameStage5 (Gamestage.GameStage5)
package Gamestage {
import BaseClass.*;
public class GameStage5 extends BaseStage {
public function GameStage5(mainobj:Object){
super(mainobj);
}
override public function setcarxy():void{
carxy = new Array(537, 730);
}
}
}//package Gamestage
Section 114
//GameStage6 (Gamestage.GameStage6)
package Gamestage {
import BaseClass.*;
public class GameStage6 extends BaseStage {
public function GameStage6(mainobj:Object){
super(mainobj);
}
override public function setcarxy():void{
carxy = new Array(488, 646);
}
}
}//package Gamestage
Section 115
//GameStage7 (Gamestage.GameStage7)
package Gamestage {
import BaseClass.*;
public class GameStage7 extends BaseStage {
public function GameStage7(mainobj:Object){
super(mainobj);
}
override public function setcarxy():void{
carxy = new Array(440, 734);
}
}
}//package Gamestage
Section 116
//GameStage8 (Gamestage.GameStage8)
package Gamestage {
import BaseClass.*;
public class GameStage8 extends BaseStage {
public function GameStage8(mainobj:Object){
super(mainobj);
}
override public function setcarxy():void{
carxy = new Array(438, 727);
}
}
}//package Gamestage
Section 117
//GameStage9 (Gamestage.GameStage9)
package Gamestage {
import BaseClass.*;
public class GameStage9 extends BaseStage {
public function GameStage9(mainobj:Object){
super(mainobj);
}
override public function setcarxy():void{
carxy = new Array(417, -68);
}
}
}//package Gamestage
Section 118
//_03_21 (MaterialMole2_fla._03_21)
package MaterialMole2_fla {
import flash.display.*;
public dynamic class _03_21 extends MovieClip {
public function _03_21(){
addFrameScript(0, frame1);
}
function frame1(){
stop();
}
}
}//package MaterialMole2_fla
Section 119
//_04_23 (MaterialMole2_fla._04_23)
package MaterialMole2_fla {
import flash.display.*;
public dynamic class _04_23 extends MovieClip {
public function _04_23(){
addFrameScript(0, frame1);
}
function frame1(){
stop();
}
}
}//package MaterialMole2_fla
Section 120
//_05_28 (MaterialMole2_fla._05_28)
package MaterialMole2_fla {
import flash.display.*;
public dynamic class _05_28 extends MovieClip {
public function _05_28(){
addFrameScript(0, frame1);
}
function frame1(){
stop();
}
}
}//package MaterialMole2_fla
Section 121
//_1_119 (MaterialMole2_fla._1_119)
package MaterialMole2_fla {
import flash.display.*;
public dynamic class _1_119 extends MovieClip {
public var c:MovieClip;
public var t:MovieClip;
public function _1_119(){
addFrameScript(0, frame1, 1, frame2);
}
function frame1(){
stop();
}
function frame2(){
stop();
}
}
}//package MaterialMole2_fla
Section 122
//_10_132 (MaterialMole2_fla._10_132)
package MaterialMole2_fla {
import flash.display.*;
public dynamic class _10_132 extends MovieClip {
public var c:MovieClip;
public var t:MovieClip;
public function _10_132(){
addFrameScript(0, frame1, 1, frame2, 2, frame3);
}
function frame1(){
stop();
}
function frame2(){
stop();
}
function frame3(){
stop();
}
}
}//package MaterialMole2_fla
Section 123
//_2_123 (MaterialMole2_fla._2_123)
package MaterialMole2_fla {
import flash.display.*;
public dynamic class _2_123 extends MovieClip {
public var c:MovieClip;
public var t:MovieClip;
public function _2_123(){
addFrameScript(0, frame1, 1, frame2, 2, frame3);
}
function frame1(){
stop();
}
function frame2(){
stop();
}
function frame3(){
stop();
}
}
}//package MaterialMole2_fla
Section 124
//_3_128 (MaterialMole2_fla._3_128)
package MaterialMole2_fla {
import flash.display.*;
public dynamic class _3_128 extends MovieClip {
public var c:MovieClip;
public var t:MovieClip;
public function _3_128(){
addFrameScript(0, frame1, 1, frame2, 2, frame3);
}
function frame1(){
stop();
}
function frame2(){
stop();
}
function frame3(){
stop();
}
}
}//package MaterialMole2_fla
Section 125
//_4_125 (MaterialMole2_fla._4_125)
package MaterialMole2_fla {
import flash.display.*;
public dynamic class _4_125 extends MovieClip {
public var c:MovieClip;
public var t:MovieClip;
public function _4_125(){
addFrameScript(0, frame1, 1, frame2, 2, frame3);
}
function frame1(){
stop();
}
function frame2(){
stop();
}
function frame3(){
stop();
}
}
}//package MaterialMole2_fla
Section 126
//_5_126 (MaterialMole2_fla._5_126)
package MaterialMole2_fla {
import flash.display.*;
public dynamic class _5_126 extends MovieClip {
public var c:MovieClip;
public var t:MovieClip;
public function _5_126(){
addFrameScript(0, frame1, 1, frame2, 2, frame3);
}
function frame1(){
stop();
}
function frame2(){
stop();
}
function frame3(){
stop();
}
}
}//package MaterialMole2_fla
Section 127
//_6_129 (MaterialMole2_fla._6_129)
package MaterialMole2_fla {
import flash.display.*;
public dynamic class _6_129 extends MovieClip {
public var c:MovieClip;
public var t:MovieClip;
public function _6_129(){
addFrameScript(0, frame1, 1, frame2, 2, frame3);
}
function frame1(){
stop();
}
function frame2(){
stop();
}
function frame3(){
stop();
}
}
}//package MaterialMole2_fla
Section 128
//_7_130 (MaterialMole2_fla._7_130)
package MaterialMole2_fla {
import flash.display.*;
public dynamic class _7_130 extends MovieClip {
public var c:MovieClip;
public var t:MovieClip;
public function _7_130(){
addFrameScript(0, frame1, 1, frame2, 2, frame3);
}
function frame1(){
stop();
}
function frame2(){
stop();
}
function frame3(){
stop();
}
}
}//package MaterialMole2_fla
Section 129
//_8_127 (MaterialMole2_fla._8_127)
package MaterialMole2_fla {
import flash.display.*;
public dynamic class _8_127 extends MovieClip {
public var c:MovieClip;
public var t:MovieClip;
public function _8_127(){
addFrameScript(0, frame1, 1, frame2, 2, frame3);
}
function frame1(){
stop();
}
function frame2(){
stop();
}
function frame3(){
stop();
}
}
}//package MaterialMole2_fla
Section 130
//_9_131 (MaterialMole2_fla._9_131)
package MaterialMole2_fla {
import flash.display.*;
public dynamic class _9_131 extends MovieClip {
public var c:MovieClip;
public var t:MovieClip;
public function _9_131(){
addFrameScript(0, frame1, 1, frame2, 2, frame3);
}
function frame1(){
stop();
}
function frame2(){
stop();
}
function frame3(){
stop();
}
}
}//package MaterialMole2_fla
Section 131
//MainTimeline (MaterialMole2_fla.MainTimeline)
package MaterialMole2_fla {
import fog.as3.*;
import flash.events.*;
import flash.display.*;
public dynamic class MainTimeline extends MovieClip {
public var loadingImage:LoadingPreloader;
public var FogAPI:FogDevAPI;
public var ml:MiniLogo;
public function MainTimeline(){
addFrameScript(0, frame1, 1, frame2);
}
public function gotoFog(event:MouseEvent):void{
Main.FogAPI.Tracking.GotoURL("http://www.freeonlinegames.com/tag/Driving_Games");
}
function frame1(){
loadingImage = new LoadingPreloader();
FogAPI = new FogDevAPI({id:"4dda5b22cf573", root:root});
FogAPI.Preloader.Start(function (a):void{
FogAPI.Storage.Load();
play();
});
FogAPI.Preloader.SetBackground(loadingImage);
}
function frame2(){
ml = new MiniLogo();
addChild(new Main(FogAPI));
addChild(ml);
ml.scaleX = 0.12;
ml.scaleY = 0.12;
ml.buttonMode = true;
ml.addEventListener(MouseEvent.CLICK, gotoFog);
stop();
}
}
}//package MaterialMole2_fla
Section 132
//Timeline_100 (MaterialMole2_fla.Timeline_100)
package MaterialMole2_fla {
import flash.display.*;
public dynamic class Timeline_100 extends MovieClip {
public function Timeline_100(){
addFrameScript(0, frame1, 1, frame2);
}
function frame1(){
stop();
}
function frame2(){
stop();
}
}
}//package MaterialMole2_fla
Section 133
//Timeline_101 (MaterialMole2_fla.Timeline_101)
package MaterialMole2_fla {
import flash.display.*;
public dynamic class Timeline_101 extends MovieClip {
public function Timeline_101(){
addFrameScript(0, frame1, 1, frame2);
}
function frame1(){
stop();
}
function frame2(){
stop();
}
}
}//package MaterialMole2_fla
Section 134
//Timeline_102 (MaterialMole2_fla.Timeline_102)
package MaterialMole2_fla {
import flash.display.*;
public dynamic class Timeline_102 extends MovieClip {
public function Timeline_102(){
addFrameScript(0, frame1, 1, frame2);
}
function frame1(){
stop();
}
function frame2(){
stop();
}
}
}//package MaterialMole2_fla
Section 135
//Timeline_120 (MaterialMole2_fla.Timeline_120)
package MaterialMole2_fla {
import flash.display.*;
public dynamic class Timeline_120 extends MovieClip {
public function Timeline_120(){
addFrameScript(0, frame1);
}
function frame1(){
stop();
}
}
}//package MaterialMole2_fla
Section 136
//Timeline_121 (MaterialMole2_fla.Timeline_121)
package MaterialMole2_fla {
import flash.display.*;
public dynamic class Timeline_121 extends MovieClip {
public function Timeline_121(){
addFrameScript(0, frame1);
}
function frame1(){
stop();
}
}
}//package MaterialMole2_fla
Section 137
//Timeline_162 (MaterialMole2_fla.Timeline_162)
package MaterialMole2_fla {
import flash.display.*;
public dynamic class Timeline_162 extends MovieClip {
public function Timeline_162(){
addFrameScript(0, frame1);
}
function frame1(){
stop();
}
}
}//package MaterialMole2_fla
Section 138
//Timeline_163 (MaterialMole2_fla.Timeline_163)
package MaterialMole2_fla {
import flash.display.*;
public dynamic class Timeline_163 extends MovieClip {
public function Timeline_163(){
addFrameScript(0, frame1);
}
function frame1(){
stop();
}
}
}//package MaterialMole2_fla
Section 139
//Timeline_164 (MaterialMole2_fla.Timeline_164)
package MaterialMole2_fla {
import flash.display.*;
public dynamic class Timeline_164 extends MovieClip {
public function Timeline_164(){
addFrameScript(0, frame1);
}
function frame1(){
stop();
}
}
}//package MaterialMole2_fla
Section 140
//Timeline_20 (MaterialMole2_fla.Timeline_20)
package MaterialMole2_fla {
import flash.display.*;
public dynamic class Timeline_20 extends MovieClip {
public function Timeline_20(){
addFrameScript(0, frame1);
}
function frame1(){
stop();
}
}
}//package MaterialMole2_fla
Section 141
//Timeline_200 (MaterialMole2_fla.Timeline_200)
package MaterialMole2_fla {
import flash.display.*;
public dynamic class Timeline_200 extends MovieClip {
public function Timeline_200(){
addFrameScript(3, frame4);
}
function frame4(){
stop();
}
}
}//package MaterialMole2_fla
Section 142
//Timeline_205 (MaterialMole2_fla.Timeline_205)
package MaterialMole2_fla {
import flash.display.*;
public dynamic class Timeline_205 extends MovieClip {
public function Timeline_205(){
addFrameScript(0, frame1);
}
function frame1(){
stop();
}
}
}//package MaterialMole2_fla
Section 143
//Timeline_265 (MaterialMole2_fla.Timeline_265)
package MaterialMole2_fla {
import flash.display.*;
public dynamic class Timeline_265 extends MovieClip {
public function Timeline_265(){
addFrameScript(0, frame1);
}
function frame1(){
stop();
}
}
}//package MaterialMole2_fla
Section 144
//Timeline_266 (MaterialMole2_fla.Timeline_266)
package MaterialMole2_fla {
import flash.display.*;
public dynamic class Timeline_266 extends MovieClip {
public function Timeline_266(){
addFrameScript(0, frame1);
}
function frame1(){
stop();
}
}
}//package MaterialMole2_fla
Section 145
//Timeline_267 (MaterialMole2_fla.Timeline_267)
package MaterialMole2_fla {
import flash.display.*;
public dynamic class Timeline_267 extends MovieClip {
public function Timeline_267(){
addFrameScript(0, frame1);
}
function frame1(){
stop();
}
}
}//package MaterialMole2_fla
Section 146
//Timeline_275 (MaterialMole2_fla.Timeline_275)
package MaterialMole2_fla {
import flash.display.*;
public dynamic class Timeline_275 extends MovieClip {
public function Timeline_275(){
addFrameScript(0, frame1);
}
function frame1(){
stop();
}
}
}//package MaterialMole2_fla
Section 147
//Timeline_37 (MaterialMole2_fla.Timeline_37)
package MaterialMole2_fla {
import flash.display.*;
public dynamic class Timeline_37 extends MovieClip {
public function Timeline_37(){
addFrameScript(0, frame1);
}
function frame1(){
stop();
}
}
}//package MaterialMole2_fla
Section 148
//Timeline_42 (MaterialMole2_fla.Timeline_42)
package MaterialMole2_fla {
import flash.display.*;
public dynamic class Timeline_42 extends MovieClip {
public function Timeline_42(){
addFrameScript(0, frame1, 1, frame2);
}
function frame1(){
stop();
}
function frame2(){
stop();
}
}
}//package MaterialMole2_fla
Section 149
//Timeline_46 (MaterialMole2_fla.Timeline_46)
package MaterialMole2_fla {
import flash.display.*;
public dynamic class Timeline_46 extends MovieClip {
public function Timeline_46(){
addFrameScript(0, frame1);
}
function frame1(){
stop();
}
}
}//package MaterialMole2_fla
Section 150
//Timeline_51 (MaterialMole2_fla.Timeline_51)
package MaterialMole2_fla {
import flash.display.*;
public dynamic class Timeline_51 extends MovieClip {
public function Timeline_51(){
addFrameScript(0, frame1, 1, frame2);
}
function frame1(){
stop();
}
function frame2(){
stop();
}
}
}//package MaterialMole2_fla
Section 151
//Timeline_71 (MaterialMole2_fla.Timeline_71)
package MaterialMole2_fla {
import flash.display.*;
public dynamic class Timeline_71 extends MovieClip {
public var num:MovieClip;
public var word:MovieClip;
public function Timeline_71(){
addFrameScript(0, frame1, 1, frame2);
}
function frame1(){
stop();
}
function frame2(){
stop();
}
}
}//package MaterialMole2_fla
Section 152
//Timeline_75 (MaterialMole2_fla.Timeline_75)
package MaterialMole2_fla {
import flash.display.*;
public dynamic class Timeline_75 extends MovieClip {
public function Timeline_75(){
addFrameScript(0, frame1);
}
function frame1(){
stop();
}
}
}//package MaterialMole2_fla
Section 153
//Timeline_82 (MaterialMole2_fla.Timeline_82)
package MaterialMole2_fla {
import flash.display.*;
public dynamic class Timeline_82 extends MovieClip {
public function Timeline_82(){
addFrameScript(40, frame41);
}
function frame41(){
stop();
}
}
}//package MaterialMole2_fla
Section 154
//Timeline_84 (MaterialMole2_fla.Timeline_84)
package MaterialMole2_fla {
import flash.display.*;
public dynamic class Timeline_84 extends MovieClip {
public function Timeline_84(){
addFrameScript(40, frame41);
}
function frame41(){
stop();
}
}
}//package MaterialMole2_fla
Section 155
//Timeline_85 (MaterialMole2_fla.Timeline_85)
package MaterialMole2_fla {
import flash.display.*;
public dynamic class Timeline_85 extends MovieClip {
public function Timeline_85(){
addFrameScript(40, frame41);
}
function frame41(){
stop();
}
}
}//package MaterialMole2_fla
Section 156
//Timeline_86 (MaterialMole2_fla.Timeline_86)
package MaterialMole2_fla {
import flash.display.*;
public dynamic class Timeline_86 extends MovieClip {
public function Timeline_86(){
addFrameScript(40, frame41);
}
function frame41(){
stop();
}
}
}//package MaterialMole2_fla
Section 157
//Timeline_89 (MaterialMole2_fla.Timeline_89)
package MaterialMole2_fla {
import flash.display.*;
public dynamic class Timeline_89 extends MovieClip {
public function Timeline_89(){
addFrameScript(40, frame41);
}
function frame41(){
stop();
}
}
}//package MaterialMole2_fla
Section 158
//Timeline_91 (MaterialMole2_fla.Timeline_91)
package MaterialMole2_fla {
import flash.display.*;
public dynamic class Timeline_91 extends MovieClip {
public function Timeline_91(){
addFrameScript(40, frame41);
}
function frame41(){
stop();
}
}
}//package MaterialMole2_fla
Section 159
//Timeline_95 (MaterialMole2_fla.Timeline_95)
package MaterialMole2_fla {
import flash.display.*;
public dynamic class Timeline_95 extends MovieClip {
public function Timeline_95(){
addFrameScript(0, frame1);
}
function frame1(){
stop();
}
}
}//package MaterialMole2_fla
Section 160
//Timeline_97 (MaterialMole2_fla.Timeline_97)
package MaterialMole2_fla {
import flash.display.*;
public dynamic class Timeline_97 extends MovieClip {
public function Timeline_97(){
addFrameScript(0, frame1, 1, frame2, 2, frame3, 3, frame4);
}
function frame1(){
stop();
}
function frame2(){
stop();
}
function frame3(){
stop();
}
function frame4(){
stop();
}
}
}//package MaterialMole2_fla
Section 161
//Timeline_99 (MaterialMole2_fla.Timeline_99)
package MaterialMole2_fla {
import flash.display.*;
public dynamic class Timeline_99 extends MovieClip {
public function Timeline_99(){
addFrameScript(0, frame1, 1, frame2);
}
function frame1(){
stop();
}
function frame2(){
stop();
}
}
}//package MaterialMole2_fla
Section 162
//EdgeMetrics (mx.core.EdgeMetrics)
package mx.core {
public class EdgeMetrics {
public var bottom:Number;
public var left:Number;
public var right:Number;
public var top:Number;
mx_internal static const VERSION:String = "4.0.0.14159";
public static const EMPTY:EdgeMetrics = new EdgeMetrics(0, 0, 0, 0);
;
public function EdgeMetrics(left:Number=0, top:Number=0, right:Number=0, bottom:Number=0){
super();
this.left = left;
this.top = top;
this.right = right;
this.bottom = bottom;
}
public function clone():EdgeMetrics{
return (new EdgeMetrics(this.left, this.top, this.right, this.bottom));
}
}
}//package mx.core
Section 163
//FlexMovieClip (mx.core.FlexMovieClip)
package mx.core {
import flash.display.*;
import mx.utils.*;
public class FlexMovieClip extends MovieClip {
mx_internal static const VERSION:String = "4.0.0.14159";
public function FlexMovieClip(){
super();
name = NameUtil.createUniqueName(this);
//unresolved jump
var _slot1 = e;
}
override public function toString():String{
return (NameUtil.displayObjectToString(this));
}
}
}//package mx.core
Section 164
//IBorder (mx.core.IBorder)
package mx.core {
public interface IBorder {
function get borderMetrics():EdgeMetrics;
}
}//package mx.core
Section 165
//IFlexAsset (mx.core.IFlexAsset)
package mx.core {
public interface IFlexAsset {
}
}//package mx.core
Section 166
//IFlexDisplayObject (mx.core.IFlexDisplayObject)
package mx.core {
import flash.events.*;
import flash.display.*;
import flash.geom.*;
import flash.accessibility.*;
public interface IFlexDisplayObject extends IBitmapDrawable, IEventDispatcher {
function get root():DisplayObject;
function get stage():Stage;
function get name():String;
function set name(flash.display:String):void;
function get parent():DisplayObjectContainer;
function get mask():DisplayObject;
function set mask(flash.display:DisplayObject):void;
function get visible():Boolean;
function set visible(flash.display:Boolean):void;
function get x():Number;
function set x(flash.display:Number):void;
function get y():Number;
function set y(flash.display:Number):void;
function get scaleX():Number;
function set scaleX(flash.display:Number):void;
function get scaleY():Number;
function set scaleY(flash.display:Number):void;
function get mouseX():Number;
function get mouseY():Number;
function get rotation():Number;
function set rotation(flash.display:Number):void;
function get alpha():Number;
function set alpha(flash.display:Number):void;
function get width():Number;
function set width(flash.display:Number):void;
function get height():Number;
function set height(flash.display:Number):void;
function get cacheAsBitmap():Boolean;
function set cacheAsBitmap(flash.display:Boolean):void;
function get opaqueBackground():Object;
function set opaqueBackground(flash.display:Object):void;
function get scrollRect():Rectangle;
function set scrollRect(flash.display:Rectangle):void;
function get filters():Array;
function set filters(flash.display:Array):void;
function get blendMode():String;
function set blendMode(flash.display:String):void;
function get transform():Transform;
function set transform(flash.display:Transform):void;
function get scale9Grid():Rectangle;
function set scale9Grid(flash.display:Rectangle):void;
function globalToLocal(void:Point):Point;
function localToGlobal(void:Point):Point;
function getBounds(String:DisplayObject):Rectangle;
function getRect(String:DisplayObject):Rectangle;
function get loaderInfo():LoaderInfo;
function hitTestObject(mx.core:IFlexDisplayObject/mx.core:IFlexDisplayObject:stage/get:DisplayObject):Boolean;
function hitTestPoint(_arg1:Number, _arg2:Number, _arg3:Boolean=false):Boolean;
function get accessibilityProperties():AccessibilityProperties;
function set accessibilityProperties(flash.display:AccessibilityProperties):void;
function get measuredHeight():Number;
function get measuredWidth():Number;
function move(_arg1:Number, _arg2:Number):void;
function setActualSize(_arg1:Number, _arg2:Number):void;
}
}//package mx.core
Section 167
//IRepeaterClient (mx.core.IRepeaterClient)
package mx.core {
public interface IRepeaterClient {
function get instanceIndices():Array;
function set instanceIndices(E:\dev\4.0.0\frameworks\projects\framework\src;mx\core;IRepeaterClient.as:Array):void;
function get isDocument():Boolean;
function get repeaterIndices():Array;
function set repeaterIndices(E:\dev\4.0.0\frameworks\projects\framework\src;mx\core;IRepeaterClient.as:Array):void;
function get repeaters():Array;
function set repeaters(E:\dev\4.0.0\frameworks\projects\framework\src;mx\core;IRepeaterClient.as:Array):void;
function initializeRepeaterArrays(E:\dev\4.0.0\frameworks\projects\framework\src;mx\core;IRepeaterClient.as:IRepeaterClient):void;
}
}//package mx.core
Section 168
//MovieClipAsset (mx.core.MovieClipAsset)
package mx.core {
public class MovieClipAsset extends FlexMovieClip implements IFlexAsset, IFlexDisplayObject, IBorder {
private var _measuredHeight:Number;
private var _measuredWidth:Number;
mx_internal static const VERSION:String = "4.0.0.14159";
public function MovieClipAsset(){
super();
this._measuredWidth = width;
this._measuredHeight = height;
}
public function get measuredHeight():Number{
return (this._measuredHeight);
}
public function get measuredWidth():Number{
return (this._measuredWidth);
}
public function get borderMetrics():EdgeMetrics{
if (scale9Grid == null){
return (EdgeMetrics.EMPTY);
};
return (new EdgeMetrics(scale9Grid.left, scale9Grid.top, Math.ceil((this.measuredWidth - scale9Grid.right)), Math.ceil((this.measuredHeight - scale9Grid.bottom))));
}
public function move(x:Number, y:Number):void{
this.x = x;
this.y = y;
}
public function setActualSize(newWidth:Number, newHeight:Number):void{
width = newWidth;
height = newHeight;
}
}
}//package mx.core
Section 169
//mx_internal (mx.core.mx_internal)
package mx.core {
public namespace mx_internal = "http://www.adobe.com/2006/flex/mx/internal";
}//package mx.core
Section 170
//SoundAsset (mx.core.SoundAsset)
package mx.core {
import flash.media.*;
public class SoundAsset extends Sound implements IFlexAsset {
mx_internal static const VERSION:String = "4.0.0.14159";
public function SoundAsset(){
super();
}
}
}//package mx.core
Section 171
//NameUtil (mx.utils.NameUtil)
package mx.utils {
import flash.display.*;
import mx.core.*;
import flash.utils.*;
public class NameUtil {
mx_internal static const VERSION:String = "4.0.0.14159";
private static var counter:int = 0;
public static function createUniqueName(object:Object):String{
if (!object){
return (null);
};
var name:String = getQualifiedClassName(object);
var index:int = name.indexOf("::");
if (index != -1){
name = name.substr((index + 2));
};
var charCode:int = name.charCodeAt((name.length - 1));
if ((((charCode >= 48)) && ((charCode <= 57)))){
name = (name + "_");
};
return ((name + counter++));
}
public static function displayObjectToString(displayObject:DisplayObject):String{
var result:String;
var o:DisplayObject;
var s:String;
var indices:Array;
var displayObject = displayObject;
o = displayObject;
while (o != null) {
if (((((o.parent) && (o.stage))) && ((o.parent == o.stage)))){
break;
};
s = (((("id" in o)) && (o["id"]))) ? o["id"] : o.name;
if ((o is IRepeaterClient)){
indices = IRepeaterClient(o).instanceIndices;
if (indices){
s = (s + (("[" + indices.join("][")) + "]"));
};
};
result = ((result == null)) ? s : ((s + ".") + result);
o = o.parent;
};
//unresolved jump
var _slot1 = e;
return (result);
}
public static function getUnqualifiedClassName(object:Object):String{
var name:String;
if ((object is String)){
name = (object as String);
} else {
name = getQualifiedClassName(object);
};
var index:int = name.indexOf("::");
if (index != -1){
name = name.substr((index + 2));
};
return (name);
}
}
}//package mx.utils
Section 172
//BaseSound (UserdefinedClass.BaseSound)
package UserdefinedClass {
import flash.utils.*;
import flash.media.*;
public class BaseSound {
public var sd:Sound;
public var sdChannel:SoundChannel;
public var sdTransform:SoundTransform;
public function BaseSound(soundclassname:String){
super();
var soundclass:Object = getDefinitionByName(soundclassname);
sd = (new (soundclass) as Sound);
sdChannel = new SoundChannel();
}
public function playsound(loop:int, volume:Number=1){
sdTransform = new SoundTransform();
sdTransform.volume = volume;
sdChannel = sd.play(0, loop, sdTransform);
}
public function setvolume(volume:Number){
sdTransform = new SoundTransform();
sdTransform.volume = volume;
sdChannel.soundTransform = sdTransform;
}
public function stopSound(){
if (sdChannel){
sdChannel.stop();
};
}
}
}//package UserdefinedClass
Section 173
//BaseUI (UserdefinedClass.BaseUI)
package UserdefinedClass {
import flash.display.*;
public class BaseUI {
public static var uisp:Sprite = new Sprite();
public function BaseUI(){
super();
}
public static function setmoney(Mc:MovieClip, val:int, str:String, Maxval:int){
var tempP:Array = new Array();
var i:int;
while (i < Maxval) {
tempP.push(Mc[(str + i)]);
i++;
};
var tempnum:Array = MyMath.NumtoArray(val, false);
var len:int = tempnum.length;
if (val == 0){
i = 0;
while (i < Maxval) {
tempP[i].alpha = 0;
i++;
};
tempP[0].alpha = 1;
tempP[0].gotoAndStop(1);
return;
};
i = 0;
while (i < Maxval) {
if (i < len){
tempP[i].alpha = 1;
tempP[i].gotoAndStop((tempnum[i] + 1));
} else {
tempP[i].alpha = 0;
};
i++;
};
}
public static function setMaxscore(Mc:MovieClip, val:int, str:String, Maxval:int){
var tempP:Array = new Array();
var i:int;
while (i < Maxval) {
tempP.push(Mc[(str + i)]);
i++;
};
var tempnum:Array = MyMath.NumtoArray(val);
var len:int = tempnum.length;
if (val == 0){
i = 0;
while (i < Maxval) {
tempP[i].alpha = 0;
i++;
};
tempP[0].alpha = 1;
tempP[0].gotoAndStop(1);
return;
};
i = 0;
while (i < Maxval) {
if (i < len){
tempP[i].alpha = 1;
tempP[i].gotoAndStop((tempnum[i] + 1));
} else {
tempP[i].alpha = 0;
};
i++;
};
}
public static function setnumval(Mc:MovieClip, val:int, str:String){
var tempmc:Array = new Array();
var i = 1;
while (i < 11) {
tempmc.push(Mc[(str + i)]);
i++;
};
i = 0;
while (i < 10) {
if (i < val){
tempmc[i].gotoAndStop(1);
} else {
tempmc[i].gotoAndStop(2);
};
i++;
};
}
public static function setalpha(alpha:Number, Mc:MovieClip, str:String, Max:int){
var tempP:Array = new Array();
var i:int;
while (i < Max) {
tempP.push(Mc[(str + i)]);
i++;
};
i = 0;
while (i < Max) {
tempP[i].alpha = alpha;
i++;
};
}
public static function setP(Mc:MovieClip, val:int, max:int, str:String){
var tempP:Array = new Array(Mc[str]["p1"], Mc[str]["p2"], Mc[str]["p3"], Mc[str]["p4"], Mc[str]["p5"], Mc[str]["p6"], Mc[str]["p7"], Mc[str]["p8"], Mc[str]["p9"], Mc[str]["p10"]);
var i:int;
while (i < 10) {
tempP[i].gotoAndStop(3);
if (i < max){
tempP[i].gotoAndStop(2);
};
if (i < val){
tempP[i].gotoAndStop(1);
};
i++;
};
}
public static function setmax(Mc:MovieClip, val:int, max:int, str:String){
if ((max == val)){
Mc[str].gotoAndStop(2);
} else {
Mc[str].gotoAndStop(1);
};
}
public static function setScore(obj:MovieClip, Scorenum:int, str:String){
var Temp:Array = new Array(obj[(str + "0")], obj[(str + "1")], obj[(str + "2")], obj[(str + "3")], obj[(str + "4")], obj[(str + "5")]);
var tempnum:Array = MyMath.NumtoArray(Scorenum);
var len:int = tempnum.length;
var i:int;
while (i < 6) {
if (i < len){
Temp[i].alpha = 1;
Temp[i].gotoAndStop((tempnum[i] + 1));
} else {
Temp[i].alpha = 0;
};
i++;
};
}
public static function settime(Mc:MovieClip, num:int){
var timearr:Array = MyMath.TimeFormat(num);
var timemcname:Array = new Array(Mc.t0, Mc.t1, Mc.t2, Mc.t3);
var i:int;
while (i < 4) {
(timemcname[i] as MovieClip).gotoAndStop((timearr[i] + 1));
i++;
};
}
public static function setfloattime(Mc:MovieClip, S:Number){
var tempint:Array = MyMath.worknum(int(S));
var tempdec:Array = MyMath.worknum(int(((S - int(S)) * 100)));
Mc.t2.gotoAndStop((tempint[0] + 1));
Mc.t3.gotoAndStop((tempint[1] + 1));
Mc.t0.gotoAndStop((tempdec[0] + 1));
Mc.t1.gotoAndStop((tempdec[1] + 1));
if (tempint[1] == 0){
Mc.t3.alpha = 0;
} else {
Mc.t3.alpha = 1;
};
if (tempdec[0] == 0){
Mc.t0.alpha = 0;
} else {
Mc.t0.alpha = 1;
};
}
public static function setlv(obj:MovieClip, num:int){
var temp:Array = MyMath.worknum(num);
(obj.lv0 as MovieClip).gotoAndStop((temp[0] + 1));
(obj.lv1 as MovieClip).gotoAndStop((temp[1] + 1));
}
public static function setcargo(obj:MovieClip, num:int, str:String){
var temp:Array = MyMath.worknum(num);
(obj[(str + 0)] as MovieClip).gotoAndStop((temp[0] + 1));
(obj[(str + 1)] as MovieClip).gotoAndStop((temp[1] + 1));
}
public static function setcombo(obj:MovieClip, num:int){
var temp:Array = MyMath.worknum(num);
(obj.c0 as MovieClip).alpha = 1;
if (num > 9){
(obj.c1 as MovieClip).alpha = 1;
} else {
(obj.c1 as MovieClip).alpha = 0;
};
(obj.c0 as MovieClip).gotoAndStop((temp[0] + 1));
(obj.c1 as MovieClip).gotoAndStop((temp[1] + 1));
}
public static function setValue(obj:MovieClip, objname:String, frame:int){
obj[objname].gotoAndStop(frame);
}
public static function setWinScore(obj:MovieClip, Scorenum:int){
var Temp:Array = new Array(obj.s0, obj.s1, obj.s2, obj.s3, obj.s4);
var tempnum:Array = MyMath.NumtoArray(Scorenum);
var len:int = tempnum.length;
var i:int;
while (i < 5) {
if (i < len){
Temp[i].alpha = 1;
Temp[i].gotoAndStop((tempnum[i] + 1));
} else {
Temp[i].alpha = 0;
};
i++;
};
}
public static function setWinHighScore(obj:MovieClip, Scorenum:int){
var Temp:Array = new Array(obj.h0, obj.h1, obj.h2, obj.h3, obj.h4);
var tempnum:Array = MyMath.NumtoArray(Scorenum);
var len:int = tempnum.length;
var i:int;
while (i < 5) {
if (i < len){
Temp[i].alpha = 1;
Temp[i].gotoAndStop((tempnum[i] + 1));
} else {
Temp[i].alpha = 0;
};
i++;
};
}
public static function showscore(scnum:int, objname, Container:DisplayObjectContainer, x:Number, y:Number, size:Number=1, flushleft:Boolean=true){
var sc:MovieClip;
Clr.removeAllChildren(uisp);
var tempnum:Array = MyMath.NumtoArray(scnum, flushleft);
var len:int = tempnum.length;
var i:int;
while (i < len) {
sc = (new (objname) as MovieClip);
sc.scaleX = (sc.scaleY = size);
sc.x = (sc.width * i);
if (!flushleft){
sc.x = (-(sc.width) * i);
};
sc.gotoAndStop((tempnum[i] + 1));
uisp.addChild(sc);
i++;
};
uisp.x = x;
uisp.y = y;
Container.addChild(uisp);
}
}
}//package UserdefinedClass
Section 174
//Box2dFactory (UserdefinedClass.Box2dFactory)
package UserdefinedClass {
import flash.events.*;
import flash.display.*;
import Box2D.Collision.Shapes.*;
import Box2D.Common.Math.*;
import Box2D.Dynamics.Joints.*;
import Box2D.Dynamics.*;
import Box2D.Collision.*;
public class Box2dFactory {
private var mouse_MaxForce:int;// = 1500
private var _stage:Stage;
private var _world:b2World;
private var mouseJoint:b2MouseJoint;
private var _useMouseJoint:Boolean;// = false
public var tempmc:MovieClip;
public var mousesp:Sprite;
public var mX:Number;
public var mY:Number;
public var mousecount:int;// = 0
public var _density:Number;// = 5
public var _restitution:Number;// = 0
public var _friction:Number;// = 5
public var fourangle:Number;
public static const PHYSCALE:Number = 30;
public static const STEP:Number = 0.0222222222222222;
public static const ITERATION:int = 15;
private static var _instance:Box2dFactory;
public function Box2dFactory(){
super();
}
public function createWorld(gravity:b2Vec2, aabb:b2AABB, doSleep:Boolean=true):b2World{
_world = new b2World(aabb, gravity, doSleep);
return (_world);
}
public function updata():void{
world.Step(STEP, ITERATION);
setuserdata();
setMouseJointTarget();
}
private function setuserdata(){
var b:b2Body = _world.m_bodyList;
while (b) {
if (b.m_userData){
if ((b.m_userData is Object)){
if (b.m_userData.element){
if ((b.m_userData.element is DisplayObject)){
b.m_userData.element.x = (b.GetPosition().x * 30);
b.m_userData.element.y = (b.GetPosition().y * 30);
b.m_userData.element.rotation = (((b.GetAngle() * 180) / Math.PI) % 360);
};
};
};
};
b = b.m_next;
};
}
private function setMouseJointTarget():void{
var mouseXWorldPhys:Number;
var mouseYWorldPhys:Number;
var p2:b2Vec2;
if (mouseJoint){
mouseXWorldPhys = (_stage.mouseX / PHYSCALE);
mouseYWorldPhys = (_stage.mouseY / PHYSCALE);
p2 = new b2Vec2(mouseXWorldPhys, mouseYWorldPhys);
mouseJoint.SetTarget(p2);
};
}
public function createBody(x:Number, y:Number, n:int, radius:Number, angle:Number, userdata, type:String="item", four:Boolean=true):b2Body{
if (four){
fourangle = 0;
} else {
fourangle = (Math.PI * 0.25);
};
var shapeDef:b2PolygonDef = new b2PolygonDef();
setConvexVertex(shapeDef, n, radius);
var bodydef:b2BodyDef = new b2BodyDef();
bodydef.angle = angle;
bodydef.position.Set((x / PHYSCALE), (y / PHYSCALE));
bodydef.userData = new Object();
bodydef.userData.type = type;
bodydef.userData.element = userdata;
bodydef.isBullet = false;
var body:b2Body = world.CreateBody(bodydef);
userdata.bd = body;
body.CreateShape(shapeDef);
body.SetMassFromShapes();
return (body);
}
public function setConvexVertex(shapeDef:b2PolygonDef, n:int, radius:Number, friction:Number=100, restitution:Number=0.1, density:Number=20):void{
var dx:Number;
var dy:Number;
shapeDef.vertexCount = n;
var angle:Number = ((Math.PI * 2) / n);
radius = (radius / PHYSCALE);
var i:int;
while (i < n) {
dx = (radius * Math.cos(((angle * i) + fourangle)));
dy = (radius * Math.sin(((angle * i) + fourangle)));
shapeDef.vertices[i].Set(dx, dy);
i++;
};
shapeDef.friction = friction;
shapeDef.restitution = restitution;
shapeDef.density = density;
}
public function createRound(x:Number, y:Number, radius:Number, angle:Number, userdata, type:String="item"):b2Body{
var body:b2Body;
var shapeDef:b2PolygonDef = new b2PolygonDef();
var bodydef:b2BodyDef = new b2BodyDef();
var circledef:b2CircleDef = new b2CircleDef();
bodydef.position.Set((x / PHYSCALE), (y / PHYSCALE));
bodydef.userData = new Object();
bodydef.userData.element = userdata;
bodydef.isBullet = false;
bodydef.angle = angle;
bodydef.userData.type = type;
circledef.radius = (radius / PHYSCALE);
circledef.density = _density;
circledef.restitution = _restitution;
circledef.friction = _friction;
body = world.CreateBody(bodydef);
userdata.bd = body;
body.CreateShape(circledef);
body.SetMassFromShapes();
return (body);
}
public function addToWorld(objX:Number, objY:Number, objAngle:Number, friction:Number, objDensity:Number, restitution:Number, Obj, bullet:Boolean=false, type:String="none", allowsleep:Boolean=true):b2Body{
var _b2BodyDef:b2BodyDef;
var _b2Body:b2Body;
var _b2PolygonDef:b2PolygonDef;
var tem:Number;
var _loc_10:* = undefined;
_b2BodyDef = new b2BodyDef();
_b2BodyDef.position.Set(objX, objY);
_b2BodyDef.angle = objAngle;
_b2BodyDef.userData = new Object();
_b2BodyDef.userData.element = Obj;
_b2BodyDef.userData.type = type;
_b2BodyDef.isBullet = bullet;
_b2BodyDef.allowSleep = allowsleep;
_b2Body = world.CreateBody(_b2BodyDef);
Obj.bd = _b2Body;
var i:int;
while (i < Obj.numChildren) {
_loc_10 = Obj.getChildAt(i);
if (_loc_10.constructor == fang){
_b2PolygonDef = new b2PolygonDef();
tem = _loc_10.rotation;
_loc_10.rotation = 0;
_b2PolygonDef.SetAsOrientedBox((_loc_10.width / 60), (_loc_10.height / 60), new b2Vec2((_loc_10.x / 30), (_loc_10.y / 30)), (tem / 57.296));
_loc_10.rotation = tem;
_b2PolygonDef.friction = friction;
_b2PolygonDef.density = objDensity;
_b2PolygonDef.restitution = restitution;
_b2Body.CreateShape(_b2PolygonDef);
};
i++;
};
i = 0;
while (i < Obj.numChildren) {
_loc_10 = Obj.getChildAt(i);
if (_loc_10.constructor == fang){
Obj.removeChildAt(i);
} else {
i++;
};
};
if (objDensity != 0){
_b2Body.SetMassFromShapes();
};
return (_b2Body);
}
public function makeBodyByYuanInside(x, y, targetSprite, density=1, friction=1, restitution=1, bullet:Boolean=false, type:String="none", allowSleep:Boolean=true):b2Body{
var _b2BodyDef:b2BodyDef;
var _b2Body:b2Body;
var _b2CircleDef:b2CircleDef;
var tem:Number;
var _loc_10:* = undefined;
_b2BodyDef = new b2BodyDef();
_b2BodyDef.position.Set(x, y);
_b2BodyDef.userData = new Object();
_b2BodyDef.userData.element = targetSprite;
_b2BodyDef.userData.type = type;
_b2BodyDef.allowSleep = allowSleep;
_b2BodyDef.isBullet = bullet;
_b2Body = world.CreateBody(_b2BodyDef);
targetSprite.bd = _b2Body;
var i:int;
while (i < targetSprite.numChildren) {
_loc_10 = targetSprite.getChildAt(i);
if (_loc_10.constructor == yuan){
_b2CircleDef = new b2CircleDef();
tem = _loc_10.rotation;
_loc_10.rotation = 0;
_b2CircleDef.radius = (_loc_10.width / 60);
_loc_10.rotation = tem;
_b2CircleDef.friction = friction;
_b2CircleDef.density = density;
_b2CircleDef.restitution = restitution;
_b2Body.CreateShape(_b2CircleDef);
};
i++;
};
i = 0;
while (i < targetSprite.numChildren) {
_loc_10 = targetSprite.getChildAt(i);
if (_loc_10.constructor == yuan){
targetSprite.removeChildAt(i);
} else {
i++;
};
};
if (density != 0){
_b2Body.SetMassFromShapes();
};
return (_b2Body);
}
public function createDistanceJoint(body1:b2Body, body2:b2Body, anchor1:b2Vec2, anchor2:b2Vec2):b2Joint{
var distanceJointDef:b2DistanceJointDef = new b2DistanceJointDef();
distanceJointDef.Initialize(body1, body2, anchor1, anchor2);
return (world.CreateJoint(distanceJointDef));
}
public function createRevoluteJoint(body1:b2Body, body2:b2Body, anchor:b2Vec2, enableLimit:Boolean=false, lowerAngle:Number=0, upperAngle:Number=0, enableMotor:Boolean=false, motorSpeed:Number=0, maxMotorTorque:Number=0):b2Joint{
var revoluteJointDef:b2RevoluteJointDef = new b2RevoluteJointDef();
revoluteJointDef.Initialize(body1, body2, anchor);
revoluteJointDef.enableLimit = enableLimit;
revoluteJointDef.lowerAngle = lowerAngle;
revoluteJointDef.upperAngle = upperAngle;
revoluteJointDef.enableMotor = enableMotor;
revoluteJointDef.motorSpeed = motorSpeed;
revoluteJointDef.maxMotorTorque = maxMotorTorque;
return (world.CreateJoint(revoluteJointDef));
}
public function createPrismaticJoint(b1:b2Body, b2:b2Body, axis:b2Vec2, enableLimit:Boolean=false, lowerTranslation:Number=0, upperTranslation:Number=0, enableMotor:Boolean=false, motorSpeed:Number=0, maxMotorTorque:Number=0):b2Joint{
var prismaticJointDef:b2PrismaticJointDef = new b2PrismaticJointDef();
prismaticJointDef.Initialize(b1, b2, b2.GetWorldCenter(), axis);
prismaticJointDef.enableLimit = enableLimit;
prismaticJointDef.lowerTranslation = lowerTranslation;
prismaticJointDef.upperTranslation = upperTranslation;
prismaticJointDef.enableMotor = enableMotor;
prismaticJointDef.motorSpeed = motorSpeed;
prismaticJointDef.maxMotorForce = maxMotorTorque;
return (world.CreateJoint(prismaticJointDef));
}
public function prismatiocJoint(param1, param2, x, y, up:Number=-0.1, down:Number=-0.2):b2Joint{
var prismaticJointDef:b2PrismaticJointDef = undefined;
prismaticJointDef = new b2PrismaticJointDef();
prismaticJointDef.Initialize(param1.bd, param2.bd, param2.bd.GetWorldCenter(), new b2Vec2(x, y));
prismaticJointDef.lowerTranslation = down;
prismaticJointDef.upperTranslation = up;
prismaticJointDef.enableLimit = true;
prismaticJointDef.enableMotor = true;
return (world.CreateJoint(prismaticJointDef));
}
public function createPulleyJoint(b1:b2Body, b2:b2Body, groundAnchor1:b2Vec2, groundAnchor2:b2Vec2, anchor1:b2Vec2, anchor2:b2Vec2, rate:Number=1, maxLength1:Number=100, maxLength2:Number=100):b2Joint{
var pulleyJointDef:b2PulleyJointDef = new b2PulleyJointDef();
pulleyJointDef.Initialize(b1, b2, groundAnchor1, groundAnchor2, anchor1, anchor2, rate);
pulleyJointDef.maxLength1 = maxLength1;
pulleyJointDef.maxLength2 = maxLength2;
return (world.CreateJoint(pulleyJointDef));
}
public function createGearJoint(b1:b2Body, b2:b2Body, j1:b2Joint, j2:b2Joint, rate:Number=1):b2Joint{
var gearJointDef:b2GearJointDef = new b2GearJointDef();
gearJointDef.body1 = b1;
gearJointDef.body2 = b2;
gearJointDef.joint1 = j1;
gearJointDef.joint2 = j2;
gearJointDef.ratio = rate;
return (world.CreateJoint(gearJointDef));
}
public function mouseControlBody(sta:Stage, mcbd:MovieClip, sp:Sprite):void{
if (((!(sta)) || ((mcbd == null)))){
return;
};
_stage = sta;
mousesp = sp;
tempmc = mcbd;
tempmc.isMouse = true;
_useMouseJoint = true;
_stage.addEventListener(MouseEvent.MOUSE_DOWN, createMouse);
_stage.addEventListener(MouseEvent.MOUSE_UP, destroyMouse);
mX = _stage.mouseX;
mY = _stage.mouseY;
}
public function GetBodyAtMouse(includeStatic:Boolean=false):b2Body{
var tShape:b2Shape;
var inside:Boolean;
var mouseXWorldPhys:Number = (_stage.mouseX / PHYSCALE);
var mouseYWorldPhys:Number = (_stage.mouseY / PHYSCALE);
var vec:b2Vec2 = new b2Vec2(mouseXWorldPhys, mouseYWorldPhys);
var aabb:b2AABB = new b2AABB();
aabb.lowerBound.Set((mouseXWorldPhys - 0.001), (mouseYWorldPhys - 0.001));
aabb.upperBound.Set((mouseXWorldPhys + 0.001), (mouseYWorldPhys + 0.001));
var k_maxCount = 10;
var shapes:Array = new Array();
var count:int = world.Query(aabb, shapes, k_maxCount);
var body:b2Body;
var i:int;
while (i < count) {
if ((((shapes[i].GetBody().IsStatic() == false)) || (includeStatic))){
tShape = (shapes[i] as b2Shape);
inside = tShape.TestPoint(tShape.GetBody().GetXForm(), vec);
if (inside){
body = tShape.GetBody();
break;
};
};
i++;
};
return (body);
}
public function createMouse(evt:MouseEvent):void{
var mouseJointDef:b2MouseJointDef;
var body:b2Body = (tempmc.bd as b2Body);
if (body){
mouseJointDef = new b2MouseJointDef();
mouseJointDef.body1 = world.GetGroundBody();
mouseJointDef.body2 = body;
mouseJointDef.target.Set((_stage.mouseX / 30), (_stage.mouseY / 30));
mouseJointDef.maxForce = mouse_MaxForce;
mouseJointDef.timeStep = STEP;
mouseJoint = (world.CreateJoint(mouseJointDef) as b2MouseJoint);
};
}
public function getBody():b2Body{
var temp:b2Body;
var b:b2Body = world.GetBodyList();
while (b) {
if (b.m_userData){
if (b.m_userData.element){
if (b.m_userData.element.name == tempmc.name){
temp = b;
break;
};
};
};
b = b.GetNext();
};
return (temp);
}
public function destroyMouse(evt:MouseEvent=null):void{
if (mouseJoint){
world.DestroyJoint(mouseJoint);
mouseJoint = null;
_stage.removeEventListener(MouseEvent.MOUSE_DOWN, createMouse);
_stage.removeEventListener(MouseEvent.MOUSE_UP, destroyMouse);
_useMouseJoint = false;
};
}
public function showDebug(container:DisplayObjectContainer):void{
var sp:Sprite = new Sprite();
container.addChild(sp);
var dbg:b2DebugDraw = new b2DebugDraw();
dbg.m_sprite = sp;
dbg.m_alpha = 0.5;
dbg.m_drawScale = PHYSCALE;
dbg.m_fillAlpha = 0.5;
dbg.m_drawFlags = b2DebugDraw.e_shapeBit;
dbg.m_lineThickness = 1;
world.SetDebugDraw(dbg);
}
public function clear():void{
var dBody:b2Body;
var dJoint:b2Joint;
var groundBody:b2Body = _world.GetGroundBody();
var tempBody:b2Body = _world.GetBodyList();
while (_world.GetBodyCount() > 1) {
if (tempBody != groundBody){
dBody = tempBody;
tempBody = tempBody.GetNext();
_world.DestroyBody(dBody);
} else {
tempBody = tempBody.GetNext();
};
};
var tempJoint:b2Joint = _world.GetJointList();
while (_world.GetJointCount() > 0) {
dJoint = tempJoint;
tempJoint = tempJoint.GetNext();
_world.DestroyJoint(dJoint);
};
_world = null;
}
public function get world():b2World{
return (_world);
}
public static function getInstance():Box2dFactory{
if (_instance == null){
_instance = new (Box2dFactory);
};
return (_instance);
}
}
}//package UserdefinedClass
Section 175
//Camera (UserdefinedClass.Camera)
package UserdefinedClass {
import flash.events.*;
import flash.display.*;
import flash.geom.*;
public class Camera {
public var lockTarget:DisplayObject;
public var lockPoint:Point;
public var lockWay:String;
private var _isLocked:Boolean;// = false
public var easing:Boolean;// = false
public var easingRate:Number;// = 0.5
public var count:int;// = 50
public static var LOCKWAY_NORMAL:String = "lockway_normal";
public static var LOCKWAY_X:String = "lockway_x";
public static var LOCKWAY_Y:String = "lockway_y";
private static var _instance:Camera;
public static var Scene:DisplayObject;
public function Camera(s:SingleEnforcer){
super();
if (s == null){
throw (new Error("using SingletonPattern"));
};
}
public function set x(x:Number):void{
Scene.x = -(x);
}
public function get x():Number{
return (-(Scene.x));
}
public function set y(y:Number):void{
Scene.y = -(y);
}
public function get y():Number{
return (-(Scene.y));
}
public function reset():void{
Scene.x = 0;
Scene.y = 0;
}
public function get isLocked():Boolean{
return (_isLocked);
}
public function moveTo(p:Point, t:Point=null):void{
this.x = (t.x - p.x);
this.y = (t.y - p.y);
}
public function lookAt(t:DisplayObject, p:Point=null, lw:String="lockway_normal"):void{
if (p == null){
lockPoint = new Point(0, 0);
} else {
lockPoint = p;
};
lockTarget = t;
lockWay = lw;
lockCemeraHandler(null);
}
private function lockCemeraHandler(e:Event):void{
switch (lockWay){
case LOCKWAY_NORMAL:
lockWayNormal();
break;
case LOCKWAY_X:
lockWayX();
break;
case LOCKWAY_Y:
lockWayY();
break;
};
}
private function lockWayNormal():void{
if (easing){
this.x = (this.x + (((lockTarget.x - this.x) - lockPoint.x) * easingRate));
this.y = (this.y + (((lockTarget.y - this.y) - lockPoint.y) * easingRate));
if (lockTarget.y < -200){
} else {
this.y = (this.y + (((lockTarget.y - this.y) - lockPoint.y) * easingRate));
};
} else {
this.x = (lockTarget.x - lockPoint.x);
this.y = (lockTarget.y - lockPoint.y);
};
}
private function lockWayX():void{
if (easing){
this.x = (this.x + (((lockTarget.x - this.x) - lockPoint.x) * easingRate));
} else {
this.x = (lockTarget.x - lockPoint.x);
};
}
private function lockWayY():void{
if (easing){
this.y = (this.y + (((lockTarget.y - this.y) - lockPoint.y) * easingRate));
} else {
this.y = (lockTarget.y - lockPoint.y);
};
}
public function clear(){
_instance = null;
}
public static function getInstance(container:Sprite):Camera{
if (_instance == null){
Scene = container;
_instance = new Camera(new SingleEnforcer());
};
return (_instance);
}
}
}//package UserdefinedClass
class SingleEnforcer {
private function SingleEnforcer(){
}
}
Section 176
//Clr (UserdefinedClass.Clr)
package UserdefinedClass {
import flash.display.*;
public class Clr {
public function Clr(){
super();
}
public static function removeAllChildren(container:DisplayObjectContainer):void{
var count:int = container.numChildren;
var i:int;
while (i < count) {
container.removeChildAt(0);
i++;
};
}
}
}//package UserdefinedClass
Section 177
//DisplaytoBitMap (UserdefinedClass.DisplaytoBitMap)
package UserdefinedClass {
import flash.display.*;
import flash.geom.*;
public class DisplaytoBitMap {
public function DisplaytoBitMap(){
super();
}
public static function Change(Dis:DisplayObjectContainer){
var tempbitmapdata:BitmapData = new BitmapData((Dis.width / Dis.scaleX), (Dis.height / Dis.scaleY), true, 0);
var rectangle:Rectangle = Dis.getBounds(Dis.stage);
var mix:Matrix = new Matrix();
mix.tx = (mix.tx - rectangle.x);
mix.ty = (mix.ty - rectangle.y);
tempbitmapdata.draw(Dis, mix);
Clr.removeAllChildren(Dis);
var tempbitmap:Bitmap = new Bitmap(tempbitmapdata);
tempbitmap.x = (tempbitmap.x + rectangle.x);
tempbitmap.y = (tempbitmap.y + rectangle.y);
Dis.addChild(tempbitmap);
}
public static function BigBitMapChange(Dis:DisplayObjectContainer){
var i:int;
var j:int;
var tempw:Number;
var temph:Number;
var tempbitmapdata:BitmapData;
var mix:Matrix;
var tempbitmap:Bitmap;
var wcount:int;
var hcount:int;
wcount = Math.ceil((Dis.width / 2880));
hcount = Math.ceil((Dis.height / 2880));
var w:Number = Dis.width;
var h:Number = Dis.height;
var bitmapCache:Array = new Array();
var rectangle:Rectangle = Dis.getBounds(Dis.stage);
if ((((wcount == 1)) && ((hcount == 1)))){
Change(Dis);
return;
};
i = 0;
while (i < hcount) {
j = 0;
while (j < wcount) {
tempw = 0;
temph = 0;
if ((i + 1) == hcount){
temph = h;
if (temph < 2880){
temph = Math.ceil(temph);
};
} else {
h = (h - 2880);
temph = 2880;
};
if ((j + 1) == wcount){
tempw = w;
if (tempw < 2880){
tempw = Math.ceil(tempw);
};
} else {
w = (w - 2880);
tempw = 2880;
};
tempbitmapdata = new BitmapData(tempw, temph, true, 0);
mix = new Matrix();
mix.tx = (mix.tx - rectangle.x);
mix.ty = (mix.ty - rectangle.y);
mix.tx = (mix.tx - (2880 * j));
mix.ty = (mix.ty - (2880 * i));
tempbitmapdata.draw(Dis, mix);
tempbitmap = new Bitmap(tempbitmapdata);
tempbitmap.x = (tempbitmap.x + rectangle.x);
tempbitmap.y = (tempbitmap.y + rectangle.y);
tempbitmap.x = (tempbitmap.x + (2880 * j));
tempbitmap.y = (tempbitmap.y + (2880 * i));
bitmapCache.push(tempbitmap);
j++;
};
i++;
};
Clr.removeAllChildren(Dis);
var len:int = bitmapCache.length;
i = 0;
while (i < len) {
Dis.addChild((bitmapCache[i] as Bitmap));
i++;
};
}
public static function ChangetoBitMap(Dis:DisplayObjectContainer):Bitmap{
var tempbitmapdata:BitmapData = new BitmapData((Dis.width / Dis.scaleX), (Dis.height / Dis.scaleY), true, 0);
var rectangle:Rectangle = Dis.getBounds(Dis.stage);
var mix:Matrix = new Matrix();
mix.tx = (mix.tx - rectangle.x);
mix.ty = (mix.ty - rectangle.y);
tempbitmapdata.draw(Dis, mix);
var tempbitmap:Bitmap = new Bitmap(tempbitmapdata);
tempbitmap.x = (tempbitmap.x + rectangle.x);
tempbitmap.y = (tempbitmap.y + rectangle.y);
return (tempbitmap);
}
}
}//package UserdefinedClass
Section 178
//Input (UserdefinedClass.Input)
package UserdefinedClass {
import flash.events.*;
import flash.display.*;
public class Input {
public static var LEFT:uint = 39;
public static var RIGHT:uint = 37;
public static var UP:uint = 38;
public static var DOWN:uint = 40;
public static var SHIFT:uint = 16;
public static var Z:uint = 90;
public static var X:uint = 88;
public static var SPACE:uint = 32;
public static var P:uint = 80;
public static var R:uint = 82;
public static var key:Array = new Array();
public static var sta:Stage;
public function Input(){
super();
}
public static function addinput(_sta:Stage){
if (sta){
return;
};
sta = _sta;
sta.addEventListener(KeyboardEvent.KEY_UP, onkeyup);
sta.addEventListener(KeyboardEvent.KEY_DOWN, onkeydown);
}
private static function onkeydown(e:KeyboardEvent):void{
key[e.keyCode] = true;
}
private static function onkeyup(e:KeyboardEvent):void{
key[e.keyCode] = false;
}
public static function keydownrunfun(keynum:uint, fun:Function){
var f:Function = fun;
((key[keynum]) && (f()));
}
public static function keyuprunfun(keynum:uint, fun:Function){
var f:Function = fun;
if (key[keynum] == false){
f();
};
}
public static function removeinput(){
sta.removeEventListener(KeyboardEvent.KEY_UP, onkeyup);
sta.removeEventListener(KeyboardEvent.KEY_DOWN, onkeydown);
sta = null;
}
}
}//package UserdefinedClass
Section 179
//Mybutton (UserdefinedClass.Mybutton)
package UserdefinedClass {
import flash.net.*;
import flash.display.*;
public class Mybutton extends SimpleButton {
public var netobj:Object;
public function Mybutton(){
netobj = new Object();
super();
SoundControl.Mybtnground.push(this);
}
public function setlink(url:String){
netobj["req"] = new URLRequest(url);
}
public function link(){
var req:URLRequest = (netobj["req"] as URLRequest);
navigateToURL(req);
}
}
}//package UserdefinedClass
Section 180
//MyMath (UserdefinedClass.MyMath)
package UserdefinedClass {
import flash.geom.*;
public class MyMath {
public function MyMath(){
super();
}
public static function randRange(max:Number):Number{
var randomNum:Number = int((Math.random() * (max + 1)));
return (randomNum);
}
public static function FrandRange(min:Number, max:Number):Number{
var randomNum:Number = (int((Math.random() * ((max - min) + 1))) + min);
return (randomNum);
}
public static function ranRangeground(min:Number, max:Number, Num:int):Array{
var _random:int;
var temp:Array = new Array();
var len:int = ((max - min) + 1);
var rearr:Array = new Array();
var i:int;
while (i < len) {
temp.push((min + i));
i++;
};
while (Num) {
_random = randRange((len - 1));
rearr.push(temp[_random]);
temp.splice(_random, 1);
len--;
Num--;
};
return (rearr);
}
public static function NumtoArray(num:int, flushleft:Boolean=true):Array{
var str:String = String(num);
var len:int = str.length;
var i:int;
var array:Array = new Array();
while (i < len) {
array.push(int(str.charAt(i)));
i++;
};
if (!flushleft){
array.reverse();
};
return (array);
}
public static function TimeFormat(num:int):Array{
if (num >= 6000){
num = 5999;
};
var minute:int = (num / 60);
var second:int = (num % 60);
var minutearr:Array = worknum(minute);
var secondarr:Array = worknum(second);
return (new Array(secondarr[0], secondarr[1], minutearr[0], minutearr[1]));
}
public static function worknum(num:int):Array{
var ten:int = (num * 0.1);
var one:int = (num % 10);
return (new Array(one, ten));
}
public static function LtoG(contain, child):Point{
var _loc_3:* = undefined;
var _loc_4:* = undefined;
_loc_3 = child.localToGlobal(new Point(0, 0));
_loc_4 = contain.globalToLocal(_loc_3);
return (new Point(_loc_4.x, _loc_4.y));
}
}
}//package UserdefinedClass
Section 181
//MySave (UserdefinedClass.MySave)
package UserdefinedClass {
import flash.net.*;
public class MySave {
public static var shareobj:SharedObject;
public function MySave(){
super();
}
public static function init(savename:String){
shareobj = Main.FogAPI.Storage.GetLocal(savename);
}
public static function exist(varname:String):Boolean{
return (Boolean(((shareobj) && (shareobj.data[varname]))));
}
public static function clear(){
if (shareobj){
shareobj.clear();
};
}
public static function setdata(varname:String, vardata){
shareobj.data[varname] = vardata;
}
public static function save(){
Main.FogAPI.Storage.Sync();
}
public static function cleardata(varname:String){
shareobj.data[varname] = null;
delete shareobj.data[varname];
}
public static function getdata(varname:String){
return (shareobj.data[varname]);
}
}
}//package UserdefinedClass
Section 182
//MyTime (UserdefinedClass.MyTime)
package UserdefinedClass {
import flash.events.*;
import flash.utils.*;
public class MyTime {
public var count:int;
public var time:Timer;
private var Fun:Function;
private var endFun:Function;
public function MyTime(fun:Function){
super();
Fun = fun;
count = 0;
}
public function starttime(){
time = new Timer(1000);
time.addEventListener(TimerEvent.TIMER, oncountdown);
time.start();
}
public function oncountdown(e:TimerEvent):void{
count++;
Fun();
}
public function pausetime(){
time.stop();
}
public function restart(){
time.start();
}
public function removetime(){
time.stop();
time.removeEventListener(TimerEvent.TIMER, oncountdown);
}
}
}//package UserdefinedClass
Section 183
//SoundControl (UserdefinedClass.SoundControl)
package UserdefinedClass {
import flash.media.*;
public class SoundControl {
public static var buttonsound:Number = 1;
public static var Mybtnground:Array = new Array();
public static var Mysdground:Array = new Array();
public function SoundControl(){
super();
}
public static function setbtnsound(volume:Number){
var i:*;
if (!Mybtnground.length){
return;
};
var sdtransform:SoundTransform = new SoundTransform(volume);
for (i in Mybtnground) {
(Mybtnground[i] as Mybutton).soundTransform = sdtransform;
};
}
public static function setsd(volume:Number){
var i:*;
if (!Mysdground.length){
return;
};
var sdtransform:SoundTransform = new SoundTransform(volume);
for (i in Mysdground) {
(Mysdground[i] as BaseSound).sdChannel.soundTransform = sdtransform;
};
}
public static function destorySdground(){
Mysdground = new Array();
}
public static function stopallsound(){
SoundMixer.stopAll();
}
public static function setallsd(volume:Number){
var sdtransform:SoundTransform = new SoundTransform();
sdtransform.volume = volume;
SoundMixer.soundTransform = sdtransform;
}
public static function destory(){
Mybtnground = new Array();
Mysdground = new Array();
}
}
}//package UserdefinedClass
Section 184
//anchor (anchor)
package {
import flash.display.*;
public dynamic class anchor extends MovieClip {
public var anchor1:MovieClip;
public var anchor2:MovieClip;
}
}//package
Section 185
//Background (Background)
package {
import flash.display.*;
public dynamic class Background extends MovieClip {
}
}//package
Section 186
//Background1 (Background1)
package {
import flash.display.*;
public dynamic class Background1 extends MovieClip {
}
}//package
Section 187
//BBack (BBack)
package {
import flash.display.*;
public dynamic class BBack extends MovieClip {
}
}//package
Section 188
//BBack1 (BBack1)
package {
import flash.display.*;
public dynamic class BBack1 extends MovieClip {
}
}//package
Section 189
//BGM (BGM)
package {
import flash.media.*;
public dynamic class BGM extends Sound {
}
}//package
Section 190
//BGM2 (BGM2)
package {
import flash.media.*;
public dynamic class BGM2 extends Sound {
}
}//package
Section 191
//BGM3 (BGM3)
package {
import flash.media.*;
public dynamic class BGM3 extends Sound {
}
}//package
Section 192
//Buy_sd (Buy_sd)
package {
import flash.media.*;
public dynamic class Buy_sd extends Sound {
}
}//package
Section 193
//Car_sd (Car_sd)
package {
import flash.media.*;
public dynamic class Car_sd extends Sound {
}
}//package
Section 194
//Carbody1 (Carbody1)
package {
import flash.display.*;
public dynamic class Carbody1 extends MovieClip {
public var lun1:MovieClip;
public var lun2:MovieClip;
public var anchor1:MovieClip;
public var anchor2:MovieClip;
public var car:MovieClip;
public var hit:MovieClip;
}
}//package
Section 195
//Carbody2 (Carbody2)
package {
import flash.display.*;
public dynamic class Carbody2 extends MovieClip {
public var lun1:MovieClip;
public var lun2:MovieClip;
public var anchor1:MovieClip;
public var anchor2:MovieClip;
public var car:MovieClip;
public var hit:MovieClip;
}
}//package
Section 196
//Carbody3 (Carbody3)
package {
import flash.display.*;
public dynamic class Carbody3 extends MovieClip {
public var lun1:MovieClip;
public var lun2:MovieClip;
public var anchor1:MovieClip;
public var anchor2:MovieClip;
public var car:MovieClip;
public var hit:MovieClip;
}
}//package
Section 197
//Carbody4 (Carbody4)
package {
import flash.display.*;
public dynamic class Carbody4 extends MovieClip {
public var d1:MovieClip;
public var d2:MovieClip;
public var lun1:MovieClip;
public var lun2:MovieClip;
public var anchor1:MovieClip;
public var anchor2:MovieClip;
public var car:MovieClip;
public var hit:MovieClip;
}
}//package
Section 198
//Carbody5 (Carbody5)
package {
import flash.display.*;
public dynamic class Carbody5 extends MovieClip {
public var d1:MovieClip;
public var d2:MovieClip;
public var lun1:MovieClip;
public var lun2:MovieClip;
public var anchor1:MovieClip;
public var anchor2:MovieClip;
public var car:MovieClip;
public var hit:MovieClip;
}
}//package
Section 199
//Carhead1 (Carhead1)
package {
import flash.display.*;
public dynamic class Carhead1 extends MovieClip {
public var d1:MovieClip;
public var z2:MovieClip;
public var d2:MovieClip;
public var lightmark:MovieClip;
public var lun1:MovieClip;
public var yan1:MovieClip;
public var lun2:MovieClip;
public var yan2:MovieClip;
public var head:MovieClip;
public var anchor1:MovieClip;
public var anchor2:MovieClip;
public var car:MovieClip;
public var z1:MovieClip;
}
}//package
Section 200
//Carhead2 (Carhead2)
package {
import flash.display.*;
public dynamic class Carhead2 extends MovieClip {
public var d1:MovieClip;
public var z2:MovieClip;
public var d2:MovieClip;
public var lightmark:MovieClip;
public var lun1:MovieClip;
public var yan1:MovieClip;
public var lun2:MovieClip;
public var yan2:MovieClip;
public var head:MovieClip;
public var anchor1:MovieClip;
public var anchor2:MovieClip;
public var car:MovieClip;
public var z1:MovieClip;
}
}//package
Section 201
//Cover (Cover)
package {
import flash.display.*;
public dynamic class Cover extends MovieClip {
public var help_btn:SimpleButton;
public var moregame_btn:SimpleButton;
public var mm1:SimpleButton;
public var host_btn:SimpleButton;
public var play_btn:SimpleButton;
}
}//package
Section 202
//Effect (Effect)
package {
import flash.display.*;
public dynamic class Effect extends MovieClip {
public function Effect(){
addFrameScript(11, frame12);
}
function frame12(){
stop();
}
}
}//package
Section 203
//Effect_sd (Effect_sd)
package {
import flash.media.*;
public dynamic class Effect_sd extends Sound {
}
}//package
Section 204
//EndMc (EndMc)
package {
import flash.display.*;
public dynamic class EndMc extends MovieClip {
}
}//package
Section 205
//fang (fang)
package {
import flash.display.*;
public dynamic class fang extends MovieClip {
}
}//package
Section 206
//Gameover (Gameover)
package {
import flash.display.*;
public dynamic class Gameover extends MovieClip {
public var moregame_btn:SimpleButton;
public var mm1:SimpleButton;
public var retry_btn:SimpleButton;
public var back_btn:SimpleButton;
}
}//package
Section 207
//Gameui (Gameui)
package {
import flash.display.*;
public dynamic class Gameui extends MovieClip {
public var t0:MovieClip;
public var t1:MovieClip;
public var menu_btn:SimpleButton;
public var t2:MovieClip;
public var music_btn:MovieClip;
public var t3:MovieClip;
public var pause_btn:MovieClip;
public var res_btn:SimpleButton;
public var power:MovieClip;
public var p:MovieClip;
}
}//package
Section 208
//Hit_sd (Hit_sd)
package {
import flash.media.*;
public dynamic class Hit_sd extends Sound {
}
}//package
Section 209
//Howtoplay (Howtoplay)
package {
import flash.display.*;
public dynamic class Howtoplay extends MovieClip {
public var item:MovieClip;
public var moregame_btn:SimpleButton;
public var mm1:SimpleButton;
public var next_btn:SimpleButton;
public function Howtoplay(){
addFrameScript(0, frame1);
}
function frame1(){
stop();
}
}
}//package
Section 210
//i101 (i101)
package {
import flash.display.*;
public dynamic class i101 extends MovieClip {
}
}//package
Section 211
//i102 (i102)
package {
import flash.display.*;
public dynamic class i102 extends MovieClip {
}
}//package
Section 212
//i103 (i103)
package {
import flash.display.*;
public dynamic class i103 extends MovieClip {
}
}//package
Section 213
//i104 (i104)
package {
import flash.display.*;
public dynamic class i104 extends MovieClip {
}
}//package
Section 214
//i11 (i11)
package {
import flash.display.*;
public dynamic class i11 extends MovieClip {
}
}//package
Section 215
//i12 (i12)
package {
import flash.display.*;
public dynamic class i12 extends MovieClip {
}
}//package
Section 216
//i13 (i13)
package {
import flash.display.*;
public dynamic class i13 extends MovieClip {
}
}//package
Section 217
//i21 (i21)
package {
import flash.display.*;
public dynamic class i21 extends MovieClip {
}
}//package
Section 218
//i22 (i22)
package {
import flash.display.*;
public dynamic class i22 extends MovieClip {
}
}//package
Section 219
//i23 (i23)
package {
import flash.display.*;
public dynamic class i23 extends MovieClip {
}
}//package
Section 220
//i31 (i31)
package {
import flash.display.*;
public dynamic class i31 extends MovieClip {
}
}//package
Section 221
//i32 (i32)
package {
import flash.display.*;
public dynamic class i32 extends MovieClip {
}
}//package
Section 222
//i33 (i33)
package {
import flash.display.*;
public dynamic class i33 extends MovieClip {
}
}//package
Section 223
//i41 (i41)
package {
import flash.display.*;
public dynamic class i41 extends MovieClip {
}
}//package
Section 224
//i42 (i42)
package {
import flash.display.*;
public dynamic class i42 extends MovieClip {
}
}//package
Section 225
//i43 (i43)
package {
import flash.display.*;
public dynamic class i43 extends MovieClip {
}
}//package
Section 226
//i51 (i51)
package {
import flash.display.*;
public dynamic class i51 extends MovieClip {
}
}//package
Section 227
//i52 (i52)
package {
import flash.display.*;
public dynamic class i52 extends MovieClip {
}
}//package
Section 228
//i53 (i53)
package {
import flash.display.*;
public dynamic class i53 extends MovieClip {
}
}//package
Section 229
//i54 (i54)
package {
import flash.display.*;
public dynamic class i54 extends MovieClip {
}
}//package
Section 230
//i61 (i61)
package {
import flash.display.*;
public dynamic class i61 extends MovieClip {
}
}//package
Section 231
//i62 (i62)
package {
import flash.display.*;
public dynamic class i62 extends MovieClip {
}
}//package
Section 232
//i63 (i63)
package {
import flash.display.*;
public dynamic class i63 extends MovieClip {
}
}//package
Section 233
//i64 (i64)
package {
import flash.display.*;
public dynamic class i64 extends MovieClip {
}
}//package
Section 234
//i71 (i71)
package {
import flash.display.*;
public dynamic class i71 extends MovieClip {
}
}//package
Section 235
//i72 (i72)
package {
import flash.display.*;
public dynamic class i72 extends MovieClip {
}
}//package
Section 236
//i73 (i73)
package {
import flash.display.*;
public dynamic class i73 extends MovieClip {
}
}//package
Section 237
//i74 (i74)
package {
import flash.display.*;
public dynamic class i74 extends MovieClip {
}
}//package
Section 238
//i81 (i81)
package {
import flash.display.*;
public dynamic class i81 extends MovieClip {
}
}//package
Section 239
//i82 (i82)
package {
import flash.display.*;
public dynamic class i82 extends MovieClip {
}
}//package
Section 240
//i83 (i83)
package {
import flash.display.*;
public dynamic class i83 extends MovieClip {
}
}//package
Section 241
//i84 (i84)
package {
import flash.display.*;
public dynamic class i84 extends MovieClip {
}
}//package
Section 242
//i91 (i91)
package {
import flash.display.*;
public dynamic class i91 extends MovieClip {
}
}//package
Section 243
//i92 (i92)
package {
import flash.display.*;
public dynamic class i92 extends MovieClip {
}
}//package
Section 244
//i93 (i93)
package {
import flash.display.*;
public dynamic class i93 extends MovieClip {
}
}//package
Section 245
//i94 (i94)
package {
import flash.display.*;
public dynamic class i94 extends MovieClip {
}
}//package
Section 246
//Item1 (Item1)
package {
import flash.display.*;
public dynamic class Item1 extends MovieClip {
}
}//package
Section 247
//Item10 (Item10)
package {
import flash.display.*;
public dynamic class Item10 extends MovieClip {
public function Item10(){
addFrameScript(0, frame1, 30, frame31);
}
function frame1(){
stop();
}
function frame31(){
stop();
}
}
}//package
Section 248
//Item11 (Item11)
package {
import flash.display.*;
public dynamic class Item11 extends MovieClip {
}
}//package
Section 249
//Item12 (Item12)
package {
import flash.display.*;
public dynamic class Item12 extends MovieClip {
}
}//package
Section 250
//Item13 (Item13)
package {
import flash.display.*;
public dynamic class Item13 extends MovieClip {
}
}//package
Section 251
//Item14 (Item14)
package {
import flash.display.*;
public dynamic class Item14 extends MovieClip {
}
}//package
Section 252
//Item15 (Item15)
package {
import flash.display.*;
public dynamic class Item15 extends MovieClip {
}
}//package
Section 253
//Item2 (Item2)
package {
import flash.display.*;
public dynamic class Item2 extends MovieClip {
}
}//package
Section 254
//Item3 (Item3)
package {
import flash.display.*;
public dynamic class Item3 extends MovieClip {
}
}//package
Section 255
//Item4 (Item4)
package {
import flash.display.*;
public dynamic class Item4 extends MovieClip {
}
}//package
Section 256
//Item5 (Item5)
package {
import flash.display.*;
public dynamic class Item5 extends MovieClip {
}
}//package
Section 257
//Item6 (Item6)
package {
import flash.display.*;
public dynamic class Item6 extends MovieClip {
public function Item6(){
addFrameScript(0, frame1, 28, frame29);
}
function frame1(){
stop();
}
function frame29(){
stop();
}
}
}//package
Section 258
//Item7 (Item7)
package {
import flash.display.*;
public dynamic class Item7 extends MovieClip {
}
}//package
Section 259
//Item8 (Item8)
package {
import flash.display.*;
public dynamic class Item8 extends MovieClip {
public function Item8(){
addFrameScript(0, frame1, 29, frame30);
}
function frame1(){
stop();
}
function frame30(){
stop();
}
}
}//package
Section 260
//Item9 (Item9)
package {
import flash.display.*;
public dynamic class Item9 extends MovieClip {
}
}//package
Section 261
//Loadingmc (Loadingmc)
package {
import flash.display.*;
public dynamic class Loadingmc extends MovieClip {
}
}//package
Section 262
//LoadingPreloader (LoadingPreloader)
package {
import flash.display.*;
public dynamic class LoadingPreloader extends MovieClip {
}
}//package
Section 263
//Main (Main)
package {
import fog.as3.*;
import flash.events.*;
import Element.*;
import flash.display.*;
import caurina.transitions.*;
import UserdefinedClass.*;
import flash.utils.*;
import BaseClass.*;
import flash.media.*;
import flash.ui.*;
public class Main extends MovieClip {
public var Game:Sprite;
public var Ui:Sprite;
public var Loading:Sprite;
public var Debug:Sprite;
public var Cue:Sprite;
public var cover:MovieClip;
public var howtoplay:MovieClip;
public var winmc:MovieClip;
public var shop:MovieClip;
public var gameui:MovieClip;
public var selstage:MovieClip;
public var loading:MovieClip;
public var gameover:MovieClip;
public var sucmcarr:Array;
public var gamestage:String;
public var allowplay:int;
public var stagenum:int;
public var mydata:MyData;
public var GameClass:BaseStage;
public var Time:Timer;
public var SoundBool:Boolean;// = true
public var initgamenum:int;// = 0
public var highscore:int;// = 0
public var money:int;
public var delaytime:Timer;
public var tempgamestage:int;
public var delayplay:Timer;
public var selpoint:int;// = 1
public var seltrain:int;// = 1
public var shopmenu:Boolean;// = false
public var dietime:int;// = 0
public var URLstr:String;// = "http://www.freeonlinegames.com/tag/Driving_Games"
public var urlstr:String;// = "http://www.freeonlinegames.com/game/material-mole.html"
public var logolink:String;
public var NewAd:MovieClip;
public var ml:MovieClip;
public static var bgm2:BaseSound = new BaseSound("BGM2");
public static var bgm3:BaseSound = new BaseSound("BGM3");
public static var bgm:BaseSound = new BaseSound("BGM");
public static var buysd:BaseSound = new BaseSound("Buy_sd");
public static var effectsd:BaseSound = new BaseSound("Effect_sd");
public static var carsd:BaseSound = new BaseSound("Car_sd");
public static var hitsd:BaseSound = new BaseSound("Hit_sd");
public static var winsd:BaseSound = new BaseSound("win_sd");
public static var BGMGroup:Array = new Array(bgm2, bgm3);
public static var FogAPI:FogDevAPI;
public function Main(fa:FogDevAPI){
NewAd = new MovieClip();
ml = new MovieClip();
super();
if (stage){
init();
} else {
addEventListener(Event.ADDED_TO_STAGE, init);
};
Main.FogAPI = fa;
}
private function init(e:Event=null):void{
removeEventListener(Event.ADDED_TO_STAGE, init);
var menu:ContextMenu = new ContextMenu();
menu.hideBuiltInItems();
contextMenu = menu;
stage.frameRate = 30;
initdata();
initcontainer();
initUImc();
initgame();
SoundMixer.soundTransform = new SoundTransform(0);
}
private function initdata():void{
gamestage = new String();
stagenum = 0;
loaddata();
}
private function initcontainer():void{
Game = new Sprite();
Ui = new Sprite();
Loading = new Sprite();
Debug = new Sprite();
Cue = new Sprite();
addChild(Game);
addChild(Ui);
addChild(Cue);
addChild(Loading);
addChild(Debug);
}
private function initUImc():void{
cover = new Cover();
howtoplay = new Howtoplay();
selstage = new Selstage();
shop = new Shop();
gameui = new Gameui();
winmc = new Win();
loading = new Loadingmc();
gameover = new Gameover();
}
private function initgame():void{
gamestage = "init";
addEventListener(MouseEvent.MOUSE_UP, onclickbtn);
stage.addEventListener(KeyboardEvent.KEY_UP, onkeyup);
addEventListener(Event.ENTER_FRAME, oncue);
Input.addinput(stage);
showcover();
}
private function onkeyup(e:KeyboardEvent):void{
if (gamestage == "playing"){
if (e.keyCode == Input.P){
gamepause();
};
if (e.keyCode == Input.R){
gamereset();
};
};
if (gamestage == "pause"){
if (e.keyCode == Input.P){
gamepause();
};
};
}
private function oncue(e:Event=null){
var i:int;
var tempMc:Array = new Array(selstage.stage1, selstage.stage2, selstage.stage3, selstage.stage4, selstage.stage5, selstage.stage6, selstage.stage7, selstage.stage8, selstage.stage9, selstage.stage10);
if (gamestage == "select"){
selstage.T.x = 700;
selstage.T.y = 80;
selstage.T1.x = 800;
selstage.T1.y = 80;
i = 0;
while (i < 10) {
if (hitbtn(tempMc[i])){
if (tempMc[i].currentFrame > 1){
selstage.T.x = (tempMc[i].x + 79);
selstage.T.y = (tempMc[i].y - 21);
BaseUI.setmoney(selstage.T, MyData.getInstance().gamedataground[i].JYTcargo[0], "c", 3);
BaseUI.settime(selstage.T, MyData.getInstance().gamedataground[i].JYTtime[0]);
} else {
selstage.T1.x = tempMc[i].x;
selstage.T1.y = (tempMc[i].y - 21);
selstage.T1.gotoAndStop(i);
};
};
i++;
};
};
if (gamestage == "shop"){
updatashop();
};
}
private function updatashop(){
var tempMc3:Array = new Array(shop.car.buy1, shop.car.buy2, shop.car.buy3);
var tempMc1:Array = new Array(shop.car.car1, shop.car.car2, shop.car.car3, shop.car.car4, shop.car.car5);
var tempNum:int;
shop.word.gotoAndStop(1);
var i:int;
while (i < 3) {
if (hitbtn(tempMc3[i])){
tempNum = MyData.getInstance().addv[i];
if (tempNum < 3){
shop.word.gotoAndStop((i + 2));
setcueitemNum(i, tempNum);
} else {
shop.word.gotoAndStop(1);
};
BaseUI.setmoney(shop.word.word, MyData.getInstance().addvv[tempNum], "m", 4);
};
i++;
};
i = 1;
while (i < 5) {
if (hitbtn(tempMc1[i])){
if (tempMc1[i].currentFrame == 2){
shop.word.gotoAndStop(5);
BaseUI.setmoney(shop.word.word, MyData.getInstance().carvalue[(i - 1)], "m", 4);
setcuerandomitem(MyData.getInstance().caritemnum[(i - 1)]);
};
};
i++;
};
}
private function setcuerandomitem(arr:Array){
var tempStr:Array = new Array("a", "b", "c", "d", "e");
var i:int;
while (i < 5) {
BaseUI.setMaxscore(shop.word.num, arr[i], tempStr[i], 2);
i++;
};
}
private function setcueitemNum(Numx:int, Numy:int){
var pArr:Array = new Array();
pArr = MyData.getInstance().itemnum[Numx][Numy];
var tempStr:Array = new Array("a", "b", "c", "d", "e");
var i:int;
while (i < 5) {
BaseUI.setMaxscore(shop.word.num, pArr[i], tempStr[i], 2);
i++;
};
}
public function dorediv(Num:int, num:int):int{
var tempnum:int = (Num % num);
if (tempnum == 0){
return (num);
};
return (tempnum);
}
private function loaddata():void{
var j:int;
MySave.init("MaterialExpress2");
if (MySave.exist("reset")){
allowplay = MySave.getdata("allowplay");
money = MySave.getdata("money");
MyData.getInstance().succeed = MySave.getdata("succeed");
MyData.getInstance().highscore = MySave.getdata("highscore");
MyData.getInstance().addv = MySave.getdata("addv");
MyData.getInstance().cardata = MySave.getdata("cardata");
MyData.getInstance().material = MySave.getdata("material");
MyData.getInstance().stageunlock = MySave.getdata("stageunlock");
MyData.getInstance().caritem = MySave.getdata("caritem");
} else {
MySave.setdata("reset", true);
allowplay = 1;
money = 0;
MyData.getInstance().highscore = new Array();
j = 0;
while (j < 10) {
MyData.getInstance().highscore.push(0);
j++;
};
MySave.setdata("stageunlock", MyData.getInstance().stageunlock);
MySave.setdata("cardata", MyData.getInstance().cardata);
MySave.setdata("highscore", MyData.getInstance().highscore);
MySave.setdata("money", money);
MySave.setdata("material", MyData.getInstance().material);
MySave.setdata("allowplay", allowplay);
MySave.setdata("succeed", MyData.getInstance().succeed);
MySave.setdata("addv", MyData.getInstance().addv);
MySave.setdata("caritem", MyData.getInstance().caritem);
MySave.save();
};
}
public function savestage(){
MySave.setdata("stageunlock", MyData.getInstance().stageunlock);
MySave.save();
}
public function removedata(){
MySave.init("MaterialExpress2");
MySave.clear();
}
private function savedata():void{
MySave.setdata("allowplay", allowplay);
MySave.save();
}
public function saveCardata(){
MySave.setdata("caritem", MyData.getInstance().caritem);
MySave.setdata("cardata", MyData.getInstance().cardata);
MySave.save();
}
public function savemoney(){
MySave.setdata("money", money);
MySave.save();
}
public function saveshop(){
MySave.setdata("money", money);
MySave.setdata("material", MyData.getInstance().material);
MySave.setdata("cardata", MyData.getInstance().cardata);
MySave.setdata("addv", MyData.getInstance().addv);
MySave.save();
}
public function saveHS(){
MySave.setdata("highscore", MyData.getInstance().highscore);
MySave.save();
}
public function savesucceed(){
MySave.setdata("succeed", MyData.getInstance().succeed);
MySave.save();
}
private function savealldata(){
MySave.setdata("cardata", MyData.getInstance().cardata);
MySave.setdata("highscore", MyData.getInstance().highscore);
MySave.setdata("money", money);
MySave.setdata("allowplay", allowplay);
MySave.setdata("succeed", MyData.getInstance().succeed);
MySave.setdata("addv", MyData.getInstance().addv);
MySave.save();
}
private function issave():void{
initgamenum++;
if (initgamenum > MySave.getdata("allowplay")){
if (initgamenum < 11){
allowplay = initgamenum;
MySave.setdata("allowplay", allowplay);
MySave.save();
};
};
initgamenum--;
}
private function showcover():void{
SoundControl.stopallsound();
Main.bgm.playsound(1000000);
gamestage = "cover";
Clr.removeAllChildren(Ui);
Ui.addChild(cover);
}
private function showshop(){
gamestage = "shop";
Clr.removeAllChildren(Ui);
Ui.addChild(shop);
initshop();
}
private function showsuc(){
}
private function updatasuc():void{
}
private function remoney(lv:int):int{
return (MyData.getInstance().charv[lv]);
}
public function showReel(num:int){
var tempMc:MovieClip = new Reel();
tempMc.J.gotoAndStop(num);
Ui.addChild(tempMc);
gamestage = "reel";
}
private function initshop(){
var tempMc1:Array = new Array(shop.car.car1, shop.car.car2, shop.car.car3, shop.car.car4, shop.car.car5);
var tempStr:Array = new Array("a", "b", "c", "d", "e");
var tempMc2:Array = new Array("sp", "bp", "ap");
if (MyData.getInstance().caritem[0]){
shop.car.head.head.carmask.alpha = 1;
} else {
shop.car.head.head.carmask.alpha = 0;
};
if (MyData.getInstance().caritem[1]){
shop.car.head.head.light.alpha = 1;
} else {
shop.car.head.head.light.alpha = 0;
};
var tempNum:int;
var i:int;
while (i < 5) {
tempNum = MyData.getInstance().cardata[i];
tempMc1[i].gotoAndStop((tempNum + 1));
if (tempNum == 3){
shop.car.carbody.gotoAndStop((i + 1));
seltrain = (i + 1);
};
tempNum = MyData.getInstance().material[i];
BaseUI.setMaxscore(shop, tempNum, tempStr[i], 3);
i++;
};
i = 0;
while (i < 3) {
tempNum = MyData.getInstance().addv[i];
shop.car[tempMc2[i]].gotoAndStop((tempNum + 1));
i++;
};
tempNum = (MyData.getInstance().addv[0] + 1);
shop.car.head.lun1.gotoAndStop(tempNum);
shop.car.head.lun2.gotoAndStop(tempNum);
tempNum = (MyData.getInstance().addv[1] + 1);
shop.car.head.head.guan.gotoAndStop(tempNum);
tempNum = (MyData.getInstance().addv[2] + 1);
shop.car.head.head.yan.gotoAndStop(tempNum);
BaseUI.setmoney(shop, money, "m", 6);
}
public function addmoney(am:int){
if ((money + am) <= 999999){
money = (money + am);
} else {
money = 999999;
};
}
private function showselect():void{
stagenum = 0;
gamestage = "select";
Clr.removeAllChildren(Ui);
setselectstage();
Ui.addChild(selstage);
initshop();
}
private function showhowtoplay():void{
gamestage = "howtoplay";
Clr.removeAllChildren(Ui);
Ui.addChild(howtoplay);
howtoplay.gotoAndStop(1);
inithowtoplay();
}
private function inithowtoplay():void{
var tempstr:Array = new Array("a", "b", "c", "d", "e", "f", "g", "h", "i", "j");
var i:int;
while (i < 10) {
BaseUI.setMaxscore(howtoplay.item, MyData.getInstance().itemprice[i], tempstr[i], 4);
i++;
};
}
public function showloading():void{
gamestage = "loading";
SoundControl.stopallsound();
Loading.addChild(loading);
}
private function onclickbtn(e:MouseEvent):void{
if (gamestage == "cover"){
workcover();
return;
};
if (gamestage == "lv"){
worksellv();
return;
};
if (gamestage == "shop"){
workshop();
return;
};
if (gamestage == "howtoplay"){
workhowtoplay();
return;
};
if (gamestage == "select"){
setselect();
return;
};
if (gamestage == "success"){
};
if (gamestage == "playing"){
workplaying();
return;
};
if (gamestage == "over"){
workover();
return;
};
if (gamestage == "win"){
workwin();
return;
};
}
private function workcover():void{
if (hitbtn(cover.play_btn)){
showselect();
SoundMixer.soundTransform = new SoundTransform(1);
return;
};
if (hitbtn(cover.help_btn)){
showhowtoplay();
return;
};
if (hitbtn(cover.host_btn)){
Main.FogAPI.Tracking.GotoURL("http://www.freegamesforyourwebsite.com/");
return;
};
if (hitbtn(cover.moregame_btn)){
Main.FogAPI.Tracking.GotoURL(URLstr);
return;
};
if (hitbtn(cover.mm1)){
Main.FogAPI.Tracking.GotoURL(urlstr);
return;
};
}
private function workplaying():void{
if (hitbtn(gameui.moregame_btn)){
Main.FogAPI.Tracking.GotoURL(URLstr);
return;
};
if (hitbtn(GameClass.startLink)){
return;
};
if (hitbtn(GameClass.endLink)){
return;
};
if (hitbtn(gameui.pause_btn)){
gamepause();
return;
};
if (hitbtn(gameui.res_btn)){
gamereset();
return;
};
if (hitbtn(gameui.menu_btn)){
GameClass.destory();
Clr.removeAllChildren(Game);
SoundControl.stopallsound();
Main.bgm.playsound(1000000);
showselect();
return;
};
if (hitbtn(gameui.music_btn)){
gameui.music_btn.gotoAndStop(((gameui.music_btn.currentFrame % 2) + 1));
if (SoundBool){
SoundBool = false;
} else {
SoundBool = true;
};
if (SoundBool){
SoundControl.setallsd(1);
} else {
SoundControl.setallsd(0);
};
return;
};
if (hitbtn(gameui.logo_btn)){
return;
};
}
private function workhowtoplay():void{
if (hitbtn(howtoplay.next_btn)){
if (howtoplay.currentFrame != 3){
howtoplay.nextFrame();
} else {
loaddata();
showselect();
};
return;
};
if (hitbtn(howtoplay.moregame_btn)){
Main.FogAPI.Tracking.GotoURL(URLstr);
return;
};
if (hitbtn(howtoplay.mm1)){
Main.FogAPI.Tracking.GotoURL(urlstr);
return;
};
}
private function workover():void{
if (hitbtn(gameover.retry_btn)){
gamereset();
return;
};
if (hitbtn(gameover.back_btn)){
GameClass.destory();
Clr.removeAllChildren(Game);
SoundControl.stopallsound();
Main.bgm.playsound(1000000);
showselect();
return;
};
if (hitbtn(gameover.moregame_btn)){
Main.FogAPI.Tracking.GotoURL(URLstr);
return;
};
if (hitbtn(gameover.mm1)){
Main.FogAPI.Tracking.GotoURL(urlstr);
return;
};
}
private function workwin():void{
if (hitbtn(winmc.moregame_btn)){
Main.FogAPI.Tracking.GotoURL(URLstr);
return;
};
if (hitbtn(winmc.next_btn)){
GameClass.destory();
Clr.removeAllChildren(Game);
SoundControl.stopallsound();
Main.bgm.playsound(1000000);
showselect();
return;
};
if (hitbtn(winmc.retry_btn)){
GameClass.destory();
Clr.removeAllChildren(Game);
toplay();
return;
};
if (hitbtn(winmc.mm1)){
Main.FogAPI.Tracking.GotoURL(urlstr);
return;
};
}
public function gamepause(){
gameui.pause_btn.gotoAndStop(((gameui.pause_btn.currentFrame % 2) + 1));
addNew();
GameClass.pausegame();
}
public function addNew(){
if (NewAd.parent){
NewAd.parent.removeChild(NewAd);
return;
};
var o:Object = new Object();
o.position = "bottom";
o.text_color = 0xFF;
o.bar_color = 0xFFFF00;
NewAd = FogAPI.LibraryCall("SuggestedGamesClip", o);
Debug.addChild(NewAd);
}
public function removeNew(){
if (NewAd.parent){
NewAd.parent.removeChild(NewAd);
};
}
public function gamereset(){
GameClass.destory();
Clr.removeAllChildren(Game);
toplay();
}
private function worksellv():void{
}
private function mathhighscore():int{
var HS:int;
var i:int;
while (i < 10) {
HS = (HS + MyData.getInstance().highscore[i]);
i++;
};
return (HS);
}
private function workshop():void{
if (hitbtn(shop.back_btn)){
saveshop();
showselect();
return;
};
if (hitbtn(shop.moregame_btn)){
Main.FogAPI.Tracking.GotoURL(URLstr);
return;
};
var tempMc1:Array = new Array(shop.car.car1, shop.car.car2, shop.car.car3, shop.car.car4, shop.car.car5);
var tempStr:Array = new Array("a", "b", "c", "d", "e");
var tempMc2:Array = new Array("sp", "bp", "ap");
var tempMc3:Array = new Array(shop.car.buy1, shop.car.buy2, shop.car.buy3);
var cursel:int;
var tempNum:int;
var i:int;
while (i < 5) {
tempNum = MyData.getInstance().cardata[i];
if (tempNum == 3){
cursel = i;
break;
};
i++;
};
i = 0;
while (i < 5) {
if (hitbtn(tempMc1[i])){
tempNum = MyData.getInstance().cardata[i];
if (tempNum == 1){
if (((workitemEnough(MyData.getInstance().caritemnum[(i - 1)])) && (workmoneyEnough(MyData.getInstance().carvalue[(i - 1)])))){
workSecMoneyItem(MyData.getInstance().caritemnum[(i - 1)], MyData.getInstance().carvalue[(i - 1)]);
MyData.getInstance().cardata[i] = 3;
MyData.getInstance().cardata[cursel] = 2;
Main.buysd.playsound(1);
saveshop();
initshop();
break;
};
};
if (tempNum != 2){
break;
} else {
MyData.getInstance().cardata[i] = 3;
MyData.getInstance().cardata[cursel] = 2;
MySave.setdata("cardata", MyData.getInstance().cardata);
MySave.save();
initshop();
};
};
i++;
};
i = 0;
while (i < 3) {
if (hitbtn(tempMc3[i])){
tempNum = MyData.getInstance().addv[i];
if (money < MyData.getInstance().addvv[tempNum]){
break;
};
switch (tempNum){
case 0:
case 1:
case 2:
if (workitemNum(i, tempNum)){
Main.buysd.playsound(1);
subitemNum(i, tempNum);
};
break;
default:
break;
};
};
i++;
};
}
private function workSecMoneyItem(arr:Array, num:int){
money = (money - num);
var i:int;
while (i < 5) {
MyData.getInstance().material[i] = (MyData.getInstance().material[i] - arr[i]);
i++;
};
}
private function workmoneyEnough(num:int):Boolean{
if (money < num){
return (false);
};
return (true);
}
private function workitemEnough(arr:Array):Boolean{
var tempbool:Boolean;
var tempArr:Array = new Array();
tempArr = MyData.getInstance().material;
var i:int;
while (i < 5) {
if (tempArr[i] < arr[i]){
tempbool = false;
break;
};
i++;
};
return (tempbool);
}
private function workitemNum(Numx:int, Numy:int):Boolean{
var tempbool:Boolean;
var tempArr:Array = new Array();
tempArr = MyData.getInstance().material;
var pArr:Array = new Array();
pArr = MyData.getInstance().itemnum[Numx][Numy];
var i:int;
while (i < 5) {
if (tempArr[i] < pArr[i]){
tempbool = false;
break;
};
i++;
};
return (tempbool);
}
private function subitemNum(Numx:int, Numy:int){
var pArr:Array = new Array();
pArr = MyData.getInstance().itemnum[Numx][Numy];
var i:int;
while (i < 5) {
MyData.getInstance().material[i] = (MyData.getInstance().material[i] - pArr[i]);
i++;
};
money = (money - MyData.getInstance().addvv[Numy]);
var _local5 = MyData.getInstance().addv;
var _local6 = Numx;
var _local7 = (_local5[_local6] + 1);
_local5[_local6] = _local7;
saveshop();
initshop();
}
private function setselect():void{
if (hitbtn(selstage.moregame_btn)){
Main.FogAPI.Tracking.GotoURL(URLstr);
return;
};
if (hitbtn(selstage.mm1)){
Main.FogAPI.Tracking.GotoURL(urlstr);
return;
};
if (hitbtn(selstage.shop_btn)){
showshop();
return;
};
if (hitbtn(selstage.quit_btn)){
showcover();
return;
};
var tempMc:Array = new Array(selstage.stage1, selstage.stage2, selstage.stage3, selstage.stage4, selstage.stage5, selstage.stage6, selstage.stage7, selstage.stage8, selstage.stage9, selstage.stage10);
var unhit:Boolean;
var i:int;
while (i < 10) {
if (tempMc[i].hitTestPoint(mouseX, mouseY, true)){
if (tempMc[i].currentFrame >= 2){
unhit = false;
stagenum = (i + 1);
};
};
i++;
};
if (unhit){
return;
};
initstage(stagenum);
trace("gamestage:", stagenum);
}
private function showlv(lv:int){
gamestage = "lv";
Clr.removeAllChildren(Ui);
}
private function initstage(num:int):void{
initgamenum = num;
toplay();
}
private function toplay(){
showloading();
delayplay = new Timer(1000, 1);
delayplay.start();
delayplay.addEventListener(TimerEvent.TIMER, loadgame);
}
private function loadgame(e:TimerEvent=null){
delayplay.stop();
delayplay.removeEventListener(TimerEvent.TIMER, loadgame);
gamestage = "standby";
Clr.removeAllChildren(Ui);
var stageclass:Class = (MyData.getInstance().stageclassground[(stagenum - 1)] as Class);
GameClass = new stageclass(this);
Game.addChild(GameClass);
initgameUI();
}
public function delayrun(time:int, fun:Function){
Tweener.addTween(this, {delay:time, onComplete:fun});
}
private function initgameUI(){
gameui.pause_btn.gotoAndStop(1);
Ui.addChild(gameui);
delayplay = new Timer(1000, 1);
delayplay.addEventListener(TimerEvent.TIMER, ongotogame);
delayplay.start();
}
private function ongotogame(e:TimerEvent):void{
delayplay.stop();
delayplay.removeEventListener(TimerEvent.TIMER, ongotogame);
Clr.removeAllChildren(Loading);
gotogame();
}
public function gotogame(){
GameClass.startlistener();
gamestage = "playing";
}
public function setTime(T:int){
BaseUI.settime(gameui, T);
}
public function setSpeedbar(V:int){
gameui.power.gotoAndStop((V + 1));
}
public function setpoint(num:Number){
var sp:Number = 284.4;
var ep:Number = 582.4;
gameui.p.x = (((ep - sp) * (num / 100)) + sp);
BaseUI.setmoney(gameui.p, int(num), "n", 3);
}
public function showGameover():void{
gamestage = "over";
Clr.removeAllChildren(Ui);
Ui.addChild(gameover);
}
public function showWin(T:int, M:int, itemNUM:Array){
winsd.playsound(1);
var tempstr:Array = new Array("a", "b", "c", "d", "e");
BaseUI.settime(winmc, T);
BaseUI.setMaxscore(winmc, M, "m", 5);
var i:int;
while (i < 5) {
BaseUI.setmoney(winmc, itemNUM[i], tempstr[i], 1);
if ((MyData.getInstance().material[i] < 1000)){
MyData.getInstance().material[i] = (MyData.getInstance().material[i] + itemNUM[i]);
} else {
MyData.getInstance().material[i] = 999;
};
i++;
};
if ((money + M) <= 999999){
money = (money + M);
} else {
money = 999999;
};
MySave.setdata("money", money);
MySave.setdata("cardata", MyData.getInstance().cardata);
MySave.setdata("material", MyData.getInstance().material);
MySave.save();
gamestage = "win";
Ui.addChild(winmc);
}
public function setpowerbar(Num:int){
gameui.power.gotoAndStop(Num);
}
private function setselectstage():void{
var tempMc:Array = new Array(selstage.stage1, selstage.stage2, selstage.stage3, selstage.stage4, selstage.stage5, selstage.stage6, selstage.stage7, selstage.stage8, selstage.stage9, selstage.stage10);
var tempArr:Array = MySave.getdata("stageunlock");
var i:int;
while (i < 10) {
tempMc[i].gotoAndStop((tempArr[i] + 1));
tempMc[i]["t"].gotoAndStop((MyData.getInstance().succeed[i]) ? 2 : 1);
tempMc[i]["c"].gotoAndStop((MyData.getInstance().succeed[(i + 10)]) ? 2 : 1);
i++;
};
}
private function hitbtn(btn:DisplayObject):Boolean{
if (((btn) && (btn.visible))){
return (btn.hitTestPoint(mouseX, mouseY, true));
};
return (false);
}
private function destroy(){
Clr.removeAllChildren(Game);
Clr.removeAllChildren(Ui);
Clr.removeAllChildren(Cue);
Clr.removeAllChildren(Loading);
}
}
}//package
Section 264
//MiniLogo (MiniLogo)
package {
import flash.display.*;
public dynamic class MiniLogo extends MovieClip {
}
}//package
Section 265
//r101 (r101)
package {
import flash.display.*;
public dynamic class r101 extends MovieClip {
public var carry10:MovieClip;
public var carry20:MovieClip;
public var carry11:MovieClip;
public var carry21:MovieClip;
public var carry12:MovieClip;
public var carry22:MovieClip;
public var carry13:MovieClip;
public var build:MovieClip;
public var carry14:MovieClip;
public var carry23:MovieClip;
public var carry15:MovieClip;
public var carry24:MovieClip;
public var carry25:MovieClip;
public var tail:MovieClip;
public var run:MovieClip;
public var road:MovieClip;
public var item1:Item15;
public var item2:Item13;
public var carry1:MovieClip;
public var back:MovieClip;
public var newitem:MovieClip;
public var pushitem:MovieClip;
public var carry2:MovieClip;
}
}//package
Section 266
//r102 (r102)
package {
import flash.display.*;
public dynamic class r102 extends MovieClip {
public var carry20:MovieClip;
public var carry21:MovieClip;
public var bridge18:MovieClip;
public var carry22:MovieClip;
public var bridge19:MovieClip;
public var carry23:MovieClip;
public var bridge111:MovieClip;
public var bridge16:MovieClip;
public var carry24:MovieClip;
public var bridge110:MovieClip;
public var bridge17:MovieClip;
public var carry25:MovieClip;
public var bridge14:MovieClip;
public var tail:MovieClip;
public var bridge15:MovieClip;
public var road:MovieClip;
public var bridge12:MovieClip;
public var bridge13:MovieClip;
public var bridge11:MovieClip;
public var item1:Item14;
public var item2:Item11;
public var back:MovieClip;
public var carry2:MovieClip;
}
}//package
Section 267
//r103 (r103)
package {
import flash.display.*;
public dynamic class r103 extends MovieClip {
public var carry3:MovieClip;
public var carry10:MovieClip;
public var carry20:MovieClip;
public var carry11:MovieClip;
public var carry21:MovieClip;
public var carry12:MovieClip;
public var carry30:MovieClip;
public var carry22:MovieClip;
public var carry31:MovieClip;
public var carry13:MovieClip;
public var carry32:MovieClip;
public var carry23:MovieClip;
public var carry14:MovieClip;
public var carry24:MovieClip;
public var carry33:MovieClip;
public var carry15:MovieClip;
public var carry34:MovieClip;
public var carry25:MovieClip;
public var carry35:MovieClip;
public var tail:MovieClip;
public var road:MovieClip;
public var item1:Item15;
public var item2:Item12;
public var carry1:MovieClip;
public var item3:Item11;
public var back:MovieClip;
public var carry2:MovieClip;
}
}//package
Section 268
//r104 (r104)
package {
import flash.display.*;
public dynamic class r104 extends MovieClip {
public var carry3:MovieClip;
public var carry30:MovieClip;
public var carry31:MovieClip;
public var carry32:MovieClip;
public var carry33:MovieClip;
public var endpoint:MovieClip;
public var carry34:MovieClip;
public var carry35:MovieClip;
public var road:MovieClip;
public var item1:Item13;
public var item2:Item14;
public var back:MovieClip;
}
}//package
Section 269
//r11 (r11)
package {
import flash.display.*;
public dynamic class r11 extends MovieClip {
public var carry10:MovieClip;
public var carry11:MovieClip;
public var bridge18:MovieClip;
public var carry12:MovieClip;
public var bridge19:MovieClip;
public var carry13:MovieClip;
public var build:MovieClip;
public var carry14:MovieClip;
public var bridge16:MovieClip;
public var carry15:MovieClip;
public var bridge17:MovieClip;
public var bridge14:MovieClip;
public var tail:MovieClip;
public var run:MovieClip;
public var bridge15:MovieClip;
public var road:MovieClip;
public var bridge12:MovieClip;
public var bridge13:MovieClip;
public var bridge11:MovieClip;
public var item1:Item15;
public var carry1:MovieClip;
public var back:MovieClip;
public var newitem:MovieClip;
public var pushitem:MovieClip;
}
}//package
Section 270
//r12 (r12)
package {
import flash.display.*;
public dynamic class r12 extends MovieClip {
public var tail:MovieClip;
public var road:MovieClip;
public var item1:MovieClip;
public var back:MovieClip;
}
}//package
Section 271
//r13 (r13)
package {
import flash.display.*;
public dynamic class r13 extends MovieClip {
public var bridge26:MovieClip;
public var endpoint:MovieClip;
public var bridge27:MovieClip;
public var bridge24:MovieClip;
public var road:MovieClip;
public var bridge25:MovieClip;
public var bridge22:MovieClip;
public var bridge23:MovieClip;
public var item1:Item12;
public var bridge21:MovieClip;
public var back:MovieClip;
}
}//package
Section 272
//r21 (r21)
package {
import flash.display.*;
public dynamic class r21 extends MovieClip {
public var carry3:MovieClip;
public var carry10:MovieClip;
public var carry20:MovieClip;
public var carry11:MovieClip;
public var carry30:MovieClip;
public var carry21:MovieClip;
public var carry12:MovieClip;
public var carry31:MovieClip;
public var carry22:MovieClip;
public var carry13:MovieClip;
public var build:MovieClip;
public var carry32:MovieClip;
public var carry23:MovieClip;
public var carry14:MovieClip;
public var carry33:MovieClip;
public var carry24:MovieClip;
public var carry15:MovieClip;
public var carry34:MovieClip;
public var carry25:MovieClip;
public var carry35:MovieClip;
public var tail:MovieClip;
public var run:MovieClip;
public var road:MovieClip;
public var item1:Item11;
public var carry1:MovieClip;
public var back:MovieClip;
public var newitem:MovieClip;
public var pushitem:MovieClip;
public var carry2:MovieClip;
}
}//package
Section 273
//r22 (r22)
package {
import flash.display.*;
public dynamic class r22 extends MovieClip {
public var carry10:MovieClip;
public var carry20:MovieClip;
public var carry11:MovieClip;
public var bridge18:MovieClip;
public var carry21:MovieClip;
public var carry12:MovieClip;
public var bridge19:MovieClip;
public var carry22:MovieClip;
public var carry13:MovieClip;
public var carry23:MovieClip;
public var carry14:MovieClip;
public var bridge16:MovieClip;
public var carry24:MovieClip;
public var carry15:MovieClip;
public var bridge17:MovieClip;
public var carry25:MovieClip;
public var bridge14:MovieClip;
public var tail:MovieClip;
public var bridge15:MovieClip;
public var road:MovieClip;
public var bridge12:MovieClip;
public var bridge13:MovieClip;
public var bridge11:MovieClip;
public var item1:Item13;
public var carry1:MovieClip;
public var back:MovieClip;
public var carry2:MovieClip;
}
}//package
Section 274
//r23 (r23)
package {
import flash.display.*;
public dynamic class r23 extends MovieClip {
public var carry10:MovieClip;
public var carry11:MovieClip;
public var carry12:MovieClip;
public var carry13:MovieClip;
public var carry14:MovieClip;
public var carry15:MovieClip;
public var endpoint:MovieClip;
public var road:MovieClip;
public var item1:MovieClip;
public var carry1:MovieClip;
public var back:MovieClip;
}
}//package
Section 275
//r31 (r31)
package {
import flash.display.*;
public dynamic class r31 extends MovieClip {
public var carry10:MovieClip;
public var carry11:MovieClip;
public var carry12:MovieClip;
public var bridge18:MovieClip;
public var bridge28:MovieClip;
public var carry13:MovieClip;
public var build:MovieClip;
public var carry14:MovieClip;
public var bridge16:MovieClip;
public var carry15:MovieClip;
public var bridge26:MovieClip;
public var bridge17:MovieClip;
public var bridge27:MovieClip;
public var bridge14:MovieClip;
public var tail:MovieClip;
public var run:MovieClip;
public var bridge24:MovieClip;
public var bridge15:MovieClip;
public var road:MovieClip;
public var bridge25:MovieClip;
public var bridge12:MovieClip;
public var bridge22:MovieClip;
public var bridge13:MovieClip;
public var bridge23:MovieClip;
public var bridge11:MovieClip;
public var item1:Item13;
public var bridge21:MovieClip;
public var carry1:MovieClip;
public var back:MovieClip;
public var newitem:MovieClip;
public var pushitem:MovieClip;
}
}//package
Section 276
//r32 (r32)
package {
import flash.display.*;
public dynamic class r32 extends MovieClip {
public var carry10:MovieClip;
public var carry11:MovieClip;
public var bridge115:MovieClip;
public var carry12:MovieClip;
public var bridge114:MovieClip;
public var bridge18:MovieClip;
public var bridge19:MovieClip;
public var carry13:MovieClip;
public var carry14:MovieClip;
public var bridge111:MovieClip;
public var bridge16:MovieClip;
public var carry15:MovieClip;
public var bridge110:MovieClip;
public var bridge17:MovieClip;
public var bridge113:MovieClip;
public var bridge14:MovieClip;
public var tail:MovieClip;
public var bridge112:MovieClip;
public var bridge15:MovieClip;
public var road:MovieClip;
public var bridge12:MovieClip;
public var bridge13:MovieClip;
public var bridge11:MovieClip;
public var item1:Item15;
public var item2:Item14;
public var carry1:MovieClip;
public var back:MovieClip;
}
}//package
Section 277
//r33 (r33)
package {
import flash.display.*;
public dynamic class r33 extends MovieClip {
public var carry3:MovieClip;
public var carry20:MovieClip;
public var carry30:MovieClip;
public var carry21:MovieClip;
public var carry31:MovieClip;
public var carry22:MovieClip;
public var carry32:MovieClip;
public var carry23:MovieClip;
public var carry33:MovieClip;
public var carry24:MovieClip;
public var endpoint:MovieClip;
public var carry34:MovieClip;
public var carry25:MovieClip;
public var carry35:MovieClip;
public var road:MovieClip;
public var item1:Item12;
public var item2:Item12;
public var item3:Item12;
public var back:MovieClip;
public var carry2:MovieClip;
}
}//package
Section 278
//r41 (r41)
package {
import flash.display.*;
public dynamic class r41 extends MovieClip {
public var carry10:MovieClip;
public var carry11:MovieClip;
public var carry12:MovieClip;
public var carry13:MovieClip;
public var build:MovieClip;
public var carry14:MovieClip;
public var carry15:MovieClip;
public var tail:MovieClip;
public var run:MovieClip;
public var road:MovieClip;
public var item1:Item11;
public var item2:Item11;
public var carry1:MovieClip;
public var back:MovieClip;
public var newitem:MovieClip;
public var pushitem:MovieClip;
}
}//package
Section 279
//r42 (r42)
package {
import flash.display.*;
public dynamic class r42 extends MovieClip {
public var carry3:MovieClip;
public var carry10:MovieClip;
public var carry20:MovieClip;
public var carry11:MovieClip;
public var carry30:MovieClip;
public var carry21:MovieClip;
public var carry12:MovieClip;
public var carry31:MovieClip;
public var carry22:MovieClip;
public var carry13:MovieClip;
public var carry32:MovieClip;
public var carry23:MovieClip;
public var carry14:MovieClip;
public var carry33:MovieClip;
public var carry24:MovieClip;
public var carry15:MovieClip;
public var carry34:MovieClip;
public var carry25:MovieClip;
public var carry35:MovieClip;
public var tail:MovieClip;
public var road:MovieClip;
public var item1:Item11;
public var item2:MovieClip;
public var carry1:MovieClip;
public var back:MovieClip;
public var carry2:MovieClip;
}
}//package
Section 280
//r43 (r43)
package {
import flash.display.*;
public dynamic class r43 extends MovieClip {
public var bridge18:MovieClip;
public var bridge19:MovieClip;
public var bridge16:MovieClip;
public var endpoint:MovieClip;
public var bridge17:MovieClip;
public var bridge14:MovieClip;
public var bridge15:MovieClip;
public var road:MovieClip;
public var bridge12:MovieClip;
public var bridge13:MovieClip;
public var bridge11:MovieClip;
public var item1:Item13;
public var item3:MovieClip;
public var back:MovieClip;
}
}//package
Section 281
//r51 (r51)
package {
import flash.display.*;
public dynamic class r51 extends MovieClip {
public var carry10:MovieClip;
public var carry11:MovieClip;
public var carry12:MovieClip;
public var bridge18:MovieClip;
public var bridge19:MovieClip;
public var carry13:MovieClip;
public var build:MovieClip;
public var carry14:MovieClip;
public var bridge16:MovieClip;
public var carry15:MovieClip;
public var bridge17:MovieClip;
public var bridge14:MovieClip;
public var tail:MovieClip;
public var run:MovieClip;
public var bridge15:MovieClip;
public var road:MovieClip;
public var bridge12:MovieClip;
public var bridge13:MovieClip;
public var bridge11:MovieClip;
public var item1:Item13;
public var item2:Item13;
public var carry1:MovieClip;
public var back:MovieClip;
public var newitem:MovieClip;
public var pushitem:MovieClip;
}
}//package
Section 282
//r52 (r52)
package {
import flash.display.*;
public dynamic class r52 extends MovieClip {
public var carry10:MovieClip;
public var carry20:MovieClip;
public var carry11:MovieClip;
public var bridge18:MovieClip;
public var carry21:MovieClip;
public var carry12:MovieClip;
public var bridge19:MovieClip;
public var carry22:MovieClip;
public var carry13:MovieClip;
public var carry23:MovieClip;
public var carry14:MovieClip;
public var bridge16:MovieClip;
public var bridge111:MovieClip;
public var carry24:MovieClip;
public var carry15:MovieClip;
public var bridge17:MovieClip;
public var bridge110:MovieClip;
public var carry25:MovieClip;
public var bridge113:MovieClip;
public var bridge14:MovieClip;
public var tail:MovieClip;
public var bridge15:MovieClip;
public var bridge112:MovieClip;
public var road:MovieClip;
public var bridge12:MovieClip;
public var bridge13:MovieClip;
public var bridge11:MovieClip;
public var item1:Item14;
public var item2:Item14;
public var carry1:MovieClip;
public var back:MovieClip;
public var carry2:MovieClip;
}
}//package
Section 283
//r53 (r53)
package {
import flash.display.*;
public dynamic class r53 extends MovieClip {
public var carry10:MovieClip;
public var carry11:MovieClip;
public var carry20:MovieClip;
public var carry12:MovieClip;
public var carry21:MovieClip;
public var carry22:MovieClip;
public var carry13:MovieClip;
public var carry23:MovieClip;
public var carry14:MovieClip;
public var carry24:MovieClip;
public var carry15:MovieClip;
public var carry25:MovieClip;
public var tail:MovieClip;
public var road:MovieClip;
public var item1:Item15;
public var item2:Item15;
public var carry1:MovieClip;
public var back:MovieClip;
public var carry2:MovieClip;
}
}//package
Section 284
//r54 (r54)
package {
import flash.display.*;
public dynamic class r54 extends MovieClip {
public var endpoint:MovieClip;
public var road:MovieClip;
public var item1:Item11;
public var back:MovieClip;
}
}//package
Section 285
//r61 (r61)
package {
import flash.display.*;
public dynamic class r61 extends MovieClip {
public var carry10:MovieClip;
public var carry20:MovieClip;
public var carry11:MovieClip;
public var carry21:MovieClip;
public var carry12:MovieClip;
public var carry22:MovieClip;
public var carry13:MovieClip;
public var build:MovieClip;
public var carry23:MovieClip;
public var carry14:MovieClip;
public var carry24:MovieClip;
public var carry15:MovieClip;
public var carry25:MovieClip;
public var tail:MovieClip;
public var run:MovieClip;
public var road:MovieClip;
public var item1:Item15;
public var item2:Item15;
public var carry1:MovieClip;
public var back:MovieClip;
public var newitem:MovieClip;
public var pushitem:MovieClip;
public var carry2:MovieClip;
}
}//package
Section 286
//r62 (r62)
package {
import flash.display.*;
public dynamic class r62 extends MovieClip {
public var bridge16:MovieClip;
public var bridge14:MovieClip;
public var tail:MovieClip;
public var bridge15:MovieClip;
public var road:MovieClip;
public var bridge12:MovieClip;
public var bridge13:MovieClip;
public var bridge11:MovieClip;
public var item1:Item15;
public var item2:Item15;
public var back:MovieClip;
}
}//package
Section 287
//r63 (r63)
package {
import flash.display.*;
public dynamic class r63 extends MovieClip {
public var carry10:MovieClip;
public var carry20:MovieClip;
public var carry11:MovieClip;
public var carry21:MovieClip;
public var carry12:MovieClip;
public var carry22:MovieClip;
public var carry13:MovieClip;
public var carry23:MovieClip;
public var carry14:MovieClip;
public var carry24:MovieClip;
public var carry15:MovieClip;
public var carry25:MovieClip;
public var tail:MovieClip;
public var road:MovieClip;
public var item1:MovieClip;
public var item2:Item14;
public var carry1:MovieClip;
public var item3:Item12;
public var back:MovieClip;
public var carry2:MovieClip;
}
}//package
Section 288
//r64 (r64)
package {
import flash.display.*;
public dynamic class r64 extends MovieClip {
public var carry10:MovieClip;
public var carry20:MovieClip;
public var carry11:MovieClip;
public var carry21:MovieClip;
public var carry12:MovieClip;
public var carry22:MovieClip;
public var carry13:MovieClip;
public var carry23:MovieClip;
public var carry14:MovieClip;
public var carry24:MovieClip;
public var carry15:MovieClip;
public var endpoint:MovieClip;
public var carry25:MovieClip;
public var road:MovieClip;
public var item1:Item14;
public var item2:Item11;
public var carry1:MovieClip;
public var back:MovieClip;
public var carry2:MovieClip;
}
}//package
Section 289
//r71 (r71)
package {
import flash.display.*;
public dynamic class r71 extends MovieClip {
public var carry10:MovieClip;
public var carry11:MovieClip;
public var carry12:MovieClip;
public var carry13:MovieClip;
public var build:MovieClip;
public var carry14:MovieClip;
public var carry15:MovieClip;
public var tail:MovieClip;
public var run:MovieClip;
public var road:MovieClip;
public var item1:Item14;
public var carry1:MovieClip;
public var back:MovieClip;
public var newitem:MovieClip;
public var pushitem:MovieClip;
}
}//package
Section 290
//r72 (r72)
package {
import flash.display.*;
public dynamic class r72 extends MovieClip {
public var carry10:MovieClip;
public var carry20:MovieClip;
public var carry11:MovieClip;
public var bridge18:MovieClip;
public var carry21:MovieClip;
public var carry12:MovieClip;
public var bridge19:MovieClip;
public var carry22:MovieClip;
public var carry13:MovieClip;
public var carry23:MovieClip;
public var carry14:MovieClip;
public var bridge16:MovieClip;
public var bridge111:MovieClip;
public var carry24:MovieClip;
public var carry15:MovieClip;
public var bridge17:MovieClip;
public var bridge110:MovieClip;
public var carry25:MovieClip;
public var bridge14:MovieClip;
public var tail:MovieClip;
public var bridge112:MovieClip;
public var bridge15:MovieClip;
public var road:MovieClip;
public var bridge12:MovieClip;
public var bridge13:MovieClip;
public var bridge11:MovieClip;
public var item1:Item13;
public var item2:Item13;
public var carry1:MovieClip;
public var back:MovieClip;
public var carry2:MovieClip;
}
}//package
Section 291
//r73 (r73)
package {
import flash.display.*;
public dynamic class r73 extends MovieClip {
public var carry20:MovieClip;
public var carry21:MovieClip;
public var bridge18:MovieClip;
public var carry22:MovieClip;
public var bridge19:MovieClip;
public var carry23:MovieClip;
public var bridge16:MovieClip;
public var bridge111:MovieClip;
public var carry24:MovieClip;
public var bridge17:MovieClip;
public var bridge110:MovieClip;
public var carry25:MovieClip;
public var bridge14:MovieClip;
public var tail:MovieClip;
public var bridge15:MovieClip;
public var road:MovieClip;
public var bridge12:MovieClip;
public var bridge13:MovieClip;
public var bridge11:MovieClip;
public var item1:Item11;
public var item2:Item12;
public var back:MovieClip;
public var carry2:MovieClip;
}
}//package
Section 292
//r74 (r74)
package {
import flash.display.*;
public dynamic class r74 extends MovieClip {
public var carry10:MovieClip;
public var carry11:MovieClip;
public var carry20:MovieClip;
public var carry12:MovieClip;
public var carry21:MovieClip;
public var carry22:MovieClip;
public var carry13:MovieClip;
public var carry14:MovieClip;
public var carry23:MovieClip;
public var carry15:MovieClip;
public var carry24:MovieClip;
public var endpoint:MovieClip;
public var carry25:MovieClip;
public var road:MovieClip;
public var item1:Item14;
public var carry1:MovieClip;
public var back:MovieClip;
public var carry2:MovieClip;
}
}//package
Section 293
//r81 (r81)
package {
import flash.display.*;
public dynamic class r81 extends MovieClip {
public var carry10:MovieClip;
public var carry11:MovieClip;
public var carry12:MovieClip;
public var carry13:MovieClip;
public var build:MovieClip;
public var carry14:MovieClip;
public var carry15:MovieClip;
public var tail:MovieClip;
public var run:MovieClip;
public var road:MovieClip;
public var item1:Item11;
public var item2:Item11;
public var carry1:MovieClip;
public var back:MovieClip;
public var newitem:MovieClip;
public var pushitem:MovieClip;
}
}//package
Section 294
//r82 (r82)
package {
import flash.display.*;
public dynamic class r82 extends MovieClip {
public var carry3:MovieClip;
public var carry10:MovieClip;
public var carry20:MovieClip;
public var carry11:MovieClip;
public var carry30:MovieClip;
public var carry21:MovieClip;
public var carry12:MovieClip;
public var bridge18:MovieClip;
public var carry31:MovieClip;
public var carry22:MovieClip;
public var carry13:MovieClip;
public var carry32:MovieClip;
public var carry23:MovieClip;
public var carry14:MovieClip;
public var bridge16:MovieClip;
public var carry33:MovieClip;
public var carry24:MovieClip;
public var carry15:MovieClip;
public var bridge17:MovieClip;
public var carry34:MovieClip;
public var carry25:MovieClip;
public var bridge14:MovieClip;
public var carry35:MovieClip;
public var tail:MovieClip;
public var bridge15:MovieClip;
public var road:MovieClip;
public var bridge12:MovieClip;
public var bridge13:MovieClip;
public var bridge11:MovieClip;
public var item1:Item13;
public var item2:Item13;
public var carry1:MovieClip;
public var back:MovieClip;
public var carry2:MovieClip;
}
}//package
Section 295
//r83 (r83)
package {
import flash.display.*;
public dynamic class r83 extends MovieClip {
public var carry10:MovieClip;
public var carry11:MovieClip;
public var carry12:MovieClip;
public var bridge18:MovieClip;
public var bridge19:MovieClip;
public var carry13:MovieClip;
public var carry14:MovieClip;
public var bridge16:MovieClip;
public var bridge111:MovieClip;
public var carry15:MovieClip;
public var bridge17:MovieClip;
public var bridge110:MovieClip;
public var bridge14:MovieClip;
public var tail:MovieClip;
public var bridge112:MovieClip;
public var bridge15:MovieClip;
public var road:MovieClip;
public var bridge12:MovieClip;
public var bridge13:MovieClip;
public var bridge11:MovieClip;
public var item1:Item12;
public var item2:Item12;
public var carry1:MovieClip;
public var back:MovieClip;
}
}//package
Section 296
//r84 (r84)
package {
import flash.display.*;
public dynamic class r84 extends MovieClip {
public var carry10:MovieClip;
public var carry11:MovieClip;
public var carry12:MovieClip;
public var carry13:MovieClip;
public var carry14:MovieClip;
public var carry15:MovieClip;
public var endpoint:MovieClip;
public var road:MovieClip;
public var item1:MovieClip;
public var item2:Item15;
public var carry1:MovieClip;
public var back:MovieClip;
}
}//package
Section 297
//r91 (r91)
package {
import flash.display.*;
public dynamic class r91 extends MovieClip {
public var bridge18:MovieClip;
public var bridge19:MovieClip;
public var build:MovieClip;
public var bridge16:MovieClip;
public var bridge110:MovieClip;
public var bridge17:MovieClip;
public var bridge14:MovieClip;
public var tail:MovieClip;
public var run:MovieClip;
public var bridge15:MovieClip;
public var road:MovieClip;
public var bridge12:MovieClip;
public var bridge13:MovieClip;
public var bridge11:MovieClip;
public var back:MovieClip;
public var newitem:MovieClip;
public var pushitem:MovieClip;
}
}//package
Section 298
//r92 (r92)
package {
import flash.display.*;
public dynamic class r92 extends MovieClip {
public var carry10:MovieClip;
public var carry20:MovieClip;
public var carry11:MovieClip;
public var carry21:MovieClip;
public var carry12:MovieClip;
public var carry22:MovieClip;
public var carry13:MovieClip;
public var carry23:MovieClip;
public var carry14:MovieClip;
public var carry24:MovieClip;
public var carry15:MovieClip;
public var carry25:MovieClip;
public var tail:MovieClip;
public var road:MovieClip;
public var item1:Item11;
public var item2:Item14;
public var carry1:MovieClip;
public var item3:Item12;
public var back:MovieClip;
public var carry2:MovieClip;
}
}//package
Section 299
//r93 (r93)
package {
import flash.display.*;
public dynamic class r93 extends MovieClip {
public var carry3:MovieClip;
public var carry10:MovieClip;
public var carry20:MovieClip;
public var carry11:MovieClip;
public var carry21:MovieClip;
public var carry30:MovieClip;
public var carry12:MovieClip;
public var carry22:MovieClip;
public var carry31:MovieClip;
public var carry13:MovieClip;
public var carry32:MovieClip;
public var carry23:MovieClip;
public var carry14:MovieClip;
public var carry24:MovieClip;
public var carry33:MovieClip;
public var carry15:MovieClip;
public var carry25:MovieClip;
public var carry34:MovieClip;
public var carry35:MovieClip;
public var tail:MovieClip;
public var road:MovieClip;
public var item1:Item13;
public var item2:Item15;
public var carry1:MovieClip;
public var back:MovieClip;
public var carry2:MovieClip;
}
}//package
Section 300
//r94 (r94)
package {
import flash.display.*;
public dynamic class r94 extends MovieClip {
public var carry20:MovieClip;
public var bridge18:MovieClip;
public var carry21:MovieClip;
public var bridge19:MovieClip;
public var carry22:MovieClip;
public var carry23:MovieClip;
public var bridge16:MovieClip;
public var carry24:MovieClip;
public var endpoint:MovieClip;
public var bridge110:MovieClip;
public var bridge17:MovieClip;
public var carry25:MovieClip;
public var bridge14:MovieClip;
public var bridge15:MovieClip;
public var road:MovieClip;
public var bridge12:MovieClip;
public var bridge13:MovieClip;
public var bridge11:MovieClip;
public var item1:Item15;
public var item2:Item12;
public var back:MovieClip;
public var carry2:MovieClip;
}
}//package
Section 301
//Reel (Reel)
package {
import flash.display.*;
public dynamic class Reel extends MovieClip {
public var J:MovieClip;
public function Reel(){
addFrameScript(105, frame106);
}
function frame106(){
stop();
}
}
}//package
Section 302
//Selstage (Selstage)
package {
import flash.display.*;
public dynamic class Selstage extends MovieClip {
public var stage7:MovieClip;
public var stage8:MovieClip;
public var stage9:MovieClip;
public var quit_btn:SimpleButton;
public var moregame_btn:SimpleButton;
public var stage10:MovieClip;
public var mm1:SimpleButton;
public var shop_btn:SimpleButton;
public var stage1:MovieClip;
public var stage2:MovieClip;
public var stage3:MovieClip;
public var stage4:MovieClip;
public var stage5:MovieClip;
public var T1:MovieClip;
public var T:MovieClip;
public var stage6:MovieClip;
}
}//package
Section 303
//Shop (Shop)
package {
import flash.display.*;
public dynamic class Shop extends MovieClip {
public var e0:MovieClip;
public var d1:MovieClip;
public var e1:MovieClip;
public var d2:MovieClip;
public var e2:MovieClip;
public var a0:MovieClip;
public var moregame_btn:SimpleButton;
public var b0:MovieClip;
public var a1:MovieClip;
public var c0:MovieClip;
public var b1:MovieClip;
public var a2:MovieClip;
public var c1:MovieClip;
public var b2:MovieClip;
public var c2:MovieClip;
public var m0:MovieClip;
public var m1:MovieClip;
public var m2:MovieClip;
public var car:MovieClip;
public var m3:MovieClip;
public var m4:MovieClip;
public var back_btn:SimpleButton;
public var word:MovieClip;
public var m5:MovieClip;
public var d0:MovieClip;
}
}//package
Section 304
//ST (ST)
package {
import flash.display.*;
public dynamic class ST extends MovieClip {
public function ST(){
addFrameScript(21, frame22);
}
function frame22(){
stop();
}
}
}//package
Section 305
//Win (Win)
package {
import flash.display.*;
public dynamic class Win extends MovieClip {
public var t0:MovieClip;
public var e0:MovieClip;
public var t1:MovieClip;
public var t2:MovieClip;
public var t3:MovieClip;
public var a0:MovieClip;
public var moregame_btn:SimpleButton;
public var b0:MovieClip;
public var c0:MovieClip;
public var mm1:SimpleButton;
public var retry_btn:SimpleButton;
public var m0:MovieClip;
public var m1:MovieClip;
public var m2:MovieClip;
public var m3:MovieClip;
public var m4:MovieClip;
public var next_btn:SimpleButton;
public var d0:MovieClip;
}
}//package
Section 306
//win_sd (win_sd)
package {
import flash.media.*;
public dynamic class win_sd extends Sound {
}
}//package
Section 307
//YTY (YTY)
package {
import flash.display.*;
public dynamic class YTY extends MovieClip {
public function YTY(){
addFrameScript(41, frame42);
}
function frame42(){
stop();
}
}
}//package
Section 308
//yuan (yuan)
package {
import flash.display.*;
public dynamic class yuan extends MovieClip {
}
}//package