2019-03-01 13:04:21 -05:00
|
|
|
|
2019-01-26 21:27:20 -05:00
|
|
|
;=====================================
|
|
|
|
; Intro
|
|
|
|
|
2019-01-26 21:52:00 -05:00
|
|
|
.include "zp.inc"
|
|
|
|
.include "hardware.inc"
|
|
|
|
|
2019-01-26 21:27:20 -05:00
|
|
|
intro:
|
|
|
|
|
2019-01-26 21:52:00 -05:00
|
|
|
;===========================
|
|
|
|
; Enable graphics
|
|
|
|
|
|
|
|
bit LORES
|
|
|
|
bit SET_GR
|
|
|
|
bit FULLGR
|
|
|
|
|
|
|
|
;===========================
|
2019-02-03 00:55:45 -05:00
|
|
|
; Setup pages
|
2019-01-26 21:52:00 -05:00
|
|
|
|
2019-02-03 00:55:45 -05:00
|
|
|
lda #4
|
2019-01-26 21:52:00 -05:00
|
|
|
sta DRAW_PAGE
|
2019-02-03 00:55:45 -05:00
|
|
|
lda #0
|
2019-01-26 21:52:00 -05:00
|
|
|
sta DISP_PAGE
|
|
|
|
|
2019-03-01 16:31:10 -05:00
|
|
|
; jmp tunnel1
|
2019-02-05 23:46:31 -05:00
|
|
|
|
2019-01-26 21:52:00 -05:00
|
|
|
;===============================
|
|
|
|
;===============================
|
|
|
|
; Opening scene with car
|
|
|
|
;===============================
|
|
|
|
;===============================
|
2019-03-01 16:31:10 -05:00
|
|
|
|
2019-03-02 10:55:32 -05:00
|
|
|
;==================================
|
|
|
|
; Uncompress the data
|
|
|
|
;==================================
|
|
|
|
lda #<intro1_data_lz4
|
|
|
|
sta LZ4_SRC
|
|
|
|
lda #>intro1_data_lz4
|
|
|
|
sta LZ4_SRC+1
|
|
|
|
|
2019-03-02 13:37:17 -05:00
|
|
|
lda #$90 ; load to $9000
|
2019-03-02 10:55:32 -05:00
|
|
|
|
|
|
|
jsr lz4_decode
|
2019-01-26 21:52:00 -05:00
|
|
|
|
2019-02-03 12:06:45 -05:00
|
|
|
;==================================
|
|
|
|
; draw the car driving up
|
|
|
|
;==================================
|
|
|
|
; draw getting out of the car
|
2019-02-03 00:55:45 -05:00
|
|
|
|
2019-03-01 22:31:43 -05:00
|
|
|
lda #<building_sequence
|
2019-02-03 12:06:45 -05:00
|
|
|
sta INTRO_LOOPL
|
2019-03-01 22:31:43 -05:00
|
|
|
lda #>building_sequence
|
2019-02-03 12:06:45 -05:00
|
|
|
sta INTRO_LOOPH
|
2019-02-03 00:55:45 -05:00
|
|
|
|
2019-02-03 12:06:45 -05:00
|
|
|
jsr run_sequence
|
2019-02-03 00:55:45 -05:00
|
|
|
|
2019-01-27 00:20:20 -05:00
|
|
|
;===============================
|
|
|
|
;===============================
|
|
|
|
; Walk into door
|
|
|
|
;===============================
|
|
|
|
;===============================
|
2019-01-26 21:52:00 -05:00
|
|
|
|
2019-02-04 23:26:55 -05:00
|
|
|
;==================================
|
|
|
|
; draw feet going into door
|
|
|
|
|
|
|
|
lda #<feet_sequence
|
|
|
|
sta INTRO_LOOPL
|
|
|
|
lda #>feet_sequence
|
|
|
|
sta INTRO_LOOPH
|
|
|
|
|
|
|
|
jsr run_sequence
|
|
|
|
|
2019-03-02 10:02:46 -05:00
|
|
|
|
2019-01-27 00:20:20 -05:00
|
|
|
;===============================
|
|
|
|
;===============================
|
|
|
|
; Elevator going down
|
|
|
|
;===============================
|
|
|
|
;===============================
|
|
|
|
|
2019-02-05 23:46:31 -05:00
|
|
|
elevator:
|
2019-01-27 00:20:20 -05:00
|
|
|
;=============================
|
2019-02-05 23:46:31 -05:00
|
|
|
; Load background to $c00 and $1000
|
2019-01-27 00:20:20 -05:00
|
|
|
|
|
|
|
lda #>(elevator_rle)
|
|
|
|
sta GBASH
|
|
|
|
lda #<(elevator_rle)
|
|
|
|
sta GBASL
|
2019-03-01 13:04:21 -05:00
|
|
|
|
2019-02-03 00:55:45 -05:00
|
|
|
lda #$c ; load to off-screen $c00
|
2019-01-27 00:20:20 -05:00
|
|
|
jsr load_rle_gr
|
2019-03-01 13:04:21 -05:00
|
|
|
|
2019-02-05 23:46:31 -05:00
|
|
|
lda #>(elevator_rle)
|
|
|
|
sta GBASH
|
|
|
|
lda #<(elevator_rle)
|
|
|
|
sta GBASL
|
2019-03-01 13:04:21 -05:00
|
|
|
lda #$10 ; load also to off-screen $1000
|
2019-02-05 23:46:31 -05:00
|
|
|
jsr load_rle_gr
|
2019-01-27 00:20:20 -05:00
|
|
|
|
|
|
|
|
|
|
|
jsr gr_copy_to_current
|
2019-02-05 23:46:31 -05:00
|
|
|
|
|
|
|
lda #$66
|
|
|
|
sta COLOR
|
|
|
|
|
|
|
|
; elevator outer door
|
|
|
|
|
|
|
|
ldx #39
|
|
|
|
stx V2
|
|
|
|
ldx #4
|
|
|
|
ldy #14
|
2019-03-01 22:31:43 -05:00
|
|
|
jsr vlin ; VLIN 4,39 AT 14 (X, V2 at Y)
|
2019-02-05 23:46:31 -05:00
|
|
|
|
|
|
|
ldx #35
|
|
|
|
stx V2
|
|
|
|
ldx #7
|
|
|
|
ldy #18
|
2019-03-01 22:31:43 -05:00
|
|
|
jsr vlin ; VLIN 7,35 AT 18 (X, V2 at Y)
|
2019-02-05 23:46:31 -05:00
|
|
|
|
|
|
|
; elevator inner door
|
|
|
|
ldx #2
|
|
|
|
stx ELEVATOR_COUNT
|
|
|
|
elevator_middle:
|
|
|
|
ldx #38
|
|
|
|
stx V2
|
|
|
|
ldx #5
|
|
|
|
ldy #15
|
|
|
|
|
|
|
|
jsr vlin ; X, V2 at Y
|
|
|
|
|
|
|
|
ldx #36
|
|
|
|
stx V2
|
|
|
|
ldx #6
|
|
|
|
ldy #17
|
|
|
|
|
|
|
|
jsr vlin ; X, V2 at Y
|
|
|
|
|
|
|
|
elevator_inner:
|
|
|
|
ldx #37
|
|
|
|
stx V2
|
|
|
|
ldx #5
|
|
|
|
ldy #16
|
|
|
|
|
|
|
|
jsr vlin ; X, V2 at Y
|
|
|
|
|
|
|
|
|
|
|
|
|
2019-01-27 00:20:20 -05:00
|
|
|
jsr page_flip
|
2019-02-05 23:46:31 -05:00
|
|
|
|
2019-01-27 00:20:20 -05:00
|
|
|
jsr gr_copy_to_current
|
|
|
|
|
2019-02-05 23:46:31 -05:00
|
|
|
ldx #50
|
|
|
|
jsr long_wait
|
|
|
|
|
|
|
|
dec ELEVATOR_COUNT
|
|
|
|
lda ELEVATOR_COUNT
|
|
|
|
beq elevator_inner
|
|
|
|
cmp #1
|
|
|
|
beq elevator_middle
|
|
|
|
|
|
|
|
; door closed
|
|
|
|
|
|
|
|
jsr page_flip
|
|
|
|
|
|
|
|
ldx #100
|
|
|
|
jsr long_wait
|
|
|
|
|
|
|
|
;======================
|
|
|
|
; yellow line goes down
|
|
|
|
;======================
|
|
|
|
|
|
|
|
lda #0
|
|
|
|
sta COLOR
|
|
|
|
lda #5
|
|
|
|
sta V2
|
|
|
|
yellow_line_down:
|
|
|
|
|
|
|
|
jsr gr_copy_to_current
|
|
|
|
|
|
|
|
ldx #5
|
|
|
|
ldy #16
|
|
|
|
jsr vlin ; X, V2 at Y
|
|
|
|
|
|
|
|
jsr page_flip
|
|
|
|
|
|
|
|
ldx #12
|
|
|
|
jsr long_wait
|
|
|
|
|
|
|
|
inc V2
|
|
|
|
lda V2
|
2019-03-01 22:31:43 -05:00
|
|
|
cmp #37
|
2019-02-05 23:46:31 -05:00
|
|
|
bne yellow_line_down
|
|
|
|
|
|
|
|
lda DRAW_PAGE
|
|
|
|
pha
|
|
|
|
|
|
|
|
lda #$c ; erase yellow line
|
|
|
|
sta DRAW_PAGE ; on page $1000 version
|
|
|
|
ldx #5
|
|
|
|
ldy #16
|
|
|
|
jsr vlin ; X, V2 at Y
|
|
|
|
|
|
|
|
pla
|
|
|
|
sta DRAW_PAGE
|
|
|
|
|
|
|
|
;========================
|
|
|
|
; change floor indicators
|
|
|
|
;========================
|
|
|
|
|
|
|
|
lda #$33
|
|
|
|
sta COLOR
|
|
|
|
lda #5
|
|
|
|
sta V2
|
|
|
|
|
2019-03-01 22:55:07 -05:00
|
|
|
lda #4
|
|
|
|
sta PARTICLE_COUNT
|
|
|
|
floor_loop:
|
|
|
|
|
2019-02-05 23:46:31 -05:00
|
|
|
jsr gr_copy_to_current_1000
|
2019-03-01 22:55:07 -05:00
|
|
|
|
|
|
|
lda PARTICLE_COUNT
|
|
|
|
asl
|
|
|
|
tay
|
|
|
|
ldx indicators,Y
|
|
|
|
lda indicators+1,Y
|
|
|
|
|
|
|
|
jsr plot
|
|
|
|
|
2019-02-05 23:46:31 -05:00
|
|
|
jsr page_flip
|
|
|
|
ldx #150
|
|
|
|
jsr long_wait
|
|
|
|
|
2019-03-01 22:55:07 -05:00
|
|
|
dec PARTICLE_COUNT
|
|
|
|
bpl floor_loop
|
|
|
|
|
2019-02-05 23:46:31 -05:00
|
|
|
;====================
|
|
|
|
; dark elevator
|
|
|
|
;====================
|
|
|
|
|
|
|
|
; clear $c00 to black
|
2019-01-27 00:20:20 -05:00
|
|
|
|
2019-02-05 23:46:31 -05:00
|
|
|
lda DRAW_PAGE
|
|
|
|
pha
|
|
|
|
|
|
|
|
lda #$8
|
|
|
|
sta DRAW_PAGE
|
|
|
|
jsr clear_all
|
|
|
|
|
|
|
|
pla
|
|
|
|
sta DRAW_PAGE
|
|
|
|
|
|
|
|
; blue from 20, 30 - 20,34 and yellow (brown?) from 20,0 to 20,30
|
|
|
|
; scrolls down until all yellow
|
|
|
|
|
|
|
|
lda #30
|
|
|
|
sta ELEVATOR_COUNT
|
|
|
|
going_down_loop:
|
|
|
|
|
|
|
|
jsr gr_copy_to_current ; copy black screen in
|
|
|
|
|
|
|
|
; draw the yellow part
|
|
|
|
|
|
|
|
lda #$DD
|
|
|
|
sta COLOR
|
|
|
|
lda ELEVATOR_COUNT
|
|
|
|
sta V2
|
|
|
|
ldx #0
|
|
|
|
ldy #20
|
|
|
|
jsr vlin ; X, V2 at Y
|
|
|
|
|
|
|
|
lda #$22 ; draw the blue part
|
|
|
|
sta COLOR
|
|
|
|
|
|
|
|
lda ELEVATOR_COUNT
|
|
|
|
clc
|
|
|
|
adc #4
|
|
|
|
cmp #40
|
|
|
|
bmi not_too_big
|
|
|
|
|
|
|
|
lda #40
|
|
|
|
not_too_big:
|
|
|
|
sta V2
|
|
|
|
ldx ELEVATOR_COUNT
|
|
|
|
ldy #20
|
|
|
|
jsr vlin ; X, V2 at Y
|
|
|
|
|
|
|
|
jsr page_flip
|
|
|
|
|
2019-02-06 22:01:59 -05:00
|
|
|
ldx #8 ; pause
|
2019-02-05 23:46:31 -05:00
|
|
|
jsr long_wait
|
|
|
|
|
|
|
|
inc ELEVATOR_COUNT
|
|
|
|
lda ELEVATOR_COUNT
|
|
|
|
cmp #40
|
|
|
|
bne going_down_loop
|
|
|
|
|
|
|
|
;=====================
|
|
|
|
; all yellow for a bit
|
|
|
|
;=====================
|
|
|
|
|
|
|
|
jsr gr_copy_to_current ; copy black screen in
|
|
|
|
lda #$DD
|
|
|
|
sta COLOR
|
|
|
|
lda #40
|
|
|
|
sta V2
|
|
|
|
ldx #0
|
|
|
|
ldy #20
|
|
|
|
jsr vlin ; X, V2 at Y
|
|
|
|
jsr page_flip
|
|
|
|
|
|
|
|
ldx #100 ; wait a bit
|
|
|
|
jsr long_wait
|
|
|
|
|
|
|
|
|
|
|
|
; single blue dot
|
|
|
|
; solid blue line 10 later
|
|
|
|
|
|
|
|
lda #2
|
|
|
|
sta ELEVATOR_CYCLE
|
|
|
|
|
|
|
|
going_down_repeat:
|
|
|
|
|
|
|
|
lda #1
|
|
|
|
sta ELEVATOR_COUNT
|
|
|
|
going_down_blue:
|
|
|
|
|
|
|
|
jsr gr_copy_to_current ; copy black screen in
|
|
|
|
|
|
|
|
; draw the blue part
|
|
|
|
|
|
|
|
lda #$22
|
|
|
|
sta COLOR
|
|
|
|
lda ELEVATOR_COUNT
|
|
|
|
sta V2
|
|
|
|
ldx #0
|
|
|
|
ldy #20
|
|
|
|
jsr vlin ; X, V2 at Y
|
|
|
|
|
|
|
|
gdb_smc:
|
|
|
|
lda #$dd ; draw the blue part
|
|
|
|
sta COLOR
|
|
|
|
|
|
|
|
lda #40
|
|
|
|
sta V2
|
|
|
|
ldx ELEVATOR_COUNT
|
|
|
|
ldy #20
|
|
|
|
jsr vlin ; X, V2 at Y
|
|
|
|
|
|
|
|
jsr page_flip
|
|
|
|
|
2019-02-06 22:01:59 -05:00
|
|
|
ldx #8 ; pause
|
2019-02-05 23:46:31 -05:00
|
|
|
jsr long_wait
|
|
|
|
|
|
|
|
inc ELEVATOR_COUNT
|
|
|
|
lda ELEVATOR_COUNT
|
|
|
|
cmp #40
|
|
|
|
bne going_down_blue
|
|
|
|
|
|
|
|
dec ELEVATOR_CYCLE
|
|
|
|
beq elevator_exit
|
|
|
|
|
|
|
|
|
|
|
|
lda #1
|
|
|
|
sta ELEVATOR_COUNT
|
|
|
|
going_down_black:
|
|
|
|
|
|
|
|
jsr gr_copy_to_current ; copy black screen in
|
|
|
|
|
|
|
|
; draw the blue part
|
|
|
|
|
|
|
|
lda #$00
|
|
|
|
sta COLOR
|
|
|
|
lda ELEVATOR_COUNT
|
|
|
|
sta V2
|
|
|
|
ldx #0
|
|
|
|
ldy #20
|
|
|
|
jsr vlin ; X, V2 at Y
|
|
|
|
|
|
|
|
lda #$22 ; draw the blue part
|
|
|
|
sta COLOR
|
|
|
|
|
|
|
|
lda #40
|
|
|
|
sta V2
|
|
|
|
ldx ELEVATOR_COUNT
|
|
|
|
ldy #20
|
|
|
|
jsr vlin ; X, V2 at Y
|
|
|
|
|
|
|
|
jsr page_flip
|
|
|
|
|
2019-02-06 22:01:59 -05:00
|
|
|
ldx #8 ; pause
|
2019-02-05 23:46:31 -05:00
|
|
|
jsr long_wait
|
|
|
|
|
|
|
|
inc ELEVATOR_COUNT
|
|
|
|
lda ELEVATOR_COUNT
|
|
|
|
cmp #40
|
|
|
|
bne going_down_black
|
|
|
|
|
|
|
|
lda #$00
|
|
|
|
sta gdb_smc+1
|
|
|
|
|
|
|
|
jmp going_down_repeat
|
|
|
|
|
|
|
|
|
|
|
|
; black, 2, blue, black about 20
|
|
|
|
; blue until hit bottom, doors open
|
|
|
|
|
2019-02-06 22:01:59 -05:00
|
|
|
|
|
|
|
|
2019-02-05 23:46:31 -05:00
|
|
|
elevator_exit:
|
|
|
|
|
|
|
|
ldx #100 ; pause
|
|
|
|
jsr long_wait
|
2019-01-27 00:20:20 -05:00
|
|
|
|
2019-02-06 22:01:59 -05:00
|
|
|
|
|
|
|
|
2019-01-27 00:20:20 -05:00
|
|
|
;===============================
|
|
|
|
;===============================
|
|
|
|
; Getting out of Elevator
|
|
|
|
;===============================
|
|
|
|
;===============================
|
|
|
|
|
|
|
|
|
|
|
|
;=============================
|
2019-03-01 13:04:21 -05:00
|
|
|
; Load elevator background
|
2019-01-27 00:20:20 -05:00
|
|
|
|
|
|
|
lda #>(off_elevator_rle)
|
|
|
|
sta GBASH
|
|
|
|
lda #<(off_elevator_rle)
|
|
|
|
sta GBASL
|
2019-02-03 00:55:45 -05:00
|
|
|
lda #$c ; load to off-screen $c00
|
2019-01-27 00:20:20 -05:00
|
|
|
jsr load_rle_gr
|
|
|
|
|
2019-02-06 22:01:59 -05:00
|
|
|
lda #>(walking00_rle)
|
|
|
|
sta GBASH
|
|
|
|
lda #<(walking00_rle)
|
|
|
|
sta GBASL
|
|
|
|
lda #$10 ; load to off-screen $1000
|
|
|
|
jsr load_rle_gr
|
2019-02-06 00:32:54 -05:00
|
|
|
|
|
|
|
|
|
|
|
lda #10
|
|
|
|
sta ELEVATOR_COUNT
|
|
|
|
|
|
|
|
elevator_open_loop:
|
2019-02-06 22:01:59 -05:00
|
|
|
jsr gr_overlay ; note: overwrites color
|
|
|
|
lda #$00
|
|
|
|
sta COLOR
|
2019-02-06 00:32:54 -05:00
|
|
|
|
2019-02-06 22:01:59 -05:00
|
|
|
; Would have liked to have a central purple stripe, but not easy
|
2019-02-06 00:32:54 -05:00
|
|
|
|
|
|
|
; 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30
|
|
|
|
|
|
|
|
|
|
|
|
lda ELEVATOR_COUNT
|
|
|
|
sta ELEVATOR_CYCLE
|
|
|
|
elevator_inner_loop:
|
|
|
|
lda #9
|
|
|
|
clc
|
|
|
|
adc ELEVATOR_CYCLE
|
|
|
|
tay
|
|
|
|
|
|
|
|
lda #40
|
|
|
|
sta V2
|
|
|
|
ldx #0
|
|
|
|
jsr vlin ; X, V2 at Y
|
|
|
|
|
|
|
|
sec
|
|
|
|
lda #30
|
|
|
|
sbc ELEVATOR_CYCLE
|
|
|
|
tay
|
|
|
|
|
|
|
|
lda #40
|
|
|
|
sta V2
|
|
|
|
ldx #0
|
|
|
|
jsr vlin ; X, V2 at Y
|
|
|
|
|
|
|
|
dec ELEVATOR_CYCLE
|
|
|
|
bne elevator_inner_loop
|
2019-02-05 23:46:31 -05:00
|
|
|
|
2019-01-27 00:20:20 -05:00
|
|
|
jsr page_flip
|
2019-02-05 23:46:31 -05:00
|
|
|
|
2019-02-06 23:08:04 -05:00
|
|
|
ldx #25
|
|
|
|
jsr long_wait ; pause
|
2019-02-06 00:32:54 -05:00
|
|
|
|
|
|
|
dec ELEVATOR_COUNT
|
|
|
|
bne elevator_open_loop
|
|
|
|
|
2019-02-06 22:01:59 -05:00
|
|
|
;==================================
|
|
|
|
; draw walking off the elevator
|
2019-02-06 00:32:54 -05:00
|
|
|
|
2019-02-06 22:01:59 -05:00
|
|
|
lda #<walking_sequence
|
|
|
|
sta INTRO_LOOPL
|
|
|
|
lda #>walking_sequence
|
|
|
|
sta INTRO_LOOPH
|
|
|
|
|
|
|
|
jsr run_sequence
|
2019-02-06 00:32:54 -05:00
|
|
|
|
2019-02-06 23:08:04 -05:00
|
|
|
;======================================
|
|
|
|
; make background black and pause a bit
|
2019-02-06 00:32:54 -05:00
|
|
|
|
2019-02-06 23:08:04 -05:00
|
|
|
jsr clear_all
|
|
|
|
jsr page_flip
|
2019-02-06 00:32:54 -05:00
|
|
|
|
2019-03-02 11:42:59 -05:00
|
|
|
; no need to pause as uncompressing LZ4 below
|
|
|
|
; takes a bit
|
|
|
|
|
|
|
|
; ldx #80
|
|
|
|
; jsr long_wait
|
2019-01-27 00:20:20 -05:00
|
|
|
|
|
|
|
;===============================
|
|
|
|
;===============================
|
|
|
|
; Keycode
|
|
|
|
;===============================
|
|
|
|
;===============================
|
|
|
|
|
2019-03-02 11:19:03 -05:00
|
|
|
keypad:
|
|
|
|
;==================================
|
|
|
|
; Uncompress the data
|
|
|
|
;==================================
|
|
|
|
lda #<intro4_data_lz4
|
|
|
|
sta LZ4_SRC
|
|
|
|
lda #>intro4_data_lz4
|
|
|
|
sta LZ4_SRC+1
|
2019-03-02 11:10:41 -05:00
|
|
|
|
2019-03-02 13:37:17 -05:00
|
|
|
lda #$90 ; load to $9000
|
2019-03-02 11:19:03 -05:00
|
|
|
|
|
|
|
jsr lz4_decode
|
2019-03-02 11:10:41 -05:00
|
|
|
|
2019-02-06 23:08:04 -05:00
|
|
|
;=============================
|
|
|
|
; Load background to $c00
|
|
|
|
|
|
|
|
lda #>(scanner_door_rle)
|
|
|
|
sta GBASH
|
|
|
|
lda #<(scanner_door_rle)
|
|
|
|
sta GBASL
|
|
|
|
lda #$c ; load to off-screen $c00
|
|
|
|
jsr load_rle_gr
|
|
|
|
|
|
|
|
lda #<approach_sequence
|
|
|
|
sta INTRO_LOOPL
|
|
|
|
lda #>approach_sequence
|
|
|
|
sta INTRO_LOOPH
|
|
|
|
|
|
|
|
jsr run_sequence
|
|
|
|
|
|
|
|
|
2019-01-27 15:30:00 -05:00
|
|
|
;=============================
|
|
|
|
; Load background to $c00
|
|
|
|
|
|
|
|
lda #>(keypad_rle)
|
|
|
|
sta GBASH
|
|
|
|
lda #<(keypad_rle)
|
|
|
|
sta GBASL
|
2019-02-03 00:55:45 -05:00
|
|
|
lda #$c ; load to off-screen $c00
|
2019-01-27 15:30:00 -05:00
|
|
|
jsr load_rle_gr
|
|
|
|
|
2019-02-07 22:02:56 -05:00
|
|
|
;==================================
|
2019-03-01 13:04:21 -05:00
|
|
|
; draw keypad sequence
|
2019-01-27 15:30:00 -05:00
|
|
|
|
2019-02-07 22:02:56 -05:00
|
|
|
lda #<keypad_sequence
|
|
|
|
sta INTRO_LOOPL
|
|
|
|
lda #>keypad_sequence
|
|
|
|
sta INTRO_LOOPH
|
|
|
|
|
|
|
|
jsr run_sequence
|
2019-02-06 23:08:04 -05:00
|
|
|
|
2019-01-27 15:30:00 -05:00
|
|
|
|
2019-02-12 23:19:49 -05:00
|
|
|
;==================================
|
|
|
|
; doop opening sequence
|
|
|
|
|
|
|
|
lda #>(scanner_door_rle)
|
|
|
|
sta GBASH
|
|
|
|
lda #<(scanner_door_rle)
|
|
|
|
sta GBASL
|
|
|
|
lda #$c ; load to off-screen $c00
|
|
|
|
jsr load_rle_gr
|
|
|
|
|
|
|
|
|
|
|
|
lda #<opening_sequence
|
|
|
|
sta INTRO_LOOPL
|
|
|
|
lda #>opening_sequence
|
|
|
|
sta INTRO_LOOPH
|
|
|
|
|
|
|
|
jsr run_sequence
|
|
|
|
|
2019-03-02 11:42:59 -05:00
|
|
|
|
2019-01-27 00:20:20 -05:00
|
|
|
;===============================
|
|
|
|
;===============================
|
|
|
|
; Scanner
|
|
|
|
;===============================
|
|
|
|
;===============================
|
|
|
|
|
2019-02-16 22:00:06 -05:00
|
|
|
scanner:
|
2019-01-27 15:30:00 -05:00
|
|
|
lda #>(scanner_rle)
|
|
|
|
sta GBASH
|
|
|
|
lda #<(scanner_rle)
|
|
|
|
sta GBASL
|
2019-02-03 00:55:45 -05:00
|
|
|
lda #$c ; load to off-screen $c00
|
2019-01-27 15:30:00 -05:00
|
|
|
jsr load_rle_gr
|
|
|
|
|
|
|
|
jsr gr_copy_to_current
|
|
|
|
jsr page_flip
|
2019-02-13 00:46:11 -05:00
|
|
|
|
|
|
|
lda #<scanning_sequence
|
|
|
|
sta INTRO_LOOPL
|
|
|
|
lda #>scanning_sequence
|
|
|
|
sta INTRO_LOOPH
|
|
|
|
|
|
|
|
jsr run_sequence
|
2019-01-27 15:30:00 -05:00
|
|
|
|
2019-01-27 00:20:20 -05:00
|
|
|
;===============================
|
|
|
|
;===============================
|
|
|
|
; Spinny DNA / Key
|
|
|
|
;===============================
|
|
|
|
;===============================
|
2019-01-26 21:52:00 -05:00
|
|
|
|
2019-02-17 15:13:13 -05:00
|
|
|
scanner2:
|
|
|
|
|
2019-02-14 22:00:00 -05:00
|
|
|
lda #>(ai_bg_rle)
|
|
|
|
sta GBASH
|
|
|
|
lda #<(ai_bg_rle)
|
|
|
|
sta GBASL
|
|
|
|
lda #$c ; load to off-screen $c00
|
|
|
|
jsr load_rle_gr
|
|
|
|
|
2019-02-17 11:04:16 -05:00
|
|
|
jsr clear_bottom
|
|
|
|
bit TEXTGR ; split graphics/text
|
|
|
|
|
2019-02-17 11:34:47 -05:00
|
|
|
jsr gr_copy_to_current_40x40
|
2019-02-14 22:00:00 -05:00
|
|
|
jsr page_flip
|
|
|
|
|
2019-02-17 11:34:47 -05:00
|
|
|
jsr clear_bottom
|
|
|
|
|
2019-02-17 13:37:24 -05:00
|
|
|
;=============================
|
2019-02-15 01:10:17 -05:00
|
|
|
; Identification (nothing)
|
2019-02-17 13:37:24 -05:00
|
|
|
;=============================
|
2019-02-15 01:10:17 -05:00
|
|
|
|
2019-02-17 13:37:24 -05:00
|
|
|
lda #0
|
|
|
|
sta DNA_OUT
|
|
|
|
sta DNA_PROGRESS
|
2019-02-15 01:10:17 -05:00
|
|
|
|
|
|
|
lda #<ai_sequence
|
|
|
|
sta INTRO_LOOPL
|
|
|
|
lda #>ai_sequence
|
|
|
|
sta INTRO_LOOPH
|
|
|
|
|
|
|
|
jsr run_sequence_static
|
|
|
|
|
2019-02-16 13:54:09 -05:00
|
|
|
; slices / | - / nothing (pause)
|
|
|
|
; more slices / | - / nothing (pause)
|
|
|
|
; small circle / | - / nothing (pause)
|
|
|
|
; big circle / | - / nothing (pause)
|
2019-02-17 13:37:24 -05:00
|
|
|
|
2019-02-17 14:15:15 -05:00
|
|
|
; jsr gr_copy_to_current_40x40
|
|
|
|
; jsr draw_dna
|
|
|
|
; jsr page_flip
|
2019-02-17 13:37:24 -05:00
|
|
|
|
|
|
|
; approx one rotation until "Good evening"
|
|
|
|
; two rotation, then switch to key + Ferrari
|
|
|
|
; three rotations, then done
|
|
|
|
|
2019-02-16 13:54:09 -05:00
|
|
|
; - !!! DNA START 1 line
|
|
|
|
; / !!! DNA start 1 line
|
|
|
|
; !!! DNA 2 lines
|
2019-02-15 01:10:17 -05:00
|
|
|
; DNA 5 lines
|
|
|
|
; Good evening professor.
|
|
|
|
; DNA all lines
|
|
|
|
|
2019-02-17 13:37:24 -05:00
|
|
|
; Triggers:
|
|
|
|
; + DNA starts midway through big circle
|
|
|
|
; + Good evening printed at DNA_OUT=5
|
|
|
|
; + Switch to key, print ferrari
|
|
|
|
|
|
|
|
|
2019-02-16 13:54:09 -05:00
|
|
|
; Key |
|
2019-02-15 01:10:17 -05:00
|
|
|
; I see you have driven here in your \ Ferrari.
|
2019-02-16 13:54:09 -05:00
|
|
|
; Key - / nothing (pause)
|
2019-02-15 01:10:17 -05:00
|
|
|
|
2019-02-17 15:13:13 -05:00
|
|
|
|
|
|
|
ldx #35
|
|
|
|
spin_on_key:
|
|
|
|
txa
|
|
|
|
pha
|
|
|
|
|
|
|
|
jsr draw_dna
|
|
|
|
jsr page_flip
|
|
|
|
|
|
|
|
pla
|
|
|
|
tax
|
|
|
|
|
|
|
|
lda #250
|
|
|
|
jsr WAIT
|
|
|
|
|
|
|
|
dex
|
|
|
|
bne spin_on_key
|
|
|
|
|
2019-03-02 11:42:59 -05:00
|
|
|
|
2019-01-26 21:52:00 -05:00
|
|
|
|
2019-01-27 15:30:00 -05:00
|
|
|
;===============================
|
|
|
|
; Sitting at Desk
|
|
|
|
;===============================
|
2019-01-26 21:52:00 -05:00
|
|
|
|
2019-03-02 12:07:03 -05:00
|
|
|
;==================================
|
|
|
|
; Uncompress the data
|
|
|
|
;==================================
|
|
|
|
lda #<intro6_data_lz4
|
|
|
|
sta LZ4_SRC
|
|
|
|
lda #>intro6_data_lz4
|
|
|
|
sta LZ4_SRC+1
|
|
|
|
|
2019-03-02 13:37:17 -05:00
|
|
|
lda #$90 ; load to $9000
|
2019-03-02 12:07:03 -05:00
|
|
|
|
|
|
|
jsr lz4_decode
|
|
|
|
|
|
|
|
;======================
|
|
|
|
; load bg
|
|
|
|
|
2019-02-16 00:24:24 -05:00
|
|
|
lda #>(desktop_rle)
|
2019-01-27 15:30:00 -05:00
|
|
|
sta GBASH
|
2019-02-16 00:24:24 -05:00
|
|
|
lda #<(desktop_rle)
|
2019-01-27 15:30:00 -05:00
|
|
|
sta GBASL
|
2019-02-03 00:55:45 -05:00
|
|
|
lda #$c ; load to off-screen $c00
|
2019-01-27 15:30:00 -05:00
|
|
|
jsr load_rle_gr
|
|
|
|
|
|
|
|
jsr gr_copy_to_current
|
2019-02-17 11:04:16 -05:00
|
|
|
|
|
|
|
bit FULLGR ; back to full graphics
|
|
|
|
|
2019-01-27 15:30:00 -05:00
|
|
|
jsr page_flip
|
|
|
|
|
2019-02-16 13:54:09 -05:00
|
|
|
;=================================
|
2019-02-15 01:10:17 -05:00
|
|
|
; Display rises up
|
2019-02-16 13:54:09 -05:00
|
|
|
;=================================
|
|
|
|
|
2019-02-16 14:11:50 -05:00
|
|
|
lda #<powerup_sequence
|
|
|
|
sta INTRO_LOOPL
|
|
|
|
lda #>powerup_sequence
|
|
|
|
sta INTRO_LOOPH
|
2019-02-15 01:10:17 -05:00
|
|
|
|
2019-02-16 14:11:50 -05:00
|
|
|
jsr run_sequence
|
2019-02-16 13:54:09 -05:00
|
|
|
|
2019-02-17 15:13:13 -05:00
|
|
|
ldx #80 ; pause a bit
|
|
|
|
jsr long_wait
|
2019-02-16 13:54:09 -05:00
|
|
|
|
|
|
|
;=================================
|
2019-02-15 01:10:17 -05:00
|
|
|
; Zoom in, mouse move
|
2019-02-16 13:54:09 -05:00
|
|
|
;=================================
|
|
|
|
; FIXME: shimmery edges to display?
|
|
|
|
|
|
|
|
lda #>(desktop_bg_rle)
|
|
|
|
sta GBASH
|
|
|
|
lda #<(desktop_bg_rle)
|
|
|
|
sta GBASL
|
|
|
|
lda #$c ; load to off-screen $c00
|
|
|
|
jsr load_rle_gr
|
|
|
|
|
|
|
|
jsr gr_copy_to_current
|
|
|
|
jsr page_flip
|
|
|
|
|
|
|
|
lda #<cursor_sequence
|
|
|
|
sta INTRO_LOOPL
|
|
|
|
lda #>cursor_sequence
|
|
|
|
sta INTRO_LOOPH
|
|
|
|
|
|
|
|
jsr run_sequence
|
2019-02-15 01:10:17 -05:00
|
|
|
|
2019-02-17 15:13:13 -05:00
|
|
|
ldx #40 ; pause a bit
|
|
|
|
jsr long_wait
|
|
|
|
|
2019-02-15 01:10:17 -05:00
|
|
|
|
2019-01-27 15:30:00 -05:00
|
|
|
;===============================
|
|
|
|
; Peanut OS
|
|
|
|
;===============================
|
2019-02-17 15:44:50 -05:00
|
|
|
|
|
|
|
peanutos:
|
|
|
|
|
2019-02-16 13:54:09 -05:00
|
|
|
; 1 2 3
|
|
|
|
; 0123456789012345678901234567890123456789
|
|
|
|
;
|
|
|
|
; Copyright (c) 1977 Peanut Computer, Inc.
|
2019-02-15 01:10:17 -05:00
|
|
|
; All rights reserved.
|
|
|
|
;
|
|
|
|
; CDOS Version 5.01
|
|
|
|
;
|
|
|
|
; > #
|
|
|
|
|
2019-02-16 13:54:09 -05:00
|
|
|
lda #$a0
|
|
|
|
jsr clear_top_a
|
|
|
|
jsr clear_bottom
|
|
|
|
|
|
|
|
lda #<peanut
|
|
|
|
sta OUTL
|
|
|
|
lda #>peanut
|
|
|
|
sta OUTH
|
|
|
|
|
2019-02-16 18:11:47 -05:00
|
|
|
jsr move_and_print_list
|
2019-02-16 13:54:09 -05:00
|
|
|
|
|
|
|
jsr page_flip
|
|
|
|
|
|
|
|
bit SET_TEXT
|
|
|
|
|
2019-02-17 15:44:50 -05:00
|
|
|
; wait 1s
|
|
|
|
|
|
|
|
ldx #60
|
|
|
|
jsr long_wait
|
|
|
|
|
|
|
|
lda #1
|
|
|
|
sta CURSOR_COUNT
|
2019-02-16 13:54:09 -05:00
|
|
|
|
2019-02-17 15:44:50 -05:00
|
|
|
project_23_loop:
|
2019-02-16 18:00:02 -05:00
|
|
|
; RUN PROJECT 23# (typed)
|
|
|
|
; #
|
|
|
|
|
2019-02-17 15:44:50 -05:00
|
|
|
lda #$a0
|
|
|
|
jsr clear_top_a
|
|
|
|
jsr clear_bottom
|
2019-02-16 13:54:09 -05:00
|
|
|
|
2019-02-17 15:44:50 -05:00
|
|
|
lda #<peanut
|
|
|
|
sta OUTL
|
|
|
|
lda #>peanut
|
|
|
|
sta OUTH
|
|
|
|
|
|
|
|
jsr move_and_print_list
|
|
|
|
|
|
|
|
; $550
|
|
|
|
|
|
|
|
lda #$5
|
|
|
|
clc
|
|
|
|
adc DRAW_PAGE
|
|
|
|
sta OUTH
|
|
|
|
lda #$52
|
|
|
|
sta OUTL
|
|
|
|
|
|
|
|
ldy #0
|
|
|
|
print_project23_loop:
|
|
|
|
|
|
|
|
lda project_23,Y
|
|
|
|
eor #$80
|
|
|
|
sta (OUTL),Y
|
|
|
|
|
|
|
|
iny
|
|
|
|
cpy CURSOR_COUNT
|
|
|
|
bne print_project23_loop
|
|
|
|
|
|
|
|
lda #' '
|
|
|
|
sta (OUTL),Y
|
|
|
|
|
|
|
|
jsr page_flip
|
|
|
|
|
2019-02-18 00:41:16 -05:00
|
|
|
ldx #10
|
2019-02-17 15:44:50 -05:00
|
|
|
jsr long_wait
|
|
|
|
|
|
|
|
inc CURSOR_COUNT
|
|
|
|
lda CURSOR_COUNT
|
|
|
|
cmp #15
|
|
|
|
bne project_23_loop
|
|
|
|
|
|
|
|
ldx #20 ; brief pasue at end of line
|
|
|
|
jsr long_wait
|
|
|
|
|
|
|
|
lda #(' '|$80) ; clear out last cursor
|
|
|
|
sta (OUTL),Y
|
|
|
|
|
|
|
|
lda #' ' ; put cursor on next line
|
|
|
|
sta $5d2 ; both pages
|
|
|
|
sta $9d2
|
|
|
|
|
|
|
|
|
|
|
|
; wait 1s
|
|
|
|
|
|
|
|
ldx #100
|
|
|
|
jsr long_wait
|
|
|
|
|
2019-02-16 13:54:09 -05:00
|
|
|
|
2019-02-16 18:11:47 -05:00
|
|
|
|
2019-01-27 15:30:00 -05:00
|
|
|
;===============================
|
|
|
|
; Particle Accelerator Screen
|
|
|
|
;===============================
|
2019-01-26 21:52:00 -05:00
|
|
|
|
2019-02-15 01:10:17 -05:00
|
|
|
; MODIFICATION OF PARAMETERS
|
|
|
|
; RELATING TO PARTICLE
|
|
|
|
; ACCELERATOR (SYNCHOTRON).
|
2019-02-16 22:00:06 -05:00
|
|
|
;____________ E: 23%
|
|
|
|
; ROOM 3 X:\ g: .005
|
|
|
|
; : :
|
|
|
|
; : : RK: 77.2L
|
|
|
|
; : :
|
|
|
|
;___________:_: opt: g+
|
|
|
|
; ROOM 1 X: :
|
|
|
|
; : : Shield:
|
|
|
|
; : : 1: OFF
|
|
|
|
; : : 2: ON
|
|
|
|
; : : 3: ON
|
|
|
|
; : :
|
|
|
|
; : : P^: 1
|
|
|
|
; __________: :
|
|
|
|
;/__________|/
|
2019-02-16 18:11:47 -05:00
|
|
|
|
2019-02-18 00:41:16 -05:00
|
|
|
; the actual intro draws background 3-d stuff first, gradually
|
|
|
|
; then writes text
|
|
|
|
|
|
|
|
|
2019-02-16 18:11:47 -05:00
|
|
|
lda #$a0
|
|
|
|
jsr clear_top_a
|
|
|
|
jsr clear_bottom
|
|
|
|
|
|
|
|
lda #<accelerator
|
|
|
|
sta OUTL
|
|
|
|
lda #>accelerator
|
|
|
|
sta OUTH
|
|
|
|
|
|
|
|
jsr move_and_print_list
|
|
|
|
|
|
|
|
jsr page_flip
|
|
|
|
|
2019-02-18 00:41:16 -05:00
|
|
|
ldx #50
|
|
|
|
jsr long_wait
|
2019-02-16 18:11:47 -05:00
|
|
|
|
2019-02-18 00:41:16 -05:00
|
|
|
; Cusrsor starts at E
|
|
|
|
; Down to .005 (pauses)
|
|
|
|
; End of RK
|
|
|
|
; End of g+ (pauses)
|
|
|
|
; erase +
|
|
|
|
; change to - (pauses)
|
|
|
|
; down to 1 (pauses)
|
|
|
|
; down to 2
|
|
|
|
; down to 3
|
|
|
|
; down to P (pause)
|
2019-02-15 01:10:17 -05:00
|
|
|
|
2019-02-18 00:41:16 -05:00
|
|
|
ldy #0
|
|
|
|
lda #<accel_paramaters
|
|
|
|
sta INL
|
|
|
|
lda #>accel_paramaters
|
|
|
|
sta INH
|
|
|
|
accel_input_loop:
|
|
|
|
lda (INL),Y ; get X
|
|
|
|
cmp #$ff
|
|
|
|
beq done_accel_input
|
|
|
|
sta accel_smc+1
|
|
|
|
sta accel_smc+4
|
|
|
|
iny
|
|
|
|
lda (INL),Y ; get Y
|
|
|
|
sta accel_smc+2
|
|
|
|
clc
|
|
|
|
adc #$4
|
|
|
|
sta accel_smc+5
|
|
|
|
iny
|
|
|
|
lda (INL),Y ; get char
|
|
|
|
iny
|
|
|
|
accel_smc:
|
|
|
|
sta $400
|
|
|
|
sta $800
|
|
|
|
|
|
|
|
lda (INL),Y ; get time
|
|
|
|
tax
|
|
|
|
jsr long_wait
|
|
|
|
iny
|
|
|
|
jmp accel_input_loop
|
|
|
|
done_accel_input:
|
|
|
|
|
|
|
|
|
|
|
|
; FLASH: RUN EXPERIMENT ? (pause)
|
2019-02-15 01:10:17 -05:00
|
|
|
; Y
|
2019-02-18 00:41:16 -05:00
|
|
|
lda #2
|
|
|
|
sta CURSOR_COUNT
|
|
|
|
flash_loop:
|
|
|
|
|
|
|
|
lda #<run_experiment
|
|
|
|
sta OUTL
|
|
|
|
lda #>run_experiment
|
|
|
|
sta OUTH
|
|
|
|
jsr print_both_pages
|
|
|
|
|
|
|
|
ldx #75
|
|
|
|
jsr long_wait
|
|
|
|
|
|
|
|
lda #<run_blank
|
|
|
|
sta OUTL
|
|
|
|
lda #>run_blank
|
|
|
|
sta OUTH
|
|
|
|
jsr print_both_pages
|
|
|
|
|
|
|
|
ldx #75
|
|
|
|
jsr long_wait
|
|
|
|
|
|
|
|
lda CURSOR_COUNT
|
|
|
|
cmp #1
|
|
|
|
bne not_yes
|
|
|
|
|
|
|
|
lda #'Y'|$80
|
|
|
|
sta $670
|
|
|
|
sta $A70
|
|
|
|
|
|
|
|
not_yes:
|
|
|
|
dec CURSOR_COUNT
|
|
|
|
bpl flash_loop
|
|
|
|
|
2019-02-15 01:10:17 -05:00
|
|
|
|
2019-02-16 22:00:06 -05:00
|
|
|
;======================
|
|
|
|
; Accelerate
|
|
|
|
;======================
|
2019-02-17 11:04:16 -05:00
|
|
|
bit SET_GR
|
|
|
|
|
2019-02-18 01:01:10 -05:00
|
|
|
lda #>(collider_rle)
|
2019-02-16 22:00:06 -05:00
|
|
|
sta GBASH
|
2019-02-18 01:01:10 -05:00
|
|
|
lda #<(collider_rle)
|
2019-02-16 22:00:06 -05:00
|
|
|
sta GBASL
|
|
|
|
lda #$c ; load to off-screen $c00
|
|
|
|
jsr load_rle_gr
|
|
|
|
|
|
|
|
jsr gr_copy_to_current
|
|
|
|
jsr page_flip
|
|
|
|
|
2019-02-18 12:18:46 -05:00
|
|
|
bit TEXTGR
|
|
|
|
jsr clear_bottoms
|
2019-02-16 22:00:06 -05:00
|
|
|
|
2019-02-18 12:18:46 -05:00
|
|
|
; --- Theoretical Study ---
|
|
|
|
; make this inverse?
|
|
|
|
|
|
|
|
lda #<theoretical_study
|
|
|
|
sta OUTL
|
|
|
|
lda #>theoretical_study
|
|
|
|
sta OUTH
|
|
|
|
|
|
|
|
jsr print_both_pages
|
|
|
|
|
|
|
|
;==========================
|
2019-02-15 01:10:17 -05:00
|
|
|
; - Phase 0:
|
|
|
|
; INJECTION of particles
|
|
|
|
; into synchrotron
|
|
|
|
|
2019-02-18 13:04:02 -05:00
|
|
|
lda #0
|
|
|
|
sta PARTICLE_COUNT
|
|
|
|
|
2019-02-18 12:18:46 -05:00
|
|
|
lda #<phase0
|
|
|
|
sta OUTL
|
|
|
|
lda #>phase0
|
|
|
|
sta OUTH
|
|
|
|
|
|
|
|
jsr move_and_print_list_both_pages
|
|
|
|
|
2019-02-18 13:04:02 -05:00
|
|
|
jsr gr_copy_to_current_40x40
|
|
|
|
jsr plot_particle
|
|
|
|
jsr page_flip
|
|
|
|
ldx #40
|
|
|
|
jsr long_wait
|
2019-02-18 12:18:46 -05:00
|
|
|
|
2019-02-18 13:04:02 -05:00
|
|
|
jsr gr_copy_to_current_40x40
|
|
|
|
jsr plot_particle
|
|
|
|
jsr page_flip
|
|
|
|
ldx #40
|
2019-02-18 12:18:46 -05:00
|
|
|
jsr long_wait
|
|
|
|
|
2019-02-18 13:04:02 -05:00
|
|
|
|
2019-02-18 12:18:46 -05:00
|
|
|
;===========================
|
2019-02-15 01:10:17 -05:00
|
|
|
; - Phase 1:
|
|
|
|
; Particle ACCELERATION.
|
|
|
|
|
|
|
|
|
2019-02-18 12:18:46 -05:00
|
|
|
; Note: goes around at least 4 times
|
|
|
|
|
|
|
|
jsr clear_bottoms
|
|
|
|
|
|
|
|
; --- Theoretical Study ---
|
|
|
|
lda #<theoretical_study
|
|
|
|
sta OUTL
|
|
|
|
lda #>theoretical_study
|
|
|
|
sta OUTH
|
|
|
|
|
|
|
|
jsr print_both_pages
|
|
|
|
|
|
|
|
lda #<phase1
|
|
|
|
sta OUTL
|
|
|
|
lda #>phase1
|
|
|
|
sta OUTH
|
|
|
|
|
|
|
|
jsr move_and_print_list_both_pages
|
|
|
|
|
2019-02-18 13:04:02 -05:00
|
|
|
; 5 times around? (total = 39)
|
|
|
|
|
|
|
|
particle_loop:
|
|
|
|
jsr gr_copy_to_current_40x40
|
|
|
|
jsr plot_particle
|
|
|
|
jsr page_flip
|
|
|
|
ldx #20
|
2019-02-18 12:18:46 -05:00
|
|
|
jsr long_wait
|
|
|
|
|
2019-02-18 13:04:02 -05:00
|
|
|
lda PARTICLE_COUNT
|
|
|
|
cmp #38
|
|
|
|
bne particle_loop
|
|
|
|
|
2019-02-18 12:18:46 -05:00
|
|
|
;=====================================
|
2019-02-15 01:10:17 -05:00
|
|
|
; - Phase 2:
|
|
|
|
; EJECTION of particles
|
|
|
|
; on the shield.
|
|
|
|
|
2019-02-18 13:04:02 -05:00
|
|
|
; Note: goes around once more, then does shield animation
|
2019-02-18 12:18:46 -05:00
|
|
|
|
|
|
|
jsr clear_bottoms
|
2019-02-15 01:10:17 -05:00
|
|
|
|
2019-02-18 12:18:46 -05:00
|
|
|
; --- Theoretical Study ---
|
|
|
|
lda #<theoretical_study
|
|
|
|
sta OUTL
|
|
|
|
lda #>theoretical_study
|
|
|
|
sta OUTH
|
|
|
|
|
|
|
|
jsr print_both_pages
|
|
|
|
|
|
|
|
lda #<phase2
|
|
|
|
sta OUTL
|
|
|
|
lda #>phase2
|
|
|
|
sta OUTH
|
|
|
|
|
|
|
|
jsr move_and_print_list_both_pages
|
|
|
|
|
2019-02-18 13:04:02 -05:00
|
|
|
|
|
|
|
jsr gr_copy_to_current_40x40
|
|
|
|
jsr plot_particle
|
|
|
|
jsr page_flip
|
|
|
|
ldx #20
|
2019-02-18 12:18:46 -05:00
|
|
|
jsr long_wait
|
|
|
|
|
2019-02-18 13:04:02 -05:00
|
|
|
lda #<shield_sequence
|
|
|
|
sta INTRO_LOOPL
|
|
|
|
lda #>shield_sequence
|
|
|
|
sta INTRO_LOOPH
|
|
|
|
|
|
|
|
jsr run_sequence_40x40
|
|
|
|
|
|
|
|
ldx #30
|
|
|
|
jsr long_wait
|
2019-02-18 12:18:46 -05:00
|
|
|
|
|
|
|
;=============================
|
2019-02-15 01:10:17 -05:00
|
|
|
; A N A L Y S I S
|
|
|
|
|
2019-02-18 12:18:46 -05:00
|
|
|
jsr clear_bottoms
|
|
|
|
|
|
|
|
; --- Theoretical Study ---
|
|
|
|
lda #<theoretical_study
|
|
|
|
sta OUTL
|
|
|
|
lda #>theoretical_study
|
|
|
|
sta OUTH
|
|
|
|
|
|
|
|
jsr print_both_pages
|
|
|
|
|
|
|
|
lda #<analysis
|
|
|
|
sta OUTL
|
|
|
|
lda #>analysis
|
|
|
|
sta OUTH
|
|
|
|
|
|
|
|
jsr print_both_pages
|
2019-02-15 01:10:17 -05:00
|
|
|
|
2019-02-18 12:18:46 -05:00
|
|
|
ldx #200
|
|
|
|
jsr long_wait
|
|
|
|
|
|
|
|
;=============================
|
2019-02-15 01:10:17 -05:00
|
|
|
; - RESULT:
|
|
|
|
; Probability of creating:
|
2019-02-18 12:18:46 -05:00
|
|
|
; ANTIMATTER: 91.V %
|
|
|
|
; NEUTRINO 27: 0.04 %
|
|
|
|
; NEUTRINO 424: 18 %
|
2019-02-15 01:10:17 -05:00
|
|
|
|
2019-02-18 12:18:46 -05:00
|
|
|
jsr clear_bottoms
|
2019-02-15 01:10:17 -05:00
|
|
|
|
2019-02-18 12:18:46 -05:00
|
|
|
lda #<result
|
|
|
|
sta OUTL
|
|
|
|
lda #>result
|
|
|
|
sta OUTH
|
2019-02-15 01:10:17 -05:00
|
|
|
|
2019-02-18 12:18:46 -05:00
|
|
|
jsr move_and_print_list_both_pages
|
|
|
|
|
|
|
|
ldx #200
|
|
|
|
jsr long_wait
|
|
|
|
|
|
|
|
|
|
|
|
;================================
|
|
|
|
; Practical verification Y/N ?"
|
|
|
|
|
|
|
|
jsr clear_bottoms
|
|
|
|
|
|
|
|
lda #<practical_verification
|
|
|
|
sta OUTL
|
|
|
|
lda #>practical_verification
|
|
|
|
sta OUTH
|
|
|
|
|
|
|
|
jsr print_both_pages
|
|
|
|
|
|
|
|
ldx #200
|
|
|
|
jsr long_wait
|
|
|
|
|
|
|
|
;==========================================
|
|
|
|
; THE EXPERIMENT WILL BEGIN IN 20 SECONDS
|
2019-02-15 01:10:17 -05:00
|
|
|
; 19, 18, 17
|
|
|
|
|
2019-02-18 13:04:02 -05:00
|
|
|
jsr gr_copy_to_current_40x40
|
|
|
|
jsr page_flip
|
|
|
|
|
2019-02-18 12:18:46 -05:00
|
|
|
jsr clear_bottoms
|
2019-02-15 01:10:17 -05:00
|
|
|
|
2019-02-18 12:18:46 -05:00
|
|
|
lda #<experiment
|
|
|
|
sta OUTL
|
|
|
|
lda #>experiment
|
|
|
|
sta OUTH
|
|
|
|
|
|
|
|
; 20
|
|
|
|
jsr print_both_pages
|
|
|
|
ldx #100
|
|
|
|
jsr long_wait
|
|
|
|
|
|
|
|
; 19
|
|
|
|
jsr print_both_pages
|
|
|
|
ldx #100
|
|
|
|
jsr long_wait
|
|
|
|
|
|
|
|
; 18
|
|
|
|
jsr print_both_pages
|
|
|
|
ldx #100
|
|
|
|
jsr long_wait
|
|
|
|
|
|
|
|
; 17
|
|
|
|
jsr print_both_pages
|
|
|
|
ldx #100
|
|
|
|
jsr long_wait
|
2019-02-15 01:10:17 -05:00
|
|
|
|
|
|
|
|
2019-03-02 12:07:03 -05:00
|
|
|
|
2019-01-27 00:20:20 -05:00
|
|
|
;===============================
|
|
|
|
;===============================
|
|
|
|
; Opening Soda
|
|
|
|
;===============================
|
|
|
|
;===============================
|
2019-02-18 13:40:45 -05:00
|
|
|
soda:
|
2019-02-17 11:04:16 -05:00
|
|
|
lda #>(soda_bg_rle)
|
2019-01-27 15:30:00 -05:00
|
|
|
sta GBASH
|
2019-02-17 11:04:16 -05:00
|
|
|
lda #<(soda_bg_rle)
|
2019-01-27 15:30:00 -05:00
|
|
|
sta GBASL
|
2019-02-03 00:55:45 -05:00
|
|
|
lda #$c ; load to off-screen $c00
|
2019-01-27 15:30:00 -05:00
|
|
|
jsr load_rle_gr
|
|
|
|
|
2019-02-18 12:18:46 -05:00
|
|
|
bit FULLGR
|
|
|
|
|
2019-02-17 11:04:16 -05:00
|
|
|
lda #<soda_sequence
|
|
|
|
sta INTRO_LOOPL
|
|
|
|
lda #>soda_sequence
|
|
|
|
sta INTRO_LOOPH
|
|
|
|
|
|
|
|
jsr run_sequence
|
|
|
|
|
2019-01-27 15:30:00 -05:00
|
|
|
|
2019-02-18 15:58:58 -05:00
|
|
|
; ldx #30
|
|
|
|
; jsr long_wait
|
|
|
|
|
2019-02-18 13:40:45 -05:00
|
|
|
;open_soda_loop:
|
|
|
|
; lda KEYPRESS
|
|
|
|
; bpl open_soda_loop
|
|
|
|
; bit KEYRESET
|
2019-01-27 00:20:20 -05:00
|
|
|
|
|
|
|
;===============================
|
|
|
|
;===============================
|
|
|
|
; Drinking Soda
|
|
|
|
;===============================
|
|
|
|
;===============================
|
|
|
|
|
2019-02-18 15:58:58 -05:00
|
|
|
lda #>(drinking02_rle)
|
2019-01-27 00:20:20 -05:00
|
|
|
sta GBASH
|
2019-02-18 15:58:58 -05:00
|
|
|
lda #<(drinking02_rle)
|
2019-01-27 00:20:20 -05:00
|
|
|
sta GBASL
|
2019-02-03 00:55:45 -05:00
|
|
|
lda #$c ; load to off-screen $c00
|
2019-01-27 00:20:20 -05:00
|
|
|
jsr load_rle_gr
|
|
|
|
|
2019-02-18 15:58:58 -05:00
|
|
|
lda #<drinking_sequence
|
|
|
|
sta INTRO_LOOPL
|
|
|
|
lda #>drinking_sequence
|
|
|
|
sta INTRO_LOOPH
|
2019-01-27 00:20:20 -05:00
|
|
|
|
2019-02-18 15:58:58 -05:00
|
|
|
jsr run_sequence
|
|
|
|
|
|
|
|
ldx #200
|
|
|
|
jsr long_wait
|
|
|
|
|
|
|
|
;drinking_loop:
|
|
|
|
; lda KEYPRESS
|
|
|
|
; bpl drinking_loop
|
|
|
|
; bit KEYRESET
|
2019-01-26 21:52:00 -05:00
|
|
|
|
2019-03-01 16:31:10 -05:00
|
|
|
|
2019-01-27 12:42:52 -05:00
|
|
|
;===============================
|
|
|
|
;===============================
|
|
|
|
; More crazy screen
|
|
|
|
;===============================
|
|
|
|
;===============================
|
2019-01-26 21:52:00 -05:00
|
|
|
|
2019-02-18 14:31:26 -05:00
|
|
|
lda #>(collider_rle)
|
|
|
|
sta GBASH
|
|
|
|
lda #<(collider_rle)
|
|
|
|
sta GBASL
|
|
|
|
lda #$c ; load to off-screen $c00
|
|
|
|
jsr load_rle_gr
|
|
|
|
|
|
|
|
bit TEXTGR
|
|
|
|
jsr clear_bottoms
|
|
|
|
|
2019-02-15 01:10:17 -05:00
|
|
|
; THE EXPERIMENT WILL BEGIN IN 5 SECONDS
|
2019-02-18 14:31:26 -05:00
|
|
|
jsr gr_copy_to_current_40x40
|
|
|
|
jsr page_flip
|
|
|
|
|
|
|
|
lda #<experiment
|
|
|
|
sta OUTL
|
|
|
|
lda #>experiment
|
|
|
|
sta OUTH
|
|
|
|
jsr print_both_pages
|
|
|
|
|
|
|
|
lda #<five
|
|
|
|
sta OUTL
|
|
|
|
lda #>five
|
|
|
|
sta OUTH
|
|
|
|
jsr print_both_pages
|
|
|
|
|
|
|
|
lda #0
|
|
|
|
sta MESSAGE_COUNT
|
|
|
|
sta MESSAGE_CURRENT
|
|
|
|
sta TIME_COUNT
|
|
|
|
message_loop:
|
2019-02-15 01:10:17 -05:00
|
|
|
|
|
|
|
; Shield 9A.5F Ok
|
|
|
|
; Flux % 5.0177 Ok
|
|
|
|
; CDI Vector ok
|
|
|
|
; %%%ddd ok
|
|
|
|
; Race-Track ok
|
2019-02-18 14:31:26 -05:00
|
|
|
; -----REPEAT ; 10
|
|
|
|
|
|
|
|
ldx MESSAGE_CURRENT
|
|
|
|
lda message_list,X
|
|
|
|
sta OUTL
|
|
|
|
lda message_list+1,X
|
|
|
|
sta OUTH
|
|
|
|
jsr print_both_pages
|
|
|
|
|
|
|
|
inc MESSAGE_CURRENT
|
|
|
|
inc MESSAGE_CURRENT
|
|
|
|
lda MESSAGE_CURRENT
|
|
|
|
cmp #10
|
|
|
|
bne not_ten
|
|
|
|
lda #0
|
|
|
|
sta MESSAGE_CURRENT
|
|
|
|
not_ten:
|
|
|
|
|
2019-02-15 01:10:17 -05:00
|
|
|
; 4 SECONDS
|
|
|
|
; Shield "
|
2019-02-18 14:31:26 -05:00
|
|
|
; -----REPEAT ; 10
|
|
|
|
|
2019-02-15 01:10:17 -05:00
|
|
|
; 3 SECONDS
|
|
|
|
; Sheild "
|
2019-02-18 14:31:26 -05:00
|
|
|
; -----REPEAT ; 10
|
|
|
|
|
|
|
|
; 2 SECONDS ; 10
|
|
|
|
|
|
|
|
; 1 SECONDS (at CDI Vector) ; 10
|
|
|
|
; 0 SECONDS (at %%%) ; 10
|
|
|
|
|
|
|
|
ldx #10
|
|
|
|
jsr long_wait
|
|
|
|
|
|
|
|
inc CURSOR_COUNT
|
|
|
|
|
|
|
|
lda CURSOR_COUNT
|
|
|
|
and #$07
|
|
|
|
bne not_time_oflo
|
|
|
|
|
|
|
|
inc TIME_COUNT
|
|
|
|
inc TIME_COUNT
|
|
|
|
|
|
|
|
; update seconds
|
|
|
|
|
|
|
|
ldx TIME_COUNT
|
|
|
|
lda times,X
|
|
|
|
sta OUTL
|
|
|
|
lda times+1,X
|
|
|
|
sta OUTH
|
|
|
|
jsr print_both_pages
|
|
|
|
|
|
|
|
not_time_oflo:
|
|
|
|
|
|
|
|
lda CURSOR_COUNT
|
|
|
|
cmp #42
|
|
|
|
bne not_time_gone
|
|
|
|
|
|
|
|
; clear out when near end
|
|
|
|
jsr clear_bottoms
|
|
|
|
|
|
|
|
not_time_gone:
|
|
|
|
|
|
|
|
lda CURSOR_COUNT
|
|
|
|
cmp #48
|
|
|
|
bne message_loop
|
|
|
|
|
|
|
|
;=============================
|
2019-02-15 01:10:17 -05:00
|
|
|
; EXPERIMENT LINES GOES AWAY
|
|
|
|
; Stop printing at race track
|
|
|
|
; dark blue going around track
|
|
|
|
|
2019-02-18 14:31:26 -05:00
|
|
|
; Note: goes around at least 4 times
|
2019-01-27 12:42:52 -05:00
|
|
|
|
2019-02-18 14:31:26 -05:00
|
|
|
jsr clear_bottoms
|
|
|
|
|
|
|
|
ldx #30
|
|
|
|
jsr long_wait
|
|
|
|
|
2019-02-24 00:53:41 -05:00
|
|
|
;collider_ui_loop:
|
|
|
|
; lda KEYPRESS
|
|
|
|
; bpl collider_ui_loop
|
|
|
|
; bit KEYRESET
|
|
|
|
|
|
|
|
|
|
|
|
|
2019-02-18 14:31:26 -05:00
|
|
|
; 1 times around? (total = 8)
|
|
|
|
|
|
|
|
lda #0
|
|
|
|
sta PARTICLE_COUNT
|
|
|
|
|
|
|
|
particle_loop2:
|
|
|
|
jsr gr_copy_to_current_40x40
|
|
|
|
jsr plot_particle
|
2019-01-27 12:42:52 -05:00
|
|
|
jsr page_flip
|
2019-02-18 14:31:26 -05:00
|
|
|
ldx #20
|
|
|
|
jsr long_wait
|
2019-01-27 12:42:52 -05:00
|
|
|
|
2019-02-18 14:31:26 -05:00
|
|
|
lda PARTICLE_COUNT
|
|
|
|
cmp #10
|
|
|
|
bne particle_loop2
|
|
|
|
|
|
|
|
|
|
|
|
;collider_ui_loop:
|
|
|
|
; lda KEYPRESS
|
|
|
|
; bpl collider_ui_loop
|
|
|
|
; bit KEYRESET
|
2019-01-27 12:42:52 -05:00
|
|
|
|
2019-03-01 11:53:56 -05:00
|
|
|
|
2019-03-02 12:07:03 -05:00
|
|
|
|
2019-01-27 12:42:52 -05:00
|
|
|
;===============================
|
|
|
|
;===============================
|
|
|
|
; Thunderstorm Outside
|
|
|
|
;===============================
|
|
|
|
;===============================
|
|
|
|
|
2019-03-01 16:31:10 -05:00
|
|
|
|
2019-02-23 15:53:56 -05:00
|
|
|
thunderstorm:
|
2019-03-02 13:37:17 -05:00
|
|
|
|
|
|
|
;==================================
|
|
|
|
; Uncompress the data
|
|
|
|
;==================================
|
|
|
|
lda #<intro8_data_lz4
|
|
|
|
sta LZ4_SRC
|
|
|
|
lda #>intro8_data_lz4
|
|
|
|
sta LZ4_SRC+1
|
|
|
|
|
|
|
|
lda #$90 ; load to $9000
|
|
|
|
|
|
|
|
jsr lz4_decode
|
|
|
|
|
|
|
|
|
2019-02-16 18:00:02 -05:00
|
|
|
lda #>(building_car_rle)
|
2019-02-16 13:54:09 -05:00
|
|
|
sta GBASH
|
2019-02-16 18:00:02 -05:00
|
|
|
lda #<(building_car_rle)
|
2019-02-16 13:54:09 -05:00
|
|
|
sta GBASL
|
|
|
|
lda #$c ; load to off-screen $c00
|
|
|
|
jsr load_rle_gr
|
|
|
|
|
|
|
|
jsr gr_copy_to_current
|
|
|
|
jsr page_flip
|
2019-02-18 14:31:26 -05:00
|
|
|
bit FULLGR
|
2019-02-16 13:54:09 -05:00
|
|
|
|
2019-02-23 15:53:56 -05:00
|
|
|
lda #<lightning_sequence
|
|
|
|
sta INTRO_LOOPL
|
|
|
|
lda #>lightning_sequence
|
|
|
|
sta INTRO_LOOPH
|
2019-02-23 14:59:14 -05:00
|
|
|
|
2019-02-23 15:53:56 -05:00
|
|
|
jsr run_sequence
|
2019-02-23 14:59:14 -05:00
|
|
|
|
2019-02-23 21:37:21 -05:00
|
|
|
lda #<bolt_sequence
|
|
|
|
sta INTRO_LOOPL
|
|
|
|
lda #>bolt_sequence
|
|
|
|
sta INTRO_LOOPH
|
|
|
|
|
|
|
|
jsr run_sequence
|
|
|
|
|
2019-02-24 00:53:41 -05:00
|
|
|
;outside_loop:
|
|
|
|
; lda KEYPRESS
|
|
|
|
; bpl outside_loop
|
|
|
|
; bit KEYRESET
|
2019-02-16 13:54:09 -05:00
|
|
|
|
2019-03-01 16:31:10 -05:00
|
|
|
|
2019-01-27 12:42:52 -05:00
|
|
|
;===============================
|
|
|
|
;===============================
|
|
|
|
; Tunnel 1
|
|
|
|
;===============================
|
|
|
|
;===============================
|
|
|
|
|
2019-02-27 21:57:42 -05:00
|
|
|
tunnel1:
|
2019-03-02 13:37:17 -05:00
|
|
|
|
|
|
|
;==================================
|
|
|
|
; Uncompress the data
|
|
|
|
;==================================
|
|
|
|
lda #<intro9_data_lz4
|
|
|
|
sta LZ4_SRC
|
|
|
|
lda #>intro9_data_lz4
|
|
|
|
sta LZ4_SRC+1
|
|
|
|
|
|
|
|
lda #$90 ; load to $9000
|
|
|
|
|
|
|
|
jsr lz4_decode
|
|
|
|
|
|
|
|
|
2019-01-27 12:42:52 -05:00
|
|
|
lda #>(tunnel1_rle)
|
|
|
|
sta GBASH
|
|
|
|
lda #<(tunnel1_rle)
|
|
|
|
sta GBASL
|
2019-02-03 00:55:45 -05:00
|
|
|
lda #$c ; load to off-screen $c00
|
2019-01-27 12:42:52 -05:00
|
|
|
jsr load_rle_gr
|
|
|
|
|
|
|
|
jsr gr_copy_to_current
|
|
|
|
jsr page_flip
|
|
|
|
|
2019-02-27 21:10:17 -05:00
|
|
|
lda #<tunnel1_sequence
|
|
|
|
sta INTRO_LOOPL
|
|
|
|
lda #>tunnel1_sequence
|
|
|
|
sta INTRO_LOOPH
|
|
|
|
|
|
|
|
jsr run_sequence
|
2019-02-25 00:19:20 -05:00
|
|
|
|
|
|
|
|
2019-02-27 22:25:37 -05:00
|
|
|
;tunnel1_loop:
|
|
|
|
; lda KEYPRESS
|
|
|
|
; bpl tunnel1_loop
|
|
|
|
; bit KEYRESET
|
2019-01-26 21:52:00 -05:00
|
|
|
|
|
|
|
|
|
|
|
|
2019-01-27 00:20:20 -05:00
|
|
|
;===============================
|
|
|
|
;===============================
|
|
|
|
; Tunnel 2
|
|
|
|
;===============================
|
|
|
|
;===============================
|
|
|
|
|
|
|
|
|
|
|
|
;=============================
|
|
|
|
; Load background to $c00
|
|
|
|
|
|
|
|
lda #>(tunnel2_rle)
|
|
|
|
sta GBASH
|
|
|
|
lda #<(tunnel2_rle)
|
|
|
|
sta GBASL
|
2019-02-03 00:55:45 -05:00
|
|
|
lda #$c ; load to off-screen $c00
|
2019-01-27 00:20:20 -05:00
|
|
|
jsr load_rle_gr
|
|
|
|
|
|
|
|
jsr gr_copy_to_current
|
|
|
|
jsr page_flip
|
2019-02-27 22:25:37 -05:00
|
|
|
|
|
|
|
lda #<tunnel2_sequence
|
|
|
|
sta INTRO_LOOPL
|
|
|
|
lda #>tunnel2_sequence
|
|
|
|
sta INTRO_LOOPH
|
|
|
|
|
|
|
|
jsr run_sequence
|
|
|
|
|
2019-01-27 00:20:20 -05:00
|
|
|
|
2019-02-28 20:35:09 -05:00
|
|
|
;tunnel2_loop:
|
|
|
|
; lda KEYPRESS
|
|
|
|
; bpl tunnel2_loop
|
|
|
|
; bit KEYRESET
|
2019-01-27 00:20:20 -05:00
|
|
|
|
|
|
|
|
2019-03-01 16:41:44 -05:00
|
|
|
|
2019-01-27 00:20:20 -05:00
|
|
|
;===============================
|
|
|
|
;===============================
|
|
|
|
; Zappo / Gone
|
|
|
|
;===============================
|
|
|
|
;===============================
|
2019-01-26 21:52:00 -05:00
|
|
|
|
2019-03-01 10:22:12 -05:00
|
|
|
;=========================
|
|
|
|
; zappo
|
|
|
|
|
2019-02-28 20:35:09 -05:00
|
|
|
lda #>(blue_zappo_rle)
|
|
|
|
sta GBASH
|
|
|
|
lda #<(blue_zappo_rle)
|
|
|
|
sta GBASL
|
|
|
|
lda #$c ; load to off-screen $c00
|
|
|
|
jsr load_rle_gr
|
|
|
|
|
2019-03-01 10:22:12 -05:00
|
|
|
jsr gr_copy_to_current
|
|
|
|
jsr page_flip
|
|
|
|
|
2019-02-28 20:35:09 -05:00
|
|
|
lda #<zappo_sequence
|
|
|
|
sta INTRO_LOOPL
|
|
|
|
lda #>zappo_sequence
|
|
|
|
sta INTRO_LOOPH
|
2019-01-26 21:52:00 -05:00
|
|
|
|
2019-03-01 10:22:12 -05:00
|
|
|
jsr run_sequence
|
|
|
|
|
|
|
|
;======================
|
|
|
|
; gone
|
2019-03-02 11:10:41 -05:00
|
|
|
|
2019-01-27 00:20:20 -05:00
|
|
|
lda #>(gone_rle)
|
|
|
|
sta GBASH
|
|
|
|
lda #<(gone_rle)
|
|
|
|
sta GBASL
|
2019-02-03 00:55:45 -05:00
|
|
|
lda #$c ; load to off-screen $c00
|
2019-01-27 00:20:20 -05:00
|
|
|
jsr load_rle_gr
|
|
|
|
|
|
|
|
jsr gr_copy_to_current
|
|
|
|
jsr page_flip
|
2019-03-01 10:22:12 -05:00
|
|
|
|
2019-03-01 11:00:34 -05:00
|
|
|
lda #<gone_sequence
|
2019-03-01 10:22:12 -05:00
|
|
|
sta INTRO_LOOPL
|
2019-03-01 11:00:34 -05:00
|
|
|
lda #>gone_sequence
|
2019-03-01 10:22:12 -05:00
|
|
|
sta INTRO_LOOPH
|
|
|
|
|
2019-03-01 16:41:44 -05:00
|
|
|
|
2019-03-01 10:22:12 -05:00
|
|
|
jsr run_sequence
|
2019-03-02 11:10:41 -05:00
|
|
|
|
2019-01-27 00:20:20 -05:00
|
|
|
gone_loop:
|
|
|
|
lda KEYPRESS
|
|
|
|
bpl gone_loop
|
|
|
|
bit KEYRESET
|
2019-03-01 16:41:44 -05:00
|
|
|
|
2019-01-26 21:52:00 -05:00
|
|
|
|
2019-01-26 21:27:20 -05:00
|
|
|
rts
|
|
|
|
|
2019-03-01 16:31:10 -05:00
|
|
|
|
2019-01-26 21:52:00 -05:00
|
|
|
.include "gr_pageflip.s"
|
|
|
|
.include "gr_unrle.s"
|
2019-03-02 10:02:46 -05:00
|
|
|
.include "lz4_decode.s"
|
2019-01-26 21:52:00 -05:00
|
|
|
.include "gr_copy.s"
|
|
|
|
.include "gr_offsets.s"
|
2019-02-03 00:55:45 -05:00
|
|
|
.include "gr_overlay.s"
|
2019-02-05 23:46:31 -05:00
|
|
|
.include "gr_vlin.s"
|
|
|
|
.include "gr_plot.s"
|
|
|
|
.include "gr_fast_clear.s"
|
2019-02-17 13:37:24 -05:00
|
|
|
.include "gr_putsprite.s"
|
2019-02-16 13:54:09 -05:00
|
|
|
.include "text_print.s"
|
2019-01-26 21:27:20 -05:00
|
|
|
|
2019-02-16 13:54:09 -05:00
|
|
|
|
2019-02-23 14:59:14 -05:00
|
|
|
|
2019-02-03 00:55:45 -05:00
|
|
|
|
2019-03-02 10:02:46 -05:00
|
|
|
;=====================
|
|
|
|
; long(er) wait
|
|
|
|
; waits approximately ?? ms
|
|
|
|
|
|
|
|
long_wait:
|
|
|
|
lda #64
|
|
|
|
jsr WAIT ; delay
|
|
|
|
dex
|
|
|
|
bne long_wait
|
|
|
|
rts
|
|
|
|
|
2019-02-03 12:06:45 -05:00
|
|
|
;=================================
|
|
|
|
; Display a sequence of images
|
|
|
|
|
2019-03-01 16:31:10 -05:00
|
|
|
; pattern is TIME, PTR
|
|
|
|
; if time==0, then done
|
|
|
|
; if time==255, reload $C00 with PTR
|
|
|
|
; if time==0..127 wait TIME, then overlay PTR over $C00
|
|
|
|
; if time==128..254, wait TIME-128, then overlay GBASL over $C00
|
|
|
|
|
2019-02-03 12:06:45 -05:00
|
|
|
run_sequence:
|
|
|
|
ldy #0
|
|
|
|
|
|
|
|
run_sequence_loop:
|
|
|
|
lda (INTRO_LOOPL),Y ; get time
|
2019-03-01 16:31:10 -05:00
|
|
|
beq run_sequence_done ; if zero, then done
|
2019-02-03 12:06:45 -05:00
|
|
|
|
2019-03-01 16:31:10 -05:00
|
|
|
cmp #$ff ; if $ff, then load image to $c00
|
2019-03-01 13:04:21 -05:00
|
|
|
bne not_reload
|
|
|
|
|
2019-03-01 16:31:10 -05:00
|
|
|
reload_image:
|
2019-03-01 13:04:21 -05:00
|
|
|
iny
|
|
|
|
lda (INTRO_LOOPL),Y
|
|
|
|
sta GBASL
|
|
|
|
iny
|
|
|
|
lda (INTRO_LOOPL),Y
|
|
|
|
sta GBASH
|
|
|
|
iny
|
|
|
|
sty INTRO_LOOPER ; save for later
|
|
|
|
lda #$0c ; load to $c00
|
|
|
|
jsr load_rle_gr
|
|
|
|
jmp seq_stuff
|
|
|
|
|
|
|
|
not_reload:
|
|
|
|
tax
|
2019-03-01 16:31:10 -05:00
|
|
|
cmp #$80 ;if negative, no need to load pointer
|
|
|
|
bcs no_set_image_ptr ; bge (branch if greater equal)
|
2019-02-03 12:06:45 -05:00
|
|
|
|
|
|
|
|
2019-03-01 16:31:10 -05:00
|
|
|
get_image_ptr:
|
|
|
|
iny
|
2019-02-03 12:06:45 -05:00
|
|
|
lda (INTRO_LOOPL),Y
|
|
|
|
sta GBASL
|
|
|
|
iny
|
|
|
|
lda (INTRO_LOOPL),Y
|
|
|
|
sta GBASH
|
2019-03-01 16:31:10 -05:00
|
|
|
|
|
|
|
no_set_image_ptr:
|
|
|
|
txa
|
|
|
|
and #$7f
|
|
|
|
tax
|
2019-03-01 22:31:43 -05:00
|
|
|
cpx #1
|
|
|
|
beq seq_no_wait
|
2019-03-01 16:31:10 -05:00
|
|
|
|
|
|
|
jsr long_wait
|
2019-03-01 22:31:43 -05:00
|
|
|
seq_no_wait:
|
2019-03-01 16:31:10 -05:00
|
|
|
|
2019-02-03 12:06:45 -05:00
|
|
|
iny
|
|
|
|
sty INTRO_LOOPER ; save for later
|
|
|
|
lda #$10 ; load to $1000
|
|
|
|
jsr load_rle_gr
|
|
|
|
|
|
|
|
jsr gr_overlay
|
|
|
|
jsr page_flip
|
2019-03-01 13:04:21 -05:00
|
|
|
seq_stuff:
|
2019-02-03 12:06:45 -05:00
|
|
|
ldy INTRO_LOOPER
|
|
|
|
|
|
|
|
jmp run_sequence_loop
|
|
|
|
run_sequence_done:
|
|
|
|
rts
|
|
|
|
|
2019-02-05 23:46:31 -05:00
|
|
|
|
2019-02-18 13:04:02 -05:00
|
|
|
;====================================
|
|
|
|
; Display a sequence of images 40x40
|
|
|
|
|
|
|
|
run_sequence_40x40:
|
|
|
|
ldy #0
|
|
|
|
|
|
|
|
run_sequence_40x40_loop:
|
|
|
|
lda (INTRO_LOOPL),Y ; get time
|
|
|
|
beq run_sequence_40x40_done
|
|
|
|
tax
|
|
|
|
|
|
|
|
jsr long_wait
|
|
|
|
|
|
|
|
iny
|
|
|
|
|
|
|
|
lda (INTRO_LOOPL),Y
|
|
|
|
sta GBASL
|
|
|
|
iny
|
|
|
|
lda (INTRO_LOOPL),Y
|
|
|
|
sta GBASH
|
|
|
|
iny
|
|
|
|
sty INTRO_LOOPER ; save for later
|
|
|
|
lda #$10 ; load to $1000
|
|
|
|
jsr load_rle_gr
|
|
|
|
|
|
|
|
jsr gr_overlay_40x40
|
|
|
|
jsr page_flip
|
|
|
|
ldy INTRO_LOOPER
|
|
|
|
|
|
|
|
jmp run_sequence_40x40_loop
|
|
|
|
run_sequence_40x40_done:
|
|
|
|
rts
|
|
|
|
|
|
|
|
|
2019-02-15 01:10:17 -05:00
|
|
|
;=================================
|
|
|
|
; Display a sequence of images
|
2019-02-17 11:34:47 -05:00
|
|
|
; with /-|/ static overlay
|
2019-02-15 01:10:17 -05:00
|
|
|
|
|
|
|
run_sequence_static:
|
|
|
|
ldy #0 ; init
|
|
|
|
|
|
|
|
run_sequence_static_loop:
|
2019-02-17 14:15:15 -05:00
|
|
|
|
|
|
|
lda (INTRO_LOOPL),Y ; draw DNA
|
|
|
|
sta DNA_OUT
|
|
|
|
iny
|
|
|
|
|
2019-02-15 01:10:17 -05:00
|
|
|
lda (INTRO_LOOPL),Y ; pause for time
|
|
|
|
beq run_sequence_static_done
|
|
|
|
tax
|
2019-02-17 15:13:13 -05:00
|
|
|
|
|
|
|
lda DNA_OUT
|
|
|
|
bne pause_draw_dna
|
|
|
|
|
2019-02-15 01:10:17 -05:00
|
|
|
jsr long_wait
|
2019-02-17 15:13:13 -05:00
|
|
|
jmp done_pause_dna
|
|
|
|
pause_draw_dna:
|
|
|
|
txa
|
|
|
|
pha
|
|
|
|
|
|
|
|
tya
|
|
|
|
pha
|
|
|
|
|
|
|
|
jsr draw_dna
|
|
|
|
jsr page_flip
|
|
|
|
|
|
|
|
pla
|
|
|
|
tay
|
|
|
|
|
|
|
|
pla
|
|
|
|
tax
|
|
|
|
|
|
|
|
lda #250
|
|
|
|
jsr WAIT
|
|
|
|
|
|
|
|
dex
|
|
|
|
bne pause_draw_dna
|
|
|
|
|
|
|
|
done_pause_dna:
|
2019-02-15 01:10:17 -05:00
|
|
|
|
|
|
|
iny ; point to overlay
|
|
|
|
|
2019-02-17 15:13:13 -05:00
|
|
|
lda #10 ; set up static loop
|
2019-02-15 01:10:17 -05:00
|
|
|
sta STATIC_LOOPER
|
|
|
|
|
2019-02-17 14:15:15 -05:00
|
|
|
sty INTRO_LOOPER ; save for later
|
2019-02-15 01:10:17 -05:00
|
|
|
|
|
|
|
static_loop:
|
|
|
|
|
|
|
|
lda (INTRO_LOOPL),Y
|
|
|
|
sta GBASL
|
|
|
|
iny
|
|
|
|
lda (INTRO_LOOPL),Y
|
|
|
|
sta GBASH
|
|
|
|
|
|
|
|
lda #$10 ; load to $1000
|
|
|
|
jsr load_rle_gr
|
|
|
|
|
2019-02-17 11:34:47 -05:00
|
|
|
jsr gr_overlay_40x40
|
2019-02-15 01:10:17 -05:00
|
|
|
|
|
|
|
ldy STATIC_LOOPER
|
|
|
|
lda static_pattern,Y
|
|
|
|
sta GBASL
|
|
|
|
lda static_pattern+1,Y
|
|
|
|
sta GBASH
|
|
|
|
|
|
|
|
lda #$10 ; load to $1000
|
|
|
|
jsr load_rle_gr
|
|
|
|
|
|
|
|
|
2019-02-17 11:34:47 -05:00
|
|
|
; force 40x40 overlay
|
2019-02-15 01:10:17 -05:00
|
|
|
|
2019-02-17 11:34:47 -05:00
|
|
|
jsr gr_overlay_40x40_noload
|
2019-02-15 01:10:17 -05:00
|
|
|
|
2019-02-17 14:15:15 -05:00
|
|
|
lda DNA_OUT
|
|
|
|
beq no_dna
|
|
|
|
|
|
|
|
jsr draw_dna
|
|
|
|
|
|
|
|
no_dna:
|
2019-02-15 01:10:17 -05:00
|
|
|
jsr page_flip
|
|
|
|
|
|
|
|
ldy INTRO_LOOPER
|
|
|
|
|
2019-02-16 13:54:09 -05:00
|
|
|
ldx #3
|
2019-02-15 01:10:17 -05:00
|
|
|
jsr long_wait
|
|
|
|
|
|
|
|
dec STATIC_LOOPER
|
|
|
|
dec STATIC_LOOPER
|
|
|
|
|
2019-02-16 13:54:09 -05:00
|
|
|
bpl static_loop
|
2019-02-15 01:10:17 -05:00
|
|
|
|
|
|
|
iny
|
|
|
|
iny
|
|
|
|
|
|
|
|
jmp run_sequence_static_loop
|
|
|
|
run_sequence_static_done:
|
|
|
|
rts
|
2019-03-01 11:53:56 -05:00
|
|
|
|
2019-02-15 01:10:17 -05:00
|
|
|
|
2019-02-05 23:46:31 -05:00
|
|
|
|
|
|
|
|
2019-02-17 13:37:24 -05:00
|
|
|
|
|
|
|
;====================================
|
|
|
|
; Draw DNA
|
|
|
|
;====================================
|
|
|
|
draw_dna:
|
|
|
|
|
|
|
|
lda #0 ; count
|
|
|
|
sta DNA_COUNT
|
|
|
|
|
|
|
|
draw_dna_loop:
|
|
|
|
clc
|
|
|
|
lda DNA_COUNT
|
|
|
|
adc #10
|
|
|
|
sta YPOS
|
|
|
|
|
|
|
|
lda #26
|
|
|
|
sta XPOS
|
|
|
|
|
2019-02-17 14:15:15 -05:00
|
|
|
lda DNA_COUNT ; 0, 4, 8, 12, 16....
|
|
|
|
lsr
|
|
|
|
clc
|
|
|
|
adc DNA_PROGRESS ; 0,2,4,6,8,...
|
|
|
|
|
2019-02-17 13:37:24 -05:00
|
|
|
and #$e
|
|
|
|
tax
|
|
|
|
|
|
|
|
lda dna_list,X
|
|
|
|
sta INL
|
|
|
|
lda dna_list+1,X
|
|
|
|
sta INH
|
|
|
|
|
2019-02-17 14:15:15 -05:00
|
|
|
jsr put_sprite
|
2019-02-17 13:37:24 -05:00
|
|
|
|
|
|
|
lda DNA_COUNT
|
|
|
|
clc
|
|
|
|
adc #4
|
|
|
|
sta DNA_COUNT
|
|
|
|
|
2019-02-18 13:26:10 -05:00
|
|
|
; for DNA_PROGRESS 0,2,4,6,8,10,12 we only want to print
|
|
|
|
; first X lines (gradually fade in)
|
|
|
|
; after that, draw the whole thing
|
|
|
|
|
|
|
|
lda DNA_PROGRESS
|
|
|
|
cmp #14
|
|
|
|
bpl dna_full
|
|
|
|
|
|
|
|
asl
|
|
|
|
cmp DNA_COUNT
|
|
|
|
bpl draw_dna_loop
|
|
|
|
bmi dna_full_done
|
|
|
|
|
|
|
|
dna_full:
|
|
|
|
lda DNA_COUNT
|
2019-02-17 13:37:24 -05:00
|
|
|
cmp #28
|
|
|
|
bne draw_dna_loop
|
|
|
|
|
2019-02-18 13:26:10 -05:00
|
|
|
dna_full_done:
|
|
|
|
|
2019-02-17 14:15:15 -05:00
|
|
|
inc DNA_PROGRESS
|
|
|
|
inc DNA_PROGRESS
|
|
|
|
|
2019-02-17 15:13:13 -05:00
|
|
|
; see if printing message
|
|
|
|
lda DNA_PROGRESS
|
|
|
|
cmp #10
|
|
|
|
bne no_good_message
|
|
|
|
|
|
|
|
lda #<good_evening
|
|
|
|
sta OUTL
|
|
|
|
lda #>good_evening
|
|
|
|
sta OUTH
|
|
|
|
jsr print_both_pages
|
|
|
|
jmp no_ferrari_message
|
|
|
|
|
|
|
|
no_good_message:
|
|
|
|
cmp #$30
|
|
|
|
bne no_ferrari_message
|
|
|
|
|
|
|
|
lda #<ferrari
|
|
|
|
sta OUTL
|
|
|
|
lda #>ferrari
|
|
|
|
sta OUTH
|
|
|
|
jsr print_both_pages
|
|
|
|
jsr print_both_pages
|
|
|
|
|
|
|
|
|
|
|
|
no_ferrari_message:
|
2019-02-17 13:37:24 -05:00
|
|
|
rts
|
|
|
|
|
2019-02-18 12:18:46 -05:00
|
|
|
|
2019-02-18 13:04:02 -05:00
|
|
|
;======================
|
2019-03-01 16:31:10 -05:00
|
|
|
; Plot particle
|
2019-02-18 13:04:02 -05:00
|
|
|
;======================
|
|
|
|
plot_particle:
|
|
|
|
; Xcoord in X
|
|
|
|
; Ycoord in A
|
|
|
|
; color in COLOR
|
|
|
|
|
|
|
|
lda #$22
|
|
|
|
sta COLOR
|
|
|
|
|
|
|
|
lda PARTICLE_COUNT
|
|
|
|
and #7
|
|
|
|
asl
|
|
|
|
tay
|
|
|
|
ldx particles,Y
|
|
|
|
lda particles+1,Y
|
|
|
|
|
|
|
|
jsr plot
|
|
|
|
|
|
|
|
inc PARTICLE_COUNT
|
|
|
|
|
|
|
|
rts
|
|
|
|
|
|
|
|
|
2019-03-02 10:55:32 -05:00
|
|
|
;.include "intro_data.s"
|
|
|
|
|
2019-03-02 13:37:17 -05:00
|
|
|
DATA_LOCATION = $9000
|
2019-03-02 10:55:32 -05:00
|
|
|
|
2019-03-02 11:10:41 -05:00
|
|
|
; intro1,intro2,intro3
|
|
|
|
building_sequence = (DATA_LOCATION+$0840)
|
|
|
|
feet_sequence = (DATA_LOCATION+$12D0)
|
|
|
|
walking_sequence = (DATA_LOCATION+$1A35)
|
|
|
|
walking00_rle = (DATA_LOCATION+$1597)
|
|
|
|
off_elevator_rle = (DATA_LOCATION+$1499)
|
|
|
|
indicators = (DATA_LOCATION+$1A2B)
|
|
|
|
elevator_rle = (DATA_LOCATION+$12EC)
|
2019-03-02 10:55:32 -05:00
|
|
|
|
|
|
|
intro1_data_lz4:
|
|
|
|
.word (intro1_data_lz4_end-intro1_data_lz4)
|
|
|
|
.incbin "intro_data_01.lz4",11
|
|
|
|
intro1_data_lz4_end:
|
2019-03-02 11:19:03 -05:00
|
|
|
|
2019-03-02 11:42:59 -05:00
|
|
|
; intro4,intro5
|
2019-03-02 11:19:03 -05:00
|
|
|
|
|
|
|
opening_sequence = (DATA_LOCATION+$2051)
|
|
|
|
keypad_sequence = (DATA_LOCATION+$1FF6)
|
|
|
|
keypad_rle = (DATA_LOCATION+$0496)
|
|
|
|
approach_sequence = (DATA_LOCATION+$1FE9)
|
|
|
|
scanner_door_rle = (DATA_LOCATION+$0000)
|
|
|
|
|
2019-03-02 11:42:59 -05:00
|
|
|
ferrari = (DATA_LOCATION+$2D4A)
|
|
|
|
good_evening = (DATA_LOCATION+$2D30)
|
|
|
|
dna_list = (DATA_LOCATION+$2D7A)
|
|
|
|
static_pattern = (DATA_LOCATION+$2D24)
|
|
|
|
ai_sequence = (DATA_LOCATION+$2D0E)
|
|
|
|
ai_bg_rle = (DATA_LOCATION+$2747)
|
|
|
|
scanning_sequence = (DATA_LOCATION+$2CF5)
|
|
|
|
scanner_rle = (DATA_LOCATION+$2066)
|
|
|
|
|
2019-03-02 11:19:03 -05:00
|
|
|
intro4_data_lz4:
|
|
|
|
.word (intro4_data_lz4_end-intro4_data_lz4)
|
|
|
|
.incbin "intro_data_04.lz4",11
|
|
|
|
intro4_data_lz4_end:
|
|
|
|
|
2019-03-02 12:07:03 -05:00
|
|
|
; intro6,intro7
|
|
|
|
|
|
|
|
experiment = (DATA_LOCATION+$0D2C)
|
|
|
|
practical_verification = (DATA_LOCATION+$0D0D)
|
|
|
|
result = (DATA_LOCATION+$0CA6)
|
|
|
|
analysis = (DATA_LOCATION+$0C8D)
|
|
|
|
shield_sequence = (DATA_LOCATION+$0D75)
|
|
|
|
phase2 = (DATA_LOCATION+$0C56)
|
|
|
|
phase1 = (DATA_LOCATION+$0C2F)
|
|
|
|
phase0 = (DATA_LOCATION+$0BF5)
|
|
|
|
particles = (DATA_LOCATION+$0D65)
|
|
|
|
theoretical_study = (DATA_LOCATION+$0BD9)
|
|
|
|
collider_rle = (DATA_LOCATION+$06D8)
|
|
|
|
run_blank = (DATA_LOCATION+$0BC6)
|
|
|
|
run_experiment = (DATA_LOCATION+$0BB3)
|
|
|
|
accel_paramaters = (DATA_LOCATION+$0B62)
|
|
|
|
accelerator = (DATA_LOCATION+$09C1)
|
|
|
|
project_23 = (DATA_LOCATION+$09B2)
|
|
|
|
peanut = (DATA_LOCATION+$0955)
|
|
|
|
cursor_sequence = (DATA_LOCATION+$0947)
|
|
|
|
desktop_bg_rle = (DATA_LOCATION+$0242)
|
|
|
|
powerup_sequence = (DATA_LOCATION+$093E)
|
|
|
|
desktop_rle = (DATA_LOCATION+$0000)
|
|
|
|
|
|
|
|
times = (DATA_LOCATION+$0E0C)
|
|
|
|
message_list = (DATA_LOCATION+$0DE4)
|
|
|
|
five = (DATA_LOCATION+$0DEE)
|
|
|
|
drinking_sequence = (DATA_LOCATION+$1C29)
|
|
|
|
drinking02_rle = (DATA_LOCATION+$1705)
|
|
|
|
soda_sequence = (DATA_LOCATION+$1C1A)
|
|
|
|
soda_bg_rle = (DATA_LOCATION+$0E1A)
|
|
|
|
|
|
|
|
|
|
|
|
intro6_data_lz4:
|
|
|
|
.word (intro6_data_lz4_end-intro6_data_lz4)
|
|
|
|
.incbin "intro_data_06.lz4",11
|
|
|
|
intro6_data_lz4_end:
|
|
|
|
|
2019-03-02 13:37:17 -05:00
|
|
|
; intro8
|
|
|
|
|
|
|
|
bolt_sequence = (DATA_LOCATION+$1488)
|
|
|
|
lightning_sequence = (DATA_LOCATION+$13D6)
|
|
|
|
building_car_rle = (DATA_LOCATION+$1259)
|
|
|
|
|
|
|
|
intro8_data_lz4:
|
|
|
|
.word (intro8_data_lz4_end-intro8_data_lz4)
|
|
|
|
.incbin "intro_data_08.lz4",11
|
|
|
|
intro8_data_lz4_end:
|
|
|
|
|
|
|
|
; intro9, intro10
|
|
|
|
|
|
|
|
gone_sequence = (DATA_LOCATION+$2C66)
|
|
|
|
gone_rle = (DATA_LOCATION+$2039)
|
|
|
|
zappo_sequence = (DATA_LOCATION+$2C1B)
|
|
|
|
blue_zappo_rle = (DATA_LOCATION+$1737)
|
|
|
|
tunnel2_sequence = (DATA_LOCATION+$1718)
|
|
|
|
tunnel2_rle = (DATA_LOCATION+$0B0F)
|
|
|
|
tunnel1_sequence = (DATA_LOCATION+$16F2)
|
|
|
|
tunnel1_rle = (DATA_LOCATION+$0000)
|
|
|
|
|
|
|
|
intro9_data_lz4:
|
|
|
|
.word (intro9_data_lz4_end-intro9_data_lz4)
|
|
|
|
.incbin "intro_data_09.lz4",11
|
|
|
|
intro9_data_lz4_end:
|
|
|
|
|
2019-03-02 11:19:03 -05:00
|
|
|
|
|
|
|
|
|
|
|
|