mirror of
https://gitlab.com/xCrystal/pokecrystal-board.git
synced 2024-09-09 09:51:34 -07:00
Window HUD: Prevent more Window flickering in blocks that disable interrupts (#15)
This commit is contained in:
parent
fd6f02036e
commit
f289d5621d
@ -41,6 +41,18 @@ HDMATransferTilemapAndAttrmap_OverworldEffect::
|
|||||||
call PadTilemapForHDMATransfer
|
call PadTilemapForHDMATransfer
|
||||||
call DelayFrame
|
call DelayFrame
|
||||||
|
|
||||||
|
ldh a, [hWindowHUD]
|
||||||
|
and a
|
||||||
|
jr z, .go
|
||||||
|
; wait until LCD interrupt has ocurred this frame ([rLY] - [hWindowHUD] >= 0)
|
||||||
|
.wait_lcd
|
||||||
|
; ldh a, [hWindowHUD]
|
||||||
|
ld b, a
|
||||||
|
ldh a, [rLY]
|
||||||
|
sub b
|
||||||
|
jr c, .wait_lcd
|
||||||
|
|
||||||
|
.go
|
||||||
; Transfer Attrmap and Tilemap to BG map
|
; Transfer Attrmap and Tilemap to BG map
|
||||||
di
|
di
|
||||||
ldh a, [rVBK]
|
ldh a, [rVBK]
|
||||||
@ -74,6 +86,18 @@ _HDMATransferTilemapAndAttrmap_OpenAndCloseMenu::
|
|||||||
call PadTilemapForHDMATransfer
|
call PadTilemapForHDMATransfer
|
||||||
call DelayFrame
|
call DelayFrame
|
||||||
|
|
||||||
|
ldh a, [hWindowHUD]
|
||||||
|
and a
|
||||||
|
jr z, .go
|
||||||
|
; wait until LCD interrupt has ocurred this frame ([rLY] - [hWindowHUD] >= 0)
|
||||||
|
.wait_lcd
|
||||||
|
; ldh a, [hWindowHUD]
|
||||||
|
ld b, a
|
||||||
|
ldh a, [rLY]
|
||||||
|
sub b
|
||||||
|
jr c, .wait_lcd
|
||||||
|
|
||||||
|
.go
|
||||||
; Transfer Attrmap and Tilemap to BG map
|
; Transfer Attrmap and Tilemap to BG map
|
||||||
di
|
di
|
||||||
ldh a, [rVBK]
|
ldh a, [rVBK]
|
||||||
@ -252,6 +276,18 @@ _continue_HDMATransfer:
|
|||||||
cp d
|
cp d
|
||||||
jr nc, .ly_loop
|
jr nc, .ly_loop
|
||||||
|
|
||||||
|
ldh a, [hWindowHUD]
|
||||||
|
and a
|
||||||
|
jr z, .go
|
||||||
|
; wait until LCD interrupt has ocurred this frame ([rLY] - [hWindowHUD] >= 0)
|
||||||
|
.wait_lcd
|
||||||
|
; ldh a, [hWindowHUD]
|
||||||
|
ld b, a
|
||||||
|
ldh a, [rLY]
|
||||||
|
sub b
|
||||||
|
jr c, .wait_lcd
|
||||||
|
|
||||||
|
.go
|
||||||
di
|
di
|
||||||
; while [rSTAT] & 3: pass
|
; while [rSTAT] & 3: pass
|
||||||
.rstat_loop_1
|
.rstat_loop_1
|
||||||
|
@ -3,7 +3,7 @@ SaveMenu:
|
|||||||
farcall DisplaySaveInfoOnSave
|
farcall DisplaySaveInfoOnSave
|
||||||
call SpeechTextbox2bpp
|
call SpeechTextbox2bpp
|
||||||
call UpdateSprites
|
call UpdateSprites
|
||||||
farcall SaveMenu_CopyTilemapAtOnce
|
farcall CopyTilemapAtOnce
|
||||||
ld hl, WouldYouLikeToSaveTheGameText
|
ld hl, WouldYouLikeToSaveTheGameText
|
||||||
call SaveTheGame_yesorno
|
call SaveTheGame_yesorno
|
||||||
jr nz, .refused
|
jr nz, .refused
|
||||||
@ -18,7 +18,7 @@ SaveMenu:
|
|||||||
|
|
||||||
.refused
|
.refused
|
||||||
call ExitMenu
|
call ExitMenu
|
||||||
farcall SaveMenu_CopyTilemapAtOnce
|
farcall CopyTilemapAtOnce
|
||||||
scf
|
scf
|
||||||
ret
|
ret
|
||||||
|
|
||||||
|
@ -1,80 +0,0 @@
|
|||||||
SaveMenu_CopyTilemapAtOnce:
|
|
||||||
; The following is a modified version of _CopyTilemapAtOnce
|
|
||||||
; that waits for [rLY] to be $60 instead of $80 - 1.
|
|
||||||
ldh a, [hBGMapMode]
|
|
||||||
push af
|
|
||||||
xor a
|
|
||||||
ldh [hBGMapMode], a
|
|
||||||
|
|
||||||
ldh a, [hMapAnims]
|
|
||||||
push af
|
|
||||||
xor a
|
|
||||||
ldh [hMapAnims], a
|
|
||||||
|
|
||||||
.wait
|
|
||||||
ldh a, [rLY]
|
|
||||||
cp $60
|
|
||||||
jr c, .wait
|
|
||||||
|
|
||||||
di
|
|
||||||
ld a, BANK(vBGMap2)
|
|
||||||
ldh [rVBK], a
|
|
||||||
hlcoord 0, 0, wAttrmap
|
|
||||||
call .CopyBGMapViaStack
|
|
||||||
ld a, BANK(vBGMap0)
|
|
||||||
ldh [rVBK], a
|
|
||||||
hlcoord 0, 0
|
|
||||||
call .CopyBGMapViaStack
|
|
||||||
|
|
||||||
.wait2
|
|
||||||
ldh a, [rLY]
|
|
||||||
cp $60
|
|
||||||
jr c, .wait2
|
|
||||||
ei
|
|
||||||
|
|
||||||
pop af
|
|
||||||
ldh [hMapAnims], a
|
|
||||||
pop af
|
|
||||||
ldh [hBGMapMode], a
|
|
||||||
ret
|
|
||||||
|
|
||||||
.CopyBGMapViaStack:
|
|
||||||
; Copy all tiles to vBGMap
|
|
||||||
ld [hSPBuffer], sp
|
|
||||||
ld sp, hl
|
|
||||||
ldh a, [hBGMapAddress + 1]
|
|
||||||
ld h, a
|
|
||||||
ld l, 0
|
|
||||||
ld a, SCREEN_HEIGHT
|
|
||||||
ldh [hTilesPerCycle], a
|
|
||||||
ld b, 1 << rSTAT_BUSY ; not in v/hblank
|
|
||||||
ld c, LOW(rSTAT)
|
|
||||||
|
|
||||||
.loop
|
|
||||||
rept SCREEN_WIDTH / 2
|
|
||||||
pop de
|
|
||||||
; if in v/hblank, wait until not in v/hblank
|
|
||||||
.loop\@
|
|
||||||
ldh a, [c]
|
|
||||||
and b
|
|
||||||
jr nz, .loop\@
|
|
||||||
; load vBGMap
|
|
||||||
ld [hl], e
|
|
||||||
inc l
|
|
||||||
ld [hl], d
|
|
||||||
inc l
|
|
||||||
endr
|
|
||||||
|
|
||||||
ld de, BG_MAP_WIDTH - SCREEN_WIDTH
|
|
||||||
add hl, de
|
|
||||||
ldh a, [hTilesPerCycle]
|
|
||||||
dec a
|
|
||||||
ldh [hTilesPerCycle], a
|
|
||||||
jr nz, .loop
|
|
||||||
|
|
||||||
ldh a, [hSPBuffer]
|
|
||||||
ld l, a
|
|
||||||
ldh a, [hSPBuffer + 1]
|
|
||||||
ld h, a
|
|
||||||
ld sp, hl
|
|
||||||
ret
|
|
@ -559,6 +559,12 @@ Phone_Wait20Frames:
|
|||||||
farcall PhoneRing_CopyTilemapAtOnce
|
farcall PhoneRing_CopyTilemapAtOnce
|
||||||
ret
|
ret
|
||||||
|
|
||||||
|
PhoneRing_CopyTilemapAtOnce:
|
||||||
|
ld a, [wSpriteUpdatesEnabled]
|
||||||
|
and a
|
||||||
|
jp z, WaitBGMap
|
||||||
|
jp CopyTilemapAtOnce
|
||||||
|
|
||||||
Phone_TextboxWithName:
|
Phone_TextboxWithName:
|
||||||
push bc
|
push bc
|
||||||
call Phone_CallerTextbox
|
call Phone_CallerTextbox
|
||||||
|
@ -1,84 +0,0 @@
|
|||||||
PhoneRing_CopyTilemapAtOnce:
|
|
||||||
ld a, [wSpriteUpdatesEnabled]
|
|
||||||
cp $0
|
|
||||||
jp z, WaitBGMap
|
|
||||||
|
|
||||||
; The following is a modified version of _CopyTilemapAtOnce
|
|
||||||
; that waits for [rLY] to be LY_VBLANK - 1 instead of $80 - 1.
|
|
||||||
ldh a, [hBGMapMode]
|
|
||||||
push af
|
|
||||||
xor a
|
|
||||||
ldh [hBGMapMode], a
|
|
||||||
|
|
||||||
ldh a, [hMapAnims]
|
|
||||||
push af
|
|
||||||
xor a
|
|
||||||
ldh [hMapAnims], a
|
|
||||||
|
|
||||||
.wait
|
|
||||||
ldh a, [rLY]
|
|
||||||
cp LY_VBLANK - 1
|
|
||||||
jr c, .wait
|
|
||||||
|
|
||||||
di
|
|
||||||
ld a, BANK(vBGMap2)
|
|
||||||
ldh [rVBK], a
|
|
||||||
hlcoord 0, 0, wAttrmap
|
|
||||||
call .CopyBGMapViaStack
|
|
||||||
ld a, BANK(vBGMap0)
|
|
||||||
ldh [rVBK], a
|
|
||||||
hlcoord 0, 0
|
|
||||||
call .CopyBGMapViaStack
|
|
||||||
|
|
||||||
.wait2
|
|
||||||
ldh a, [rLY]
|
|
||||||
cp LY_VBLANK - 1
|
|
||||||
jr c, .wait2
|
|
||||||
ei
|
|
||||||
|
|
||||||
pop af
|
|
||||||
ldh [hMapAnims], a
|
|
||||||
pop af
|
|
||||||
ldh [hBGMapMode], a
|
|
||||||
ret
|
|
||||||
|
|
||||||
.CopyBGMapViaStack:
|
|
||||||
; Copy all tiles to vBGMap
|
|
||||||
ld [hSPBuffer], sp
|
|
||||||
ld sp, hl
|
|
||||||
ldh a, [hBGMapAddress + 1]
|
|
||||||
ld h, a
|
|
||||||
ld l, 0
|
|
||||||
ld a, SCREEN_HEIGHT
|
|
||||||
ldh [hTilesPerCycle], a
|
|
||||||
ld b, 1 << rSTAT_BUSY ; not in v/hblank
|
|
||||||
ld c, LOW(rSTAT)
|
|
||||||
|
|
||||||
.loop
|
|
||||||
rept SCREEN_WIDTH / 2
|
|
||||||
pop de
|
|
||||||
; if in v/hblank, wait until not in v/hblank
|
|
||||||
.loop\@
|
|
||||||
ldh a, [c]
|
|
||||||
and b
|
|
||||||
jr nz, .loop\@
|
|
||||||
; load vBGMap
|
|
||||||
ld [hl], e
|
|
||||||
inc l
|
|
||||||
ld [hl], d
|
|
||||||
inc l
|
|
||||||
endr
|
|
||||||
|
|
||||||
ld de, BG_MAP_WIDTH - SCREEN_WIDTH
|
|
||||||
add hl, de
|
|
||||||
ldh a, [hTilesPerCycle]
|
|
||||||
dec a
|
|
||||||
ldh [hTilesPerCycle], a
|
|
||||||
jr nz, .loop
|
|
||||||
|
|
||||||
ldh a, [hSPBuffer]
|
|
||||||
ld l, a
|
|
||||||
ldh a, [hSPBuffer + 1]
|
|
||||||
ld h, a
|
|
||||||
ld sp, hl
|
|
||||||
ret
|
|
@ -39,9 +39,6 @@ ApplyTilemap::
|
|||||||
ret
|
ret
|
||||||
|
|
||||||
CopyTilemapAtOnce::
|
CopyTilemapAtOnce::
|
||||||
jr _CopyTilemapAtOnce
|
|
||||||
|
|
||||||
_CopyTilemapAtOnce:
|
|
||||||
ldh a, [hBGMapMode]
|
ldh a, [hBGMapMode]
|
||||||
push af
|
push af
|
||||||
xor a
|
xor a
|
||||||
@ -52,11 +49,26 @@ _CopyTilemapAtOnce:
|
|||||||
xor a
|
xor a
|
||||||
ldh [hMapAnims], a
|
ldh [hMapAnims], a
|
||||||
|
|
||||||
.wait
|
; .wait
|
||||||
ldh a, [rLY]
|
; ldh a, [rLY]
|
||||||
cp $80 - 1
|
; cp $80 - 1
|
||||||
jr c, .wait
|
; jr c, .wait
|
||||||
|
|
||||||
|
call DelayFrame
|
||||||
|
|
||||||
|
ldh a, [hWindowHUD]
|
||||||
|
and a
|
||||||
|
jr z, .go
|
||||||
|
|
||||||
|
; wait until LCD interrupt has ocurred this frame ([rLY] - [hWindowHUD] >= 0)
|
||||||
|
.wait_lcd
|
||||||
|
; ldh a, [hWindowHUD]
|
||||||
|
ld b, a
|
||||||
|
ldh a, [rLY]
|
||||||
|
sub b
|
||||||
|
jr c, .wait_lcd
|
||||||
|
|
||||||
|
.go
|
||||||
di
|
di
|
||||||
ld a, BANK(vBGMap2)
|
ld a, BANK(vBGMap2)
|
||||||
ldh [rVBK], a
|
ldh [rVBK], a
|
||||||
@ -67,10 +79,10 @@ _CopyTilemapAtOnce:
|
|||||||
hlcoord 0, 0
|
hlcoord 0, 0
|
||||||
call .CopyBGMapViaStack
|
call .CopyBGMapViaStack
|
||||||
|
|
||||||
.wait2
|
; .wait2
|
||||||
ldh a, [rLY]
|
; ldh a, [rLY]
|
||||||
cp $80 - 1
|
; cp $80 - 1
|
||||||
jr c, .wait2
|
; jr c, .wait2
|
||||||
ei
|
ei
|
||||||
|
|
||||||
pop af
|
pop af
|
||||||
@ -88,13 +100,13 @@ _CopyTilemapAtOnce:
|
|||||||
ld l, 0
|
ld l, 0
|
||||||
ld a, SCREEN_HEIGHT
|
ld a, SCREEN_HEIGHT
|
||||||
ldh [hTilesPerCycle], a
|
ldh [hTilesPerCycle], a
|
||||||
ld b, 1 << 1 ; not in v/hblank
|
ld b, 1 << rSTAT_BUSY ; not in v/hblank
|
||||||
ld c, LOW(rSTAT)
|
ld c, LOW(rSTAT)
|
||||||
|
|
||||||
.loop
|
.loop
|
||||||
rept SCREEN_WIDTH / 2
|
rept SCREEN_WIDTH / 2
|
||||||
pop de
|
pop de
|
||||||
; if in v/hblank, wait until not in v/hblank
|
; if not in v/hblank, wait until in v/hblank
|
||||||
.loop\@
|
.loop\@
|
||||||
ldh a, [c]
|
ldh a, [c]
|
||||||
and b
|
and b
|
||||||
|
@ -145,10 +145,8 @@ DisableWindowHUD::
|
|||||||
ldh [rLYC], a
|
ldh [rLYC], a
|
||||||
ld a, 1 << rSTAT_INT_HBLANK ; hblank (default)
|
ld a, 1 << rSTAT_INT_HBLANK ; hblank (default)
|
||||||
ldh [rSTAT], a
|
ldh [rSTAT], a
|
||||||
; leave window in default state (enabled and hidden)
|
; leave window in default state (hidden with WY=$90)
|
||||||
|
; rLCDC[rLCDC_WINDOW_ENABLE] will be set during next vblank
|
||||||
ld a, $90
|
ld a, $90
|
||||||
ldh [hWY], a
|
ldh [hWY], a
|
||||||
ldh a, [rLCDC]
|
|
||||||
set rLCDC_WINDOW_ENABLE, a
|
|
||||||
ldh [rLCDC], a
|
|
||||||
ret
|
ret
|
||||||
|
2
main.asm
2
main.asm
@ -186,11 +186,9 @@ INCLUDE "engine/tilesets/map_palettes.asm"
|
|||||||
INCLUDE "gfx/tileset_palette_maps.asm"
|
INCLUDE "gfx/tileset_palette_maps.asm"
|
||||||
INCLUDE "data/collision/collision_permissions.asm"
|
INCLUDE "data/collision/collision_permissions.asm"
|
||||||
INCLUDE "engine/menus/empty_sram.asm"
|
INCLUDE "engine/menus/empty_sram.asm"
|
||||||
INCLUDE "engine/menus/savemenu_copytilemapatonce.asm"
|
|
||||||
INCLUDE "engine/events/checksave.asm"
|
INCLUDE "engine/events/checksave.asm"
|
||||||
INCLUDE "data/maps/scenes.asm"
|
INCLUDE "data/maps/scenes.asm"
|
||||||
INCLUDE "engine/overworld/load_map_part.asm"
|
INCLUDE "engine/overworld/load_map_part.asm"
|
||||||
INCLUDE "engine/phone/phonering_copytilemapatonce.asm"
|
|
||||||
|
|
||||||
|
|
||||||
SECTION "bank13_2", ROMX
|
SECTION "bank13_2", ROMX
|
||||||
|
Loading…
Reference in New Issue
Block a user