dos33fsprogs/graphics/gr/plasma/plasma_tiny.s

176 lines
2.6 KiB
ArmAsm
Raw Normal View History

2021-01-09 15:00:32 -05:00
; do a (hopefully fast) plasma
; 151 -- original
; 137 -- optimize generation
; 136 -- align lookup table so we can index it easier
; 130 -- optimize indexing of lookup
; 126 -- run loops backaward
; 124 -- notice X already 0 before plot
; 131 -- use GBASCALC. much faster, but 7 bytes larger
; 129 -- run loop backwards
; 128 -- set color ourselves
; 127 -- overlap color lookup with sine table
; 119 -- forgot to comment out unused
; 121 -- make full screen
2021-01-10 15:11:32 -05:00
; 119 -- from qkumba, remove php/plp
; 118 -- from qkumba, remove SAVEX
; 109 -- realize we can use PLOT instead of GBASCALC
2021-01-09 15:00:32 -05:00
.include "zp.inc"
.include "hardware.inc"
CTEMP = $FC
;================================
; Clear screen and setup graphics
;================================
jsr SETGR
bit FULLGR ; full screen
;col = ( 8.0 + (sintable[xx&0xf])
; + 8.0 + (sintable[yy&0xf])
; ) / 2;
create_lookup:
ldy #15
create_yloop:
ldx #15
create_xloop:
clc
lda #15
adc sinetable,X
adc sinetable,Y
lsr
lookup_smc:
sta lookup ; always starts at $d00
inc lookup_smc+1
dex
bpl create_xloop
dey
bpl create_yloop
create_lookup_done:
forever_loop:
cycle_colors:
; cycle colors
; X is $FF when arrive here
inx
; ldx #0
cycle_loop:
inc lookup,X
inx
bne cycle_loop
plot_frame:
; plot frame
ldx #47 ; YY=0
plot_yloop:
;==========
ldy #39 ; XX = 39 (countdown)
2021-01-09 15:00:32 -05:00
txa ; get (y&0xf)<<4
2021-01-10 15:11:32 -05:00
pha ; save YY
2021-01-09 15:00:32 -05:00
asl
asl
asl
asl
sta CTEMP
txa
; lsr
jsr PLOT ; this sets up MASK and GBASL/H for us
; it plots a point at XX,39 but doesn't
; matter as we overdraw
2021-01-09 15:00:32 -05:00
; ldy #$0f ; setup mask ; 2
; bcc plot_mask ; 2
; ldy #$f0 ; 2
2021-01-09 15:00:32 -05:00
;plot_mask:
; sty MASK ; 2
2021-01-10 15:11:32 -05:00
; jsr GBASCALC ; point GBASL/H to address in A ; 3
2021-01-10 15:11:32 -05:00
; after, A trashed, C is clear
2021-01-09 15:00:32 -05:00
plot_xloop:
tya ; get x&0xf
and #$f
ora CTEMP ; get ((y&0xf)*16)+x
tax
plot_lookup:
; sta plot_lookup_smc+1
plot_lookup_smc:
lda lookup,X ; load lookup, (y*16)+x
; lda lookup ; load lookup, (y*16)+x
and #$f
lsr
tax
lda colorlookup,X
sta COLOR
jsr PLOT1 ; plot at GBASL,Y (x co-ord in Y)
dey
bpl plot_xloop
2021-01-10 15:11:32 -05:00
pla
tax ; restore YY
2021-01-09 15:00:32 -05:00
dex
bpl plot_yloop
bmi forever_loop
colorlookup:
bw_color_lookup:
2021-01-10 15:11:32 -05:00
; blue
2021-01-09 15:00:32 -05:00
.byte $55,$22,$66,$77,$ff,$77,$55 ; ,$00 shared w sin table
2021-01-10 15:11:32 -05:00
; pink
;.byte $55,$11,$33,$bb,$ff,$bb,$55 ; ,$00 shared w sin table
2021-01-09 15:00:32 -05:00
sinetable:
.byte $00,$03,$05,$07,$08,$07,$05,$03
.byte $00,$FD,$FB,$F9,$F8,$F9,$FB,$FD
;colorlookup:
;.byte $00,$00,$05,$05,$07,$07,$0f,$0f
;.byte $07,$07,$06,$06,$02,$02,$05,$05
;.byte $00,$55,$77,$ff,$77,$66,$22,$55
.org $d00
;.align $100
lookup: