Merge pull request #145 from Lorenzooone/fix_flicker_no_pp_ow

Fixes flickering when "Not Enough PP!" appears in the overworld
This commit is contained in:
jeffman 2021-10-08 09:49:11 -04:00 committed by GitHub
commit 13ac891abe
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 12 additions and 10 deletions

View File

@ -151,6 +151,9 @@ mov r3,6
.org 0x80B8D22 :: bl psiWindow_buffer .org 0x80B8D22 :: bl psiWindow_buffer
.org 0x80B8E44 :: bl initWindow_buffer .org 0x80B8E44 :: bl initWindow_buffer
.org 0x80B8E62 :: bl baec6_psi_window_print_buffer .org 0x80B8E62 :: bl baec6_psi_window_print_buffer
.org 0x80B8F3E :: bl initWindow_buffer
.org 0x80B8F4E :: bl initWindow_buffer
.org 0x80B8F62 :: bl psiWindow_buffer
.org 0x80B9222 :: bl initWindow_buffer .org 0x80B9222 :: bl initWindow_buffer
.org 0x80B922E :: bl psiTargetWindow_buffer .org 0x80B922E :: bl psiTargetWindow_buffer
.org 0x80B916E :: bl initWindow_buffer .org 0x80B916E :: bl initWindow_buffer

View File

@ -2385,21 +2385,21 @@ pop {pc}
//============================================================================== //==============================================================================
//It sets things up to make it so the target window is only printed once //It sets things up to make it so the target window is only printed once
b8db4_psi_inner_window: b8db4_psi_inner_window:
push {lr} push {r4,lr}
ldrb r1,[r0,#3] mov r4,r0
ldrb r1,[r4,#3]
push {r1} push {r1}
ldrh r1,[r0,#0x36] //Stores the cursor's Y of the window ldrh r1,[r4,#0x36] //Stores the cursor's Y of the window
push {r1} push {r1}
ldrh r1,[r0,#0x34] //Stores the cursor's X of the window ldrh r1,[r4,#0x34] //Stores the cursor's X of the window
push {r1} push {r1}
bl PSITargetWindowInput //Input management, target printing and header printing function. Now the function takes the cursor's Y and X as arguments too in the stack bl PSITargetWindowInput //Input management, target printing and header printing function. Now the function takes the cursor's Y and X as arguments too in the stack
pop {r2} pop {r2}
ldr r3,[r4,0x24] //Target window ldrh r1,[r4,#0x34] //Stores the cursor's X of the window
ldrh r1,[r3,#0x34] //Stores the cursor's X of the window
cmp r1,r2 cmp r1,r2
bne @@store_buffer_first bne @@store_buffer_first
pop {r2} pop {r2}
ldrh r1,[r3,#0x36] //Stores the cursor's Y of the window ldrh r1,[r4,#0x36] //Stores the cursor's Y of the window
cmp r1,r2 cmp r1,r2
bne @@store_buffer_second bne @@store_buffer_second
pop {r2} pop {r2}
@ -2423,11 +2423,10 @@ cmp r0,#0
beq @@ending beq @@ending
mov r2,#0 //Sets vwf_skip to false since the window is changed mov r2,#0 //Sets vwf_skip to false since the window is changed
ldr r1,[r4,0x24] //Target window strb r2,[r4,#3]
strb r2,[r1,#3]
@@ending: @@ending:
pop {pc} pop {r4,pc}
.pool .pool