;================================ ; move_and_print ;================================ ; get X,Y from OUTL/OUTH ; then print following string to that address ; stop at NUL ; convert to APPLE ASCII (or with 0x80) ; leave OUTL/OUTH pointing to next string move_and_print: ldy #0 lda (OUTL),Y sta CH iny lda (OUTL),Y asl tay lda gr_offsets,Y ; lookup low-res memory address clc adc CH ; add in xpos sta BASL ; store out low byte of addy lda gr_offsets+1,Y ; look up high byte adc DRAW_PAGE ; sta BASH ; and store it out ; BASH:BASL now points at right place clc lda OUTL adc #2 sta OUTL lda OUTH adc #0 sta OUTH ;================================ ; print_string ;================================ print_string: ldy #0 print_string_loop: lda (OUTL),Y beq done_print_string ; adjust for upper/lowercase cmp #$60 bcc not_lowercase ps_smc2: and #$ff not_lowercase: ; adjust for inverse/flash/normal ps_smc1: and #$3f ; make sure we are inverse sta (BASL),Y iny bne print_string_loop done_print_string: iny clc tya adc OUTL sta OUTL lda OUTH adc #0 sta OUTH rts ; want $E1 -> $81 ; 1110 1000 ; so and with $9f? force_uppercase: lda #$9f sta ps_smc2+1 rts ; set normal text set_normal: lda #$80 sta ps_smc1+1 lda #09 ; ora sta ps_smc1 rts ; restore inverse text set_inverse: lda #$3f ; sta ps_smc1+1 lda #$29 ; and sta ps_smc1 rts ;================================ ; move and print a list of lines ;================================ ; look for negative X meaning done move_and_print_list: jsr move_and_print ldy #0 lda (OUTL),Y bpl move_and_print_list rts ;============================== ; clear bottom of text screen ;============================== clear_bottom: ldx #20 clear_bottom_loop_outer: txa asl tay lda gr_offsets,Y sta OUTL iny lda gr_offsets,Y sta OUTH lda #' '+$80 ldy #39 clear_bottom_loop_inner: sta (OUTL),Y dey bpl clear_bottom_loop_inner inx cpx #24 bne clear_bottom_loop_outer rts