mirror of
https://github.com/deater/tb1.git
synced 2025-01-04 20:31:37 +00:00
snes: enemies are moving!
problem was I was letting cc65 place the BSS and it was sticking it at $2000 which is reserved for PPU registers
This commit is contained in:
parent
58178b95cd
commit
da4593e688
@ -1,2 +1,2 @@
|
|||||||
.word $e1c ; Complement of checksum
|
.word $e6b2 ; Complement of checksum
|
||||||
.word $f1e3 ; Unsigned 16-bit sum of ROM
|
.word $194d ; Unsigned 16-bit sum of ROM
|
||||||
|
@ -1,5 +1,8 @@
|
|||||||
; Level 1
|
; Level 1
|
||||||
|
|
||||||
|
;; Memory areas
|
||||||
|
extra_sprite = $600
|
||||||
|
|
||||||
;; GAME PARAMETERS
|
;; GAME PARAMETERS
|
||||||
NUM_MISSILES = 2
|
NUM_MISSILES = 2
|
||||||
NUM_ENEMIES = 6
|
NUM_ENEMIES = 6
|
||||||
@ -798,17 +801,7 @@ store_enemy_kind:
|
|||||||
|
|
||||||
; want to store to $200 + (Y*4)
|
; want to store to $200 + (Y*4)
|
||||||
|
|
||||||
; rep #$20 ; set A to 16-bit
|
tyx ; copy Y to X
|
||||||
;.a16
|
|
||||||
|
|
||||||
tyx ; copy Y to A
|
|
||||||
; asl
|
|
||||||
; asl ; multiply by 4
|
|
||||||
; tax ; put in X
|
|
||||||
|
|
||||||
|
|
||||||
; sep #$20 ; set A back to 8-bit
|
|
||||||
;.a8
|
|
||||||
|
|
||||||
; determine enemy _x
|
; determine enemy _x
|
||||||
; if < 0, make random between 2->34
|
; if < 0, make random between 2->34
|
||||||
@ -824,38 +817,28 @@ store_enemy_kind:
|
|||||||
|
|
||||||
store_init_x:
|
store_init_x:
|
||||||
|
|
||||||
sta $200,X ; store x value at $200+(Y*4)
|
sta $200,Y ; store x value at $200+(Y*4)
|
||||||
|
|
||||||
; enemy_y is always 0 by default
|
; enemy_y is always 0 by default
|
||||||
|
|
||||||
inx ; store y value at $201+(Y*4)
|
|
||||||
lda #$0
|
lda #$0
|
||||||
sta $200,X
|
sta $201,Y ; store y value at $201+(Y*4)
|
||||||
|
|
||||||
|
|
||||||
pla ; pull enemy type off stack
|
pla ; pull enemy type off stack
|
||||||
|
|
||||||
inx ; store SPRITE value to $202+(Y*4)
|
sta $202,Y ; store SPRITE value to $202+(Y*4)
|
||||||
sta $200,X
|
|
||||||
|
|
||||||
lda #$24 ; noflip, pal2, priority=2
|
lda #$24 ; noflip, pal2, priority=2
|
||||||
inx
|
sta $203,Y ; store paramaters to $203+(Y*4)
|
||||||
sta $200,X ; store paramaters to $203+(Y*4)
|
|
||||||
|
|
||||||
; X = (Y*4)+3
|
lda #$0
|
||||||
|
sta extra_sprite,Y ; xadd
|
||||||
|
sta extra_sprite+1,Y ; yadd
|
||||||
|
|
||||||
lda #$24
|
lda #2
|
||||||
sta extra_sprite,X ; ymin
|
sta extra_sprite+2,Y ; xmin
|
||||||
inx
|
lda #100
|
||||||
|
sta extra_sprite+3,Y ; xmax
|
||||||
sta extra_sprite,X ; xmin
|
|
||||||
inx
|
|
||||||
|
|
||||||
stz extra_sprite,X ; yadd
|
|
||||||
lda #$2
|
|
||||||
|
|
||||||
inx
|
|
||||||
|
|
||||||
stz extra_sprite,X ; xadd
|
|
||||||
|
|
||||||
|
|
||||||
;===========================================
|
;===========================================
|
||||||
@ -876,13 +859,11 @@ enemy_type_1:
|
|||||||
; movement proportional to level
|
; movement proportional to level
|
||||||
|
|
||||||
lda LEVEL ; xadd = level
|
lda LEVEL ; xadd = level
|
||||||
sta extra_sprite,X
|
sta extra_sprite,Y
|
||||||
|
|
||||||
inx ; point to yadd
|
|
||||||
|
|
||||||
lsr A
|
lsr A
|
||||||
ora #$1
|
ora #$1
|
||||||
sta extra_sprite,X ; yadd = level/2
|
sta extra_sprite+1,y ; yadd = level/2
|
||||||
jmp move_enemies
|
jmp move_enemies
|
||||||
|
|
||||||
enemy_type_2:
|
enemy_type_2:
|
||||||
@ -1063,7 +1044,7 @@ move_enemies:
|
|||||||
; Move Enemies! (first thing, if no new added)
|
; Move Enemies! (first thing, if no new added)
|
||||||
;==============================================
|
;==============================================
|
||||||
|
|
||||||
ldy #$20 ; point to enemies[0]
|
ldy #$80 ; point to enemies[0] (4*$20)
|
||||||
handle_enemies:
|
handle_enemies:
|
||||||
|
|
||||||
jsr is_sprite_active ; set if enemy[y].out
|
jsr is_sprite_active ; set if enemy[y].out
|
||||||
@ -1078,6 +1059,22 @@ handle_enemies:
|
|||||||
;==========================================
|
;==========================================
|
||||||
|
|
||||||
load_enemy_zero_page:
|
load_enemy_zero_page:
|
||||||
|
|
||||||
|
|
||||||
|
lda extra_sprite,Y
|
||||||
|
sta ENEMY_XADD
|
||||||
|
lda extra_sprite+1,Y
|
||||||
|
sta ENEMY_YADD
|
||||||
|
lda extra_sprite+2,Y
|
||||||
|
sta ENEMY_XMIN
|
||||||
|
lda extra_sprite+3,Y
|
||||||
|
sta ENEMY_XMAX
|
||||||
|
|
||||||
|
lda $200,Y
|
||||||
|
sta ENEMY_X
|
||||||
|
lda $201,Y
|
||||||
|
sta ENEMY_Y
|
||||||
|
|
||||||
; ldx #ENEMY_EXPLODING
|
; ldx #ENEMY_EXPLODING
|
||||||
load_to_zero_page:
|
load_to_zero_page:
|
||||||
; iny ; point to exploding
|
; iny ; point to exploding
|
||||||
@ -1106,12 +1103,12 @@ load_to_zero_page:
|
|||||||
;========
|
;========
|
||||||
|
|
||||||
move_enemy_x:
|
move_enemy_x:
|
||||||
; clc
|
clc
|
||||||
; lda ENEMY_X ; X
|
lda ENEMY_X ; X
|
||||||
; adc ENEMY_XADD ; x+=xadd
|
adc ENEMY_XADD ; x+=xadd
|
||||||
; sta ENEMY_X
|
sta ENEMY_X
|
||||||
|
|
||||||
; lsr A
|
lsr A
|
||||||
|
|
||||||
; cmp ENEMY_XMIN ; are we less than xmin?
|
; cmp ENEMY_XMIN ; are we less than xmin?
|
||||||
; bmi switch_dir_enemy_x ; if so, switch direction
|
; bmi switch_dir_enemy_x ; if so, switch direction
|
||||||
@ -1119,18 +1116,18 @@ move_enemy_x:
|
|||||||
; cmp ENEMY_XMAX ; are we greater than xmax?
|
; cmp ENEMY_XMAX ; are we greater than xmax?
|
||||||
; bpl switch_dir_enemy_x ; if so, switch direction
|
; bpl switch_dir_enemy_x ; if so, switch direction
|
||||||
|
|
||||||
; jmp move_enemy_y
|
jmp move_enemy_y
|
||||||
|
|
||||||
|
|
||||||
switch_dir_enemy_x:
|
switch_dir_enemy_x:
|
||||||
|
|
||||||
; switch X direction
|
; switch X direction
|
||||||
|
|
||||||
; lda #$0 ; load zero
|
lda #$0 ; load zero
|
||||||
; sec
|
sec
|
||||||
; sbc ENEMY_XADD ; 0 - ENEMY_XADD
|
sbc ENEMY_XADD ; 0 - ENEMY_XADD
|
||||||
; sta ENEMY_XADD ; store it back out, negated
|
sta ENEMY_XADD ; store it back out, negated
|
||||||
; jmp move_enemy_x ; re-add it in
|
jmp move_enemy_x ; re-add it in
|
||||||
|
|
||||||
;========
|
;========
|
||||||
; Move Y
|
; Move Y
|
||||||
@ -1138,34 +1135,34 @@ switch_dir_enemy_x:
|
|||||||
|
|
||||||
move_enemy_y:
|
move_enemy_y:
|
||||||
|
|
||||||
; lda #$0 ; load in zero
|
lda #$0 ; load in zero
|
||||||
; cmp ENEMY_YADD ; compare to YADD
|
cmp ENEMY_YADD ; compare to YADD
|
||||||
|
|
||||||
; bmi no_y_special_case ; if minus, we have special case
|
bmi no_y_special_case ; if minus, we have special case
|
||||||
|
|
||||||
; inc ENEMY_YADD
|
inc ENEMY_YADD
|
||||||
; bne done_enemy_y
|
bne done_enemy_y
|
||||||
|
|
||||||
; lda #$0
|
lda #$0
|
||||||
; sta ENEMY_XADD
|
sta ENEMY_XADD
|
||||||
; lda #$2
|
lda #$2
|
||||||
; sta ENEMY_YADD
|
sta ENEMY_YADD
|
||||||
|
|
||||||
; increment y
|
; increment y
|
||||||
; is it > 0?
|
; is it > 0?
|
||||||
; if not keep going
|
; if not keep going
|
||||||
; if so, yadd=level*2
|
; if so, yadd=level*2
|
||||||
|
|
||||||
; jmp done_enemy_y
|
jmp done_enemy_y
|
||||||
|
|
||||||
no_y_special_case:
|
no_y_special_case:
|
||||||
; clc
|
clc
|
||||||
; lda ENEMY_Y ; get Y
|
lda ENEMY_Y ; get Y
|
||||||
; adc ENEMY_YADD ; y+=yadd
|
adc ENEMY_YADD ; y+=yadd
|
||||||
; sta ENEMY_Y ; store back out
|
sta ENEMY_Y ; store back out
|
||||||
|
|
||||||
; lsr A
|
lsr A
|
||||||
; lsr A
|
lsr A
|
||||||
|
|
||||||
; cmp #$12 ; is y<=12?
|
; cmp #$12 ; is y<=12?
|
||||||
; bmi done_enemy_y ; if so no need to do anything
|
; bmi done_enemy_y ; if so no need to do anything
|
||||||
@ -1422,6 +1419,25 @@ enemies_xy:
|
|||||||
save_zp_enemy_back:
|
save_zp_enemy_back:
|
||||||
; save zero page copy back to RAM
|
; save zero page copy back to RAM
|
||||||
|
|
||||||
|
lda ENEMY_XADD
|
||||||
|
sta extra_sprite,Y
|
||||||
|
|
||||||
|
lda ENEMY_YADD
|
||||||
|
sta extra_sprite+1,Y
|
||||||
|
|
||||||
|
lda ENEMY_XMIN
|
||||||
|
sta extra_sprite+2,Y
|
||||||
|
|
||||||
|
lda ENEMY_XMAX
|
||||||
|
sta extra_sprite+3,Y
|
||||||
|
|
||||||
|
lda ENEMY_X
|
||||||
|
sta $200,Y
|
||||||
|
|
||||||
|
lda ENEMY_Y
|
||||||
|
sta $201,Y
|
||||||
|
|
||||||
|
|
||||||
; ldx #ENEMY_EXPLODING
|
; ldx #ENEMY_EXPLODING
|
||||||
|
|
||||||
; pla
|
; pla
|
||||||
@ -1445,8 +1461,11 @@ skip_to_next_enemy:
|
|||||||
; pla ; get saved value of Y
|
; pla ; get saved value of Y
|
||||||
|
|
||||||
iny
|
iny
|
||||||
|
iny
|
||||||
|
iny
|
||||||
|
iny
|
||||||
|
|
||||||
cpy #($20+NUM_ENEMIES) ; have we looped through them all?
|
cpy #($80+4*NUM_ENEMIES) ; have we looped through them all?
|
||||||
beq draw_the_boss ; if not, loop
|
beq draw_the_boss ; if not, loop
|
||||||
jmp handle_enemies
|
jmp handle_enemies
|
||||||
|
|
||||||
@ -2612,9 +2631,9 @@ outside:
|
|||||||
;; *********************
|
;; *********************
|
||||||
.bss
|
.bss
|
||||||
|
|
||||||
start_bss:
|
;start_bss:
|
||||||
extra_sprite: .res 256
|
;extra_sprite: .res 256
|
||||||
end_bss:
|
;end_bss:
|
||||||
|
|
||||||
|
|
||||||
;============================================================================
|
;============================================================================
|
||||||
|
Loading…
Reference in New Issue
Block a user