Mercurial > hg > Members > kono > nitros9-code
view 3rdparty/utils/view/view_wait.a @ 2488:00e35931156e
Updated
author | boisy |
---|---|
date | Wed, 31 Mar 2010 02:58:46 +0000 |
parents | b7fb6a9aead4 |
children |
line wrap: on
line source
* * View_wait.a -- End-of-picture pause... handles color cycling, screen * flipping, and timeout. * * Global labels: * keywait: Subroutine to handle end-of-picture pause. * SetSig: Sets trivial signal trap which stores signal in SigCode * check macro pshs b,cc ldb #\1 os9 F$PErr puls b,cc endm ifp1 use os9defs.a endc StdOut equ 1 StdErr equ 2 psect View_wait_a,0,0,0,0,0 ******************************************************* * * Keywait- wait for keypress or mouse click * Also, handle palette cycling. * ******************************************************* vsect dp cycleleft rmb 2 extraleft rmb 2 endsect keywait: pshs a,b,x,y,u clr <abort ldd <cyclerate Initialize cycle and extra count-down timers. std <cycleleft ldd <extrarate std <extraleft kwloop lbsr conscheck Check for consistency, to make sure we don't waste time. clr <SigCode Set up our signals. lbsr setmouse lbsr setkeysig kwchkey lbsr getkey Is there a key waiting? bcs kwnokey clr <SigCode lbsr kwdokey If so, handle it bra kwchkey . and then check again. kwnokey tst <flipping If flipping is on, do that. beq kwnoflip lbsr kwflip bra kwsig kwnoflip tst <cycle If animation is on, do that. beq kwnocycle lbsr kwanimate bra kwsig kwnocycle ldx <MaxTime If none of the above, just sleep for MaxTime cmpx #0 beq kwsig tst <SigCode bne nosleep1 os9 F$Sleep nosleep1 stx <MaxTime * * Handle a signal. kwsig ldd <MaxTime If we timed out, end now. beq kwend lda <SigCode cmpa #KButton Was it a keypress that woke us up? bne kwnokey1 clr <SigCode If so, clear sigcode, lbsr getkey . get the key bsr kwdokey . process it bcc kwloop . and keep going. bra kwend kwnokey1 cmpa #MButton Was it a mouse click? bne kwnomouse None of the above, we just exit. bsr kwdomouse lbcc kwloop bra kwend kwnomouse kwend puls a,b,x,y,u,pc * * Process a mouse click. * kwdomouse clr <SigCode orcc #Carry Set carry, since any mouse click should end. rts * * process a key press. * Expects: key in A. kwdokey pshs a,b,x cmpa #'Z Convert key to lower case bhi kwlower cmpa #'A blo kwlower suba #'A-'a kwlower cmpa #$20 Was it a space? bne kwkey1 com <cycle Yes, turn cycling on/off lbne kwdonekey lbsr setpals Restore original palettes, if we just turned cycling off. lbra kwdonekey kwkey1 cmpa #', Was it a "<"? beq kwkey21 cmpa #'< beq kwkey21 cmpa #'s Was it an "S" (slower) bne kwkey2 kwkey21 ldx <cyclerate leax 1,x Increase the cycle delay beq kwkey22 stx <cyclerate kwkey22 tst <flipping beq kwkey23 If not flipping, don't do this... ldd <fliprate addd #1 cmpd #6000 bhs kwkey23 std <fliprate kwkey23 lbra kwdonekey kwkey2 cmpa #'. beq kwkey31 cmpa #'> beq kwkey31 cmpa #'f "F" (faster) bne kwkey3 kwkey31 ldx <cyclerate leax -1,x Decrease the cycle delay beq kwkey32 stx <cyclerate Don't make it zero! kwkey32 tst <flipping beq kwkey33 If not flipping, don't do this... ldd <fliprate subd #1 cmpd #2 bls kwkey33 std <fliprate kwkey33 lbra kwdonekey kwkey3 cmpa #$B2 F2 key beq kwkey41 cmpa #$0a Down-arrow bne kwkey4 kwkey41 lbsr flipscreen lbra kwdonekey kwkey4 cmpa #$0c Up-arrow bne kwkey5 lbsr flipback lbra kwdonekey kwkey5 cmpa #$B1 bne kwkey6 lda <flipping beq kwkey61 lda #$ff kwkey61 coma sta <flipping lbra kwdonekey kwkey6 lbsr docycle Any other key? Single step. lbsr dorotate lbra kwdonekey kwdonekey andcc #^Carry Clear carry flag, since no key forces an exit. puls a,b,x,pc * * Check cycle, extra, and flipping variables for consistency, * since naive routines may end up with inconsistent or inefficient * combinations of settings (for example, we might end up with * flipping enabled, but only one screen allocated). * conscheck pshs a,b * Check "cycle" values for consistency. lda <cyclestart Do a consistency check on the cycle values. cmpa <cycleend blo cons0 ldd #$ffff if cyclestart >= cycleend, then std <cyclerate set cyclerate to $ffff. bra cons1 cons0 ldd <cyclerate otherwise, make sure cyclerate is not 0 bne cons1 ldd #10 Just a random value. std <cyclerate cons1 * Check "extra" palette values for consistency. lda <extranum Do a consistency check on extra palette values. bne cons2 ldd #$ffff if extranum is zero, std <extrarate set extrarate to $ffff. bra cons3 cons2 ldd <extrarate otherwise, make sure extrarate is not 0 bne cons3 ldd #10 Just a random value. std <extrarate cons3 * Check flipping vars for consistency lda <numscreens Do a consistency check on flipping var. cmpa #2 bhs cons4 clr <flipping If <2 screens, then ensure flipping is off. cons4 * Check "cycle" variable for consistency. lda <cyclestart A consistency check: If all animation effects cmpa <cycleend are disabled, then turn off "cycle" blo cons5 lda <extranum bne cons5 clr <cycle And turn off cycle flag. cons5 puls a,b,pc * * Do screen flipping * Return when MaxTime goes to zero, or when a signal is received. * kwflip pshs a,b,x kwfliploop ldd <MaxTime Count down one extra tick each time through lbeq kwflipend lbsr flipscreen Do one flip ldd <fliprate interval between flips cmpd <MaxTime lbls kwflip0 If MaxTime is shorter than this, use MaxTime instead. ldd <MaxTime kwflip0 tfr d,x pshs x tst <SigCode bne nosleep2 os9 F$Sleep nosleep2 pshs x ldd <MaxTime Count down MaxTime addd ,s++ subd ,s++ std <MaxTime tst <SigCode Did we end due to a signal? beq kwfliploop No, keep flipping. kwflipend puls a,b,x,pc * * Do animation * Return when MaxTime goes to zero, or a signal is received. * kwanimate pshs a,b,x kwanimloop ldd <MaxTime lbeq kwanimend If MaxTime is zero, quit now. ldd <cycleleft Have we timed out for cycle? bne kwanim0 lbsr docycle Roll the palettes. ldd <cyclerate Restore the countdown. std <cycleleft kwanim0 ldd <extraleft Have we timed out for extra? bne kwanim1 lbsr dorotate Rotate extra palettes. ldd <extrarate Restore the countdown. std <extraleft kwanim1 ldd <cycleleft Sleep for the appropriate delay cmpd <extraleft blo kwanim20 The appropriate delay is the least of ldd <extraleft cycleleft, extraleft, and MaxTime. kwanim20 cmpd <MaxTime blo kwanim2 ldd <MaxTime kwanim2 tfr d,x Save original delay in D. tst <SigCode bne nosleep3 os9 F$Sleep This returns the amount of time that we didn't sleep. nosleep3 pshs x subd ,s subtract time left std ,s This gives total time slept ldd <MaxTime Count down maximum time left subd ,s std <MaxTime ldd <cycleleft Count down cycle time left subd ,s std <cycleleft ldd <extraleft count down extra time left subd ,s++ Clean up the stack while we're at it. std <extraleft tst <SigCode Were we woken up by a signal? beq kwanimloop No, keep going. kwanimend puls a,b,x,pc * * Trivial signal handler... store signal value and exit * SigInter stb SigCode,u Store the signal code. tfr u,y Set up y as it should be. tfr u,d tfr a,dp Set up DP too. tst <abort Should we abort now? lbne _abort rti SetSig: pshs x,y,u leax SigInter,pcr Set the signal intercept leau ,y os9 F$Icpt lbcs _error puls x,y,u,pc endsect