From e201fe3e51e0eff78dc3688f4a67e8d6dd9604e0 Mon Sep 17 00:00:00 2001 From: jeffman Date: Tue, 17 Sep 2019 00:07:24 -0400 Subject: [PATCH] Add a fade-in delay --- src/m2-hack.asm | 9 +++--- src/m2-title.asm | 80 ++++++++++++++++++++++++++++++++++++++++++++++++ 2 files changed, 85 insertions(+), 4 deletions(-) create mode 100644 src/m2-title.asm diff --git a/src/m2-hack.asm b/src/m2-hack.asm index 5e0ab4e..e494e9b 100644 --- a/src/m2-hack.asm +++ b/src/m2-hack.asm @@ -1553,10 +1553,10 @@ nop .org 0x8011436 :: ldr r2,[r0,r5] .org 0x8011440 :: ldr r2,[r0,r5] - // Replace per-frame functions - .org 0x82D6B7C - dw title_frame_first + 1 - dw title_frame_second + 1 +// Setup hacks: + + // Point to sequence hacks + .org 0x801179C :: dw title_sequence_01 // --- Animation 5 (quick title screen) --- .org 0x82D6BD4 :: dh 0x008A // Enable 8-bit BG0 @@ -1778,5 +1778,6 @@ dw 0x20 :: .incbin "data/m2-title-text-pal-static.c.bin" .include "m2-customcodes.asm" .include "m2-compiled.asm" .include "m2-flyover.asm" +.include "m2-title.asm" .close diff --git a/src/m2-title.asm b/src/m2-title.asm new file mode 100644 index 0000000..a748f0c --- /dev/null +++ b/src/m2-title.asm @@ -0,0 +1,80 @@ +// r3 has 2028008 +// [r3+14] has 2028028 +// [2028028+10] has pointer to our palette buffer, 0x200 bytes after which +// we have some free space to use for things +// Let's allocate some variables: +// +0x00: Sequence 01 -- initial delay flag + +//--------------------------------------------------------- +title_return: +ldr r0,=0x8011B8C +mov pc,r0 + +//--------------------------------------------------------- +// r0 = pointer to pointer little struct +title_get_buffer: +push {r1,lr} +ldr r0,[r0] +ldr r1,[r0,0x14] +ldr r0,[r1,0x10] +ldr r1,=0x200 +add r0,r0,r1 +pop {r1,pc} + +//--------------------------------------------------------- +title_sequence_01: + +// EB has a 38 frame delay between starting the music +// and starting the fade-in +push {r0-r1} +mov r0,r3 +bl title_get_buffer + +// Check if we've set our delay flag yet +ldr r1,[r0] +cmp r1,0 +beq @@unset + + @@set: + // Count to 3 like before + ldr r3,[r3] + ldr r0,[r3,4] + cmp r0,2 + bgt @@next_fade + b @@end + @@next_fade: + mov r1,r9 + add r1,0x7C + ldrh r0,[r1] + sub r0,1 + mov r2,0 + strh r0,[r1] + str r2,[r3,4] + ldrh r0,[r1] + cmp r0,0 + beq @@fade_done + b @@end + @@fade_done: + mov r0,2 + mov r4,r10 + str r0,[r4] + b @@end + + @@unset: + // Count to 0x26 before starting the fade-in + ldr r3,[r3] + ldr r1,[r3,4] + cmp r1,0x26 + bge @@unset_start_fade + b @@end + @@unset_start_fade: + mov r1,0 + str r1,[r3,4] + mov r1,1 + str r1,[r0] + +@@end: +pop {r0-r1} +b title_return + +.pool