Fixes flickering when "Not Enough PP!" appears in the overworld

Also makes it so the game doesn't constantly print the PSI window if the cursor is not in the (0,0) position
This commit is contained in:
Lorenzo Carletti 2021-10-08 14:54:05 +02:00
parent 4b0c785811
commit 7ca056d692
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