Drag’n drop
Setup
2 movieclips, drag_mc og target_mc, placeret på scenen et stykke fra hinanden.
Grundkode:
drag_mc.addEventListener(MouseEvent.MOUSE_DOWN, dragHANDLER); function dragHANDLER(e:MouseEvent):void { drag_mc.startDrag(); } drag_mc.addEventListener(MouseEvent.MOUSE_UP, dropHANDLER); function dropHANDLER(e:MouseEvent):void { drag_mc.stopDrag(); }
Med HitTestPoint():
var sourceX:int=drag_mc.x; var sourceY:int=drag_mc.y; drag_mc.buttonMode=true; drag_mc.addEventListener(MouseEvent.MOUSE_DOWN, dragHANDLER); function dragHANDLER(e:MouseEvent):void { drag_mc.startDrag(); ////////////////////////////////// e.target.parent.addChild(e.target);//lægger øverst /////////////////////////////////// } drag_mc.addEventListener(MouseEvent.MOUSE_UP,dropHANDLER); function dropHANDLER(e:MouseEvent):void { drag_mc.stopDrag(); if (drag_mc.hitTestPoint(target_mc.x, target_mc.y, true)) { drag_mc.x=target_mc.x; drag_mc.y=target_mc.y; } else { drag_mc.x=sourceX; drag_mc.y=sourceY; } }
Created: 7 April 2008 • by admin
Categories: as3 •snippet
Comments: 1 comment, add one
Keyboard – kort men hakkende
stage.addEventListener(KeyboardEvent.KEY_DOWN, keyPressed); function keyPressed(e:KeyboardEvent) { if (e.keyCode == Keyboard.RIGHT) { mc.x +=5; } if (e.keyCode == Keyboard.LEFT) { mc.x -=5; } if (e.keyCode == Keyboard.UP) { mc.y -=5; } if (e.keyCode == Keyboard.DOWN) { mc.y +=5; } }
Se også: Keyboard – lang men flydende
Created: 7 April 2008 • by admin
Categories: events •snippet
Comments: be the first to comment
Keyboard – lang men flydende
Alle de keys man har brug for i form af booleans
var rightArrow:Boolean=false; var leftArrow:Boolean=false; var upArrow:Boolean=false; var downArrow:Boolean=false;
KEY_DOWN listeneren sætter dem til true
stage.addEventListener(KeyboardEvent.KEY_DOWN, keyPressed); function keyPressed(e:KeyboardEvent) { if (e.keyCode == Keyboard.RIGHT) { rightArrow = true; } if (e.keyCode == Keyboard.LEFT) { leftArrow = true; } if (e.keyCode == Keyboard.UP) { upArrow = true; } if (e.keyCode == Keyboard.DOWN) { downArrow = true; } }
KEY_UP listeneren sætter dem til false
stage.addEventListener(KeyboardEvent.KEY_UP, keyReleased); function keyReleased(e:KeyboardEvent) { if (e.keyCode == Keyboard.RIGHT) { rightArrow = false; } if (e.keyCode == Keyboard.LEFT) { leftArrow = false; } if (e.keyCode == Keyboard.UP) { upArrow = false; } if (e.keyCode == Keyboard.DOWN) { downArrow = false; } }
ENTER_FRAME listeneren reagerer på dem prompte
stage.addEventListener(Event.ENTER_FRAME, MOVE); function MOVE(e:Event) { if (rightArrow) { mc.x += 5; mc.play(); } if (leftArrow) { mc.x -= 5; mc.play(); } if (upArrow) { mc.y -= 5; mc.play(); } if (downArrow) { mc.y += 5; mc.play(); } if (!rightArrow && !leftArrow && !upArrow && !downArrow) { mc.stop(); } }
Se også: Keyboard – kort men hakkende
Created: 7 April 2008 • by admin
Categories: events •snippet
Comments: be the first to comment
Drop_and_Catch 1
2 movieClips oprettes, frugt_mc og kurv_mc.
Ind på scenen med dem på et lag kaldet graphics.
På actionScript lages indledes på sædvanlig vis med variabler og startværdier:
stop(); Mouse.hide(); var winScore:Number = 3; var score:Number = 0; var speed:Number = 10; var stageH:Number = stage.stageHeight; var stageW:Number = stage.stageWidth; score_txt.text = "Get: " + winScore + " fruits";
score_txt er et tekstfeldt du tegner med tekstværktøjet på et tekst-lag. I property-panelet kan du indstille det til at være dynamisk, give det dets nævnte instancenavn, og formatere det på noget prøvetekst, som du så sletter igen bagefter. Teksten blir alligevel straks erstattet af værdien ovenfor.
Så til den konstante bevægelse:
addEventListener(Event.ENTER_FRAME, MOVE); function MOVE(e:Event):void { kurv_mc.x = mouseX; frugt_mc.y += speed; if (frugt_mc.y > stageH) { frugt_mc.y = 0; frugt_mc.x = Math.random()*stageW; speed++; } }
Følgende foregår konstant, på den valgte frame-rate:
kurv_mc følger musens x-værdi.
frugt_mc bevæger sig nedaf positivt på y-aksen, og hvis den rammer bunden, lægges den straks op igen på en tilfældig x-værdi, og farten øges en smule til næste himmelfald.
Bemærk Math.random(), som udgør en random værdi mellem 0 og 1 , og derfor skal ganges med max-værdien stageW, for at udgøre en random værdi mellem 0 og hele scenebredden.
Hvis man fanger den med kurv_mc (skrives indenfor MOVE, før dens afsluttende '}'):
if (kurv_mc.hitTestObject ( frugt_mc)) { score++; score_txt.text = "your score is: " + score + " fruits"; frugt_mc.y = 0; frugt_mc.x = Math.random () * stageW; speed++; if (score >= winScore) { RESUME("win"); } }
Hvis man rammer, er der pointstigning, og det vises i tekstboksen. Så blir frugt_mc’s y-værdi nulstillet påny et tilfældigt sted på indenfor bredden og farten øges til kommende tur ned.
Og derefter blir der vurderet om man er nået til vinder-stadiet og functionen RESUME(med vedhæftet parameter “win”) blir kaldt.
Se bort fra denne forklaring lige efter du har læst og forstået den, se på koden og lev dig ind i den – og skriv så en /*kommentar*/ med helt egne ord og din egen forklaring udfra helt egen forståelse.
Nedenunder MOVE defineres RESUME (som ber om et vedhæftet parameter, som den jo også får, og som den skal bruge til videre behandling):
function RESUME(where:String):void { Mouse.show(); removeEventListener(Event.ENTER_FRAME, MOVE); gotoAndStop(where); }
Et parameter er en variabel, der videresendes fra funktion til funktion, fordi dens værdi kendes i den ene, og bruges i den anden. RESUME definerer en variabel i sin parenthes, og MOVE gir den en værdi i sin parenthes. Der kan være mange parametre i en enkelt function og de adskilles med komma.
Forslag til udbygning:
//random speed
//mere frugt fra himlen, individuel point-værdi, individuel speed
//POSITION, EVALUATE functions
//sidelæns spil
//undgå i stedet for at fange
//splash, og lose + grafik
//animationer på mc’erne
//lyd
se evt. Drop_and_Catch 2
Created: 6 April 2008 • by admin
Categories: as3 •oevelse
Comments: be the first to comment
mcStatus mekanik
mc er movieclippet med den sektionerede timeline og relevante labels. Dens labels har her samme navne som de mcStatus værdier den skal reagere på! De behøver ikke at være de samme, men det er smart.
mcStatus er en variabel, der får værdi af tilstande, som indgår i en logisk rækkefølge. Hvert trin betinger det næste (erstat navne med dem du arbejder med).
Start med at få overblik over de forskellige mcStatus værdier
/*mcStatus værdier: sleep, awake, dressup */
Og definer så en startværdi for mcStatus
var mcStatus:String = "sleep";
Kombinationer
Andre objekter ændrer mcStatus:
alarm_mc.buttonMode = true;
alarm_mc.addEventListener(MouseEvent.CLICK, alarm_HANDLER);
function alarm_HANDLER (e:MouseEvent):void {
if (mcStatus == "sleep") {
mcStatus = "awake";
}
}
dress_mc.buttonMode = true;
dress_mc.addEventListener(MouseEvent.CLICK, dress_HANDLER);
function dress_HANDLER (e:MouseEvent):void {
if (mcStatus == "awake") {
mcStatus = "dressup";
}
}
mc aktiveres ved direkte klik (hvis den ikke har været der):
mc.buttonMode = true;
mc.addEventListener(MouseEvent.CLICK, mc_HANDLER);
function mc_HANDLER (e:MouseEvent):void {
if (mc.currentLabel!= mcStatus){
mc.gotoAndPlay(mcStatus);
}
Andre objekter ændrer mcStatus og aktiverer mc:
dress_mc.buttonMode = true;
dress_mc.addEventListener(MouseEvent.CLICK, dress_HANDLER);
function dress_HANDLER (e:MouseEvent):void {
if (mcStatus == "awake") {
mcStatus = "dressup";
mc.gotoAndPlay (mcStatus);
}
}
Created: 6 April 2008 • by admin
Categories: as3 •eksempel •snippet
Comments: be the first to comment
Points – score
Hermed beskrivelsen og en anvendelsesprocedure for implementering i eksisterende scripts.
Princippet i trin
- at definere variabler til points, maximum-værdi, minimum-værdi og start-værdi
- at ændre værdierne på passende tidspunkt
- at vise værdierne for bruger
- at chekke om værdierne har nået den afgørende værdi
- at udføre konsekvenserne deraf
Det er meget muligt, at du har brug for kun at tælle opad – eller nedad, men her går eksempel i begge retninger, som du kan tilpasse. Eksemplet kan udbygges til også at tælle liv.
Foreslået fremgangs-rækkefølge
Nogle ‘sigende’ variabler
(hører til i øverste del af et script, for nemt at kunne ‘skrues’ på) :
var winScore:Number = 10; var loseScore:Number = -10; var points:Number=0;
Et dynamisk tekstfelt til display
(På et score-lag i spil.scenariet med instancenavnet ‘score_txt’).
Det kan tegnes med tekstværktøjet og indstilles til dynamisk i property panelet, hvor det også formateres med lidt prøve-tekst i. Det skal være tomt for tekst når du er færdig, for teksten blir scriptet frem.
Tekst-feltet kan evt. starte ud med en forklaring:
score_txt.text = "Get "+ winScore.toString() + " points!";
Ændring af værdier
Så stilles spørgsmålet:
Hvornår eller under hvilke omstændigheder skal points- værdien stige?
Det kunne fx. være hvis noget rammer noget andet, eller hvis en status-variabel er opfyldt, eller en boolean er blevet sat til true.
I den øskede situation, som regel inden for en if-condition, øges points med den ønskede værdi:
points += 1; // eller points=points+1; // eller points+1;
Hvornår eller under hvilke omstændigheder skal points- værdien falde?
Samme overvejelser for mistede points, og hvormange af gangen:
points - -; // eller med kompleksitet fx. points/(en brøkdel af den tid der er gået);
Nye spørgsmål:
Hvornår skal points’ene vises?
Tekstfeltet påkaldes, som vist nedenfor, fx. hver gang points’ene ændres.
Hvornår har man vundet eller tabt?
Eller som i dette eksempel: Hvilke top- eller bund- værdier skal points’ene sammenlignes med?
Hvad skal der ske hvis sammenligningen passer?
Eksempel
I simpel rækkefølge
points += 2; score_txt.text = "Your points = "+ points.toString() ; if (points == winScore) { // her slukkes for evt. igangsatte ENTER_FRAME listeners gotoAndStop("win"); }
- Og tilsvarende for minus-points.
I en udregnende function
////////////// points += 2; EVALUATE(); ////////////// points --; EVALUATE(); ////////////// function EVALUATE():void { score_txt.text = "Your points = "+ points.toString() ; if (points == winScore) { // her slukkes for evt. igangsatte ENTER_FRAME listeners, // points variabler nulstilles, // mouse.show(), hvis den har stået på hide(), osv. gotoAndStop("win"); } if (points == loseScore) { // også her slukkes for kørende ENTER_FRAME listeners // points variabler nulstilles, // mouse.show(), hvis den har stået på hide(), osv. gotoAndStop("lose"); } }
Created: 6 April 2008 • by admin
Categories: as3 •overblik •snippet
Comments: be the first to comment
