dos33fsprogs/graphics/hgr/circles/tunnel.s
2023-10-29 18:01:18 -04:00

267 lines
3.6 KiB
ArmAsm

; tunnel
; D0+ used by HGR routines
HGR_COLOR = $E4
HGR_PAGE = $E6
RR = $F5
COUNT = $F6
XX = $F7
MINUSXX = $F8
YY = $F9
MINUSYY = $FA
D = $FB
R = $FC
CX = $FD
CY = $FE
FRAME = $FF
; soft-switches
KEYPRESS = $C000
KEYRESET = $C010
; ROM routines
HGR2 = $F3D8 ; set hires page2 and clear $4000-$5fff
HGR = $F3E2 ; set hires page1 and clear $2000-$3fff
HPLOT0 = $F457 ; plot at (Y,X), (A)
HCOLOR1 = $F6F0 ; set HGR_COLOR to value in X
COLORTBL = $F6F6
PLOT = $F800 ; PLOT AT Y,A (A colors output, Y preserved)
NEXTCOL = $F85F ; COLOR=COLOR+3
SETCOL = $F864 ; COLOR=A
SETGR = $FB40 ; set graphics and clear LO-RES screen
BELL2 = $FBE4
WAIT = $FCA8 ; delay 1/2(26+27A+5A^2) us
tunnel:
; from R=12 to R=256 or so
jsr HGR2
tunnel_again:
lda #0
sta RR
draw_next:
ldx RR
lda star_z,X
tax
lda radii,X
sta R
; lda KEYPRESS
; bpl draw_next
; bit KEYRESET
lda #128
sta CX
lda #96
sta CY
;===============================
; draw circle
;===============================
; draw circle at (CX,CY) of radius R
; signed 8-bit math so problems if R > 64?
; XX=0 YY=R
; D=3-2*R
; GOTO6
lda #0
sta XX
lda R
sta YY
lda #3
sec
sbc R
sbc R
sta D
jmp do_plots
circle_loop:
; X=X+1
inc XX
; IF D>0 THEN Y=Y-1:D=D+4*(X-Y)+10
lda D
bmi else
dec YY
lda XX
sec
sbc YY
asl
asl
clc
adc D
adc #10
jmp store_D
else:
; ELSE D=D+4*X+6
lda XX
asl
asl
clc
adc D
adc #6
store_D:
sta D
do_plots:
lda XX
and #$3
bne done2
; setup constants
lda XX
eor #$FF
sta MINUSXX
inc MINUSXX
lda YY
eor #$FF
sta MINUSYY
inc MINUSYY
; HPLOT CX+X,CY+Y
; HPLOT CX-X,CY+Y
; HPLOT CX+X,CY-Y
; HPLOT CX-X,CY-Y
; HPLOT CX+Y,CY+X
; HPLOT CX-Y,CY+X
; HPLOT CX+Y,CY-X
; HPLOT CX-Y,CY-X
; calc X co-ord
lda #7
sta COUNT
pos_loop:
lda COUNT
and #$4
lsr
tay
lda COUNT
lsr
bcc xnoc
iny
xnoc:
lda CX
clc
adc XX,Y
tax
; calc y co-ord
lda COUNT
lsr
eor #$2
tay
lda CY
clc
adc XX,Y
ldy #0
jsr HPLOT0 ; plot at (Y,X), (A)
dec COUNT
bpl pos_loop
done2:
; IFY>=XTHEN4
lda YY
cmp XX
bcs circle_loop
done:
lda RR
clc
adc #1
sta RR
cmp #19
beq done_frame
; GOTO1
jmp draw_next
done_frame:
jsr HGR2
ldx #19
move_circles:
dec star_z,X
dex
bpl move_circles
jmp tunnel_again
radii:
.byte <4000, <3200, <1600, <1066, <800, <640, <533, <457
.byte <400, <355, <320, <290, <266, 246, 228, 213
.byte 200, 188, 177, 168, 160, 152, 145, 139
.byte 133, 128, 123, 118, 114, 110, 106, 103
.byte 100, 96, 94, 91, 88, 86, 84, 82
.byte 80, 78, 76, 74, 72, 71, 69, 68
.byte 66, 65, 64, 62, 61, 60, 59, 58
.byte 57, 56, 55, 54, 53, 52, 51, 50
.byte 50, 49, 48, 47, 47, 46, 45, 45
.byte 44, 43, 43, 42, 42, 41, 41, 40
.byte 40, 39, 39, 38, 38, 37, 37, 36
.byte 36, 35, 35, 35, 34, 34, 34, 33
.byte 33, 32, 32, 32, 32, 31, 31, 31
.byte 30, 30, 30, 29, 29, 29, 29, 28
.byte 28, 28, 28, 27, 27, 27, 27, 26
.byte 26, 26, 26, 26, 25, 25, 25, 25
.byte 25, 24, 24, 24, 24, 24, 23, 23
.byte 23, 23, 23, 23, 22, 22, 22, 22
.byte 22, 22, 21, 21, 21, 21, 21, 21
.byte 21, 20, 20, 20, 20, 20, 20, 20
.byte 20, 19, 19, 19, 19, 19, 19, 19
.byte 19, 18, 18, 18, 18, 18, 18, 18
.byte 18, 18, 17, 17, 17, 17, 17, 17
.byte 17, 17, 17, 17, 17, 16, 16, 16
.byte 16, 16, 16, 16, 16, 16, 16, 16
.byte 16, 15, 15, 15, 15, 15, 15, 15
.byte 15, 15, 15, 15, 15, 15, 14, 14
.byte 14, 14, 14, 14, 14, 14, 14, 14
.byte 14, 14, 14, 14, 14, 13, 13, 13
.byte 13, 13, 13, 13, 13, 13, 13, 13
.byte 13, 13, 13, 13, 13, 13, 13, 12
.byte 12, 12, 12, 12, 12, 12, 12, 12
; num-stars = 20
star_z:
.byte 15,26,38,50,63,75,78,100,112,125,137
.byte 150,162,175,187,200,212,224,237