.HALL LDA #$00 ; Clear the screen and set the view type in QQ11 to $00 JSR TT66_b0 ; (Space view with no fonts loaded) LDA nmiCounter ; Set the random number seeds to a fairly random state STA RAND+1 ; that's based on the NMI counter (which increments LDA #$86 ; every VBlank, so will be pretty random), the current STA RAND+3 ; system's galactic x-coordinate (QQ0), the high byte LDA QQ0 ; of our combat rank (TALLY+1), and a fixed number $86 STA RAND LDA TALLY+1 STA RAND+2 JSR DORND ; Set A and X to random numbers BPL HA7 ; Jump to HA7 if A is positive (50% chance) AND #3 ; Reduce A to a random number in the range 0-3 STA T ; Set X = A * 8 + A ASL A ; = 9 * A ASL A ; ASL A ; so X is a random number, either 0, 9, 18 or 27 ADC T TAX ; The following double loop calls the HAS1 routine three ; times to display three ships on screen. For each call, ; the values passed to HAS1 in XX15+2 to XX15 are taken ; from the HATB table, depending on the value in X, as ; follows: ; ; * If X = 0, pass bytes #0 to #2 of HATB to HAS1 ; then bytes #3 to #5 ; then bytes #6 to #8 ; ; * If X = 9, pass bytes #9 to #11 of HATB to HAS1 ; then bytes #12 to #14 ; then bytes #15 to #17 ; ; * If X = 18, pass bytes #18 to #20 of HATB to HAS1 ; then bytes #21 to #23 ; then bytes #24 to #26 ; ; * If X = 27, pass bytes #27 to #29 of HATB to HAS1 ; then bytes #30 to #32 ; then bytes #33 to #35 ; ; Note that the values are passed in reverse, so for the ; first call, for example, where we pass bytes #0 to #2 ; of HATB to HAS1, we call HAS1 with: ; ; XX15 = HATB+2 ; XX15+1 = HATB+1 ; XX15+2 = HATB LDY #3 ; Set CNT2 = 3 to act as an outer loop counter going STY CNT2 ; from 3 to 1, so the HAL8 loop is run 3 times .HAL8 LDY #2 ; Set Y = 2 to act as an inner loop counter going from ; 2 to 0 .HAL9 LDA HATB,X ; Copy the X-th byte of HATB to the Y-th byte of XX15, STA XX15,Y ; as described above INX ; Increment X to point to the next byte in HATB DEY ; Decrement Y to point to the previous byte in XX15 BPL HAL9 ; Loop back to copy the next byte until we have copied ; three of them (i.e. Y was 3 before the DEY) TXA ; Store X on the stack so we can retrieve it after the PHA ; call to HAS1 (as it contains the index of the next ; byte in HATB JSR HAS1 ; Call HAS1 to draw this ship in the hangar PLA ; Restore the value of X, so X points to the next byte TAX ; in HATB after the three bytes we copied into XX15 DEC CNT2 ; Decrement the outer loop counter in CNT2 BNE HAL8 ; Loop back to HAL8 to do it 3 times, once for each ship ; in the HATB table LDY #128 ; Set Y = 128 to send as byte #2 of the parameter block ; to the OSWORD 248 command below, to tell the I/O ; processor that there are multiple ships in the hangar BNE HA9 ; Jump to HA9 to display the ship hangar (this BNE is ; effectively a JMP as Y is never zero) .HA7 ; If we get here, A is a positive random number in the ; range 0-127 LSR A ; Set XX15+1 = A / 2 (random number 0-63) STA XX15+1 JSR DORND ; Set XX15 = random number 0-255 STA XX15 JSR DORND ; Set XX15+2 = #SH3 + random number 0-3 AND #3 ; ADC #SH3 ; which is the ship type of a Sidewinder, Mamba, Krait STA XX15+2 ; or Adder JSR HAS1 ; Call HAS1 to draw this ship in the hangar, with the ; following properties: ; ; * Random x-coordinate from -63 to +63 ; ; * Randomly chosen Sidewinder, Mamba, Krait or Adder ; ; * Random z-coordinate from +256 to +639 LDY #0 ; Set Y = 0 to use in the following instruction, to tell ; the hangar-drawing routine that there is just one ship ; in the hangar, so it knows not to draw between the ; ships .HA9 STY HANGFLAG ; Store Y in HANGFLAG to specify whether there are ; multiple ships in the hangar JSR HANGER ; Call HANGER to draw the hangar background LDA #0 ; Tell the NMI handler to send pattern entries from STA firstPattern ; pattern 0 in the buffer LDA #80 ; Tell the NMI handler to only clear nametable entries STA maxNameTileToClear ; up to tile 80 * 8 = 640 (i.e. up to the end of tile ; row 19) JMP UpdateHangarView ; Update the hangar view on-screen by sending the data ; to the PPU, returning from the subroutine using a tail ; callName: HALL [Show more] Type: Subroutine Category: Ship hangar Summary: Draw the ships in the ship hangar, then draw the hangarContext: See this subroutine in context in the source code References: This subroutine is called as follows: * HALL_b1 calls HALL
Half the time this will draw one of the four pre-defined ship hangar groups in HATB, and half the time this will draw a solitary Sidewinder, Mamba, Krait or Adder on a random position. In all cases, the ships will be randomly spun around on the ground so they can face in any direction, and larger ships are drawn higher up off the ground than smaller ships.
[X]
Subroutine DORND (category: Maths (Arithmetic))
Generate random numbers
[X]
Label HA7 is local to this routine
[X]
Label HA9 is local to this routine
[X]
Label HAL8 is local to this routine
[X]
Label HAL9 is local to this routine
[X]
Subroutine HANGER (category: Ship hangar)
Display the ship hangar
[X]
Subroutine HAS1 (category: Ship hangar)
Draw a ship in the ship hangar
[X]
Variable HATB (category: Ship hangar)
Ship hangar group table
[X]
Configuration variable SH3 = 17
Ship type for a Sidewinder
[X]
Subroutine TT66_b0 (category: Drawing the screen)
Call the TT66 routine in ROM bank 0
[X]
Subroutine UpdateHangarView (category: PPU)
Update the hangar view on-screen by sending the data to the PPU, either immediately or during VBlank
[X]
Variable firstPattern in workspace ZP
The number of the first pattern for which we send data to the PPU in the NMI handler (potentially for both bitplanes, if both are configured to be sent)
[X]
Variable maxNameTileToClear in workspace ZP
The tile number at which the NMI handler should stop clearing tiles in the nametable buffers during its clearing cycle
[X]
Variable nmiCounter in workspace WP
A counter that increments every VBlank at the start of the NMI handler