mirror of
https://gitlab.com/xCrystal/pokecrystal-board.git
synced 2024-11-16 11:27:33 -08:00
Implement disabled spaces through north/south connections (#33)
This commit is contained in:
parent
7641bb7876
commit
fc6f496254
@ -91,6 +91,7 @@ MACRO connection
|
|||||||
dw wOverworldMapBlocks + _map
|
dw wOverworldMapBlocks + _map
|
||||||
db _len - _src
|
db _len - _src
|
||||||
db \3_WIDTH
|
db \3_WIDTH
|
||||||
|
db \3_HEIGHT
|
||||||
db _y, _x
|
db _y, _x
|
||||||
dw wOverworldMapBlocks + _win
|
dw wOverworldMapBlocks + _win
|
||||||
|
|
||||||
|
@ -373,10 +373,63 @@ BackupDisabledSpace::
|
|||||||
|
|
||||||
LoadDisabledSpaces:
|
LoadDisabledSpaces:
|
||||||
; map setup command (called after the map setup command LoadBlockData)
|
; map setup command (called after the map setup command LoadBlockData)
|
||||||
|
; load blocks with disabled spaces in the active map, and in each of its connected maps.
|
||||||
|
; for connected maps, only blocks that are in visible range from the active map,
|
||||||
|
; i.e. those that appear in wOverworldMapBlocks while in the active map.
|
||||||
ld hl, wMapGroup
|
ld hl, wMapGroup
|
||||||
ld d, [hl]
|
ld d, [hl]
|
||||||
inc hl
|
inc hl
|
||||||
ld e, [hl] ; wMapNumber
|
ld e, [hl] ; wMapNumber
|
||||||
|
xor a ; active map
|
||||||
|
ld [wTempByteValue], a
|
||||||
|
call _LoadDisabledSpaces
|
||||||
|
|
||||||
|
ld hl, wNorthConnectedMapGroup
|
||||||
|
ld a, [hli]
|
||||||
|
cp GROUP_N_A
|
||||||
|
jr z, .south
|
||||||
|
ld d, a ; wNorthConnectedMapGroup
|
||||||
|
ld e, [hl] ; wNorthConnectedMapNumber
|
||||||
|
ld a, 1 ; north connected map
|
||||||
|
ld [wTempByteValue], a
|
||||||
|
call _LoadDisabledSpaces
|
||||||
|
.south
|
||||||
|
|
||||||
|
ld hl, wSouthConnectedMapGroup
|
||||||
|
ld a, [hli]
|
||||||
|
cp GROUP_N_A
|
||||||
|
jr z, .west
|
||||||
|
ld d, a ; wSouthConnectedMapGroup
|
||||||
|
ld e, [hl] ; wSouthConnectedMapNumber
|
||||||
|
ld a, 2 ; south connected map
|
||||||
|
ld [wTempByteValue], a
|
||||||
|
call _LoadDisabledSpaces
|
||||||
|
.west
|
||||||
|
|
||||||
|
ld hl, wWestConnectedMapGroup
|
||||||
|
ld a, [hli]
|
||||||
|
cp GROUP_N_A
|
||||||
|
jr z, .east
|
||||||
|
ld d, a ; wWestConnectedMapGroup
|
||||||
|
ld e, [hl] ; wWestConnectedMapNumber
|
||||||
|
ld a, 3 ; west connected map
|
||||||
|
ld [wTempByteValue], a
|
||||||
|
call _LoadDisabledSpaces
|
||||||
|
.east
|
||||||
|
|
||||||
|
ld hl, wEastConnectedMapGroup
|
||||||
|
ld a, [hli]
|
||||||
|
cp GROUP_N_A
|
||||||
|
jr z, .done
|
||||||
|
ld d, a ; wEastConnectedMapGroup
|
||||||
|
ld e, [hl] ; wEastConnectedMapNumber
|
||||||
|
ld a, 4 ; east connected map
|
||||||
|
ld [wTempByteValue], a
|
||||||
|
call _LoadDisabledSpaces
|
||||||
|
.done
|
||||||
|
ret
|
||||||
|
|
||||||
|
_LoadDisabledSpaces:
|
||||||
ld a, BANK(wDisabledSpacesBackups)
|
ld a, BANK(wDisabledSpacesBackups)
|
||||||
ld [rSVBK], a
|
ld [rSVBK], a
|
||||||
|
|
||||||
@ -404,6 +457,24 @@ LoadDisabledSpaces:
|
|||||||
jr .find_loop
|
jr .find_loop
|
||||||
|
|
||||||
.found_matching_entry
|
.found_matching_entry
|
||||||
|
; temporarily load wMapScriptsBank, wMapSpacesPointer for this map,
|
||||||
|
; so that we can later can call LoadTempSpaceData in the context of this map.
|
||||||
|
ld a, 1
|
||||||
|
ld [rSVBK], a
|
||||||
|
ld a, [wMapGroup]
|
||||||
|
push af
|
||||||
|
ld a, [wMapNumber]
|
||||||
|
push af
|
||||||
|
ld a, d
|
||||||
|
ld [wMapGroup], a
|
||||||
|
ld a, e
|
||||||
|
ld [wMapNumber], a
|
||||||
|
push hl
|
||||||
|
call CopyMapPartialAndAttributesPartial
|
||||||
|
pop hl
|
||||||
|
ld a, BANK(wDisabledSpacesBackups)
|
||||||
|
ld [rSVBK], a
|
||||||
|
|
||||||
; loop through all MAX_SPACES_PER_MAP flags and call .ApplyDisabledSpace in the disabled spaces.
|
; loop through all MAX_SPACES_PER_MAP flags and call .ApplyDisabledSpace in the disabled spaces.
|
||||||
xor a
|
xor a
|
||||||
.apply_loop_2
|
.apply_loop_2
|
||||||
@ -422,6 +493,16 @@ LoadDisabledSpaces:
|
|||||||
jr .apply_loop_1
|
jr .apply_loop_1
|
||||||
|
|
||||||
.done
|
.done
|
||||||
|
ld a, 1
|
||||||
|
ld [rSVBK], a
|
||||||
|
; restore active map attributes
|
||||||
|
pop af
|
||||||
|
ld [wMapNumber], a
|
||||||
|
pop af
|
||||||
|
ld [wMapGroup], a
|
||||||
|
call CopyMapPartialAndAttributesPartial
|
||||||
|
ret
|
||||||
|
|
||||||
.no_match
|
.no_match
|
||||||
ld a, 1
|
ld a, 1
|
||||||
ld [rSVBK], a
|
ld [rSVBK], a
|
||||||
@ -436,6 +517,31 @@ LoadDisabledSpaces:
|
|||||||
ld [rSVBK], a
|
ld [rSVBK], a
|
||||||
ld a, e ; a = space to apply as disabled
|
ld a, e ; a = space to apply as disabled
|
||||||
call LoadTempSpaceData
|
call LoadTempSpaceData
|
||||||
|
ld hl, .return
|
||||||
|
push hl
|
||||||
|
jumptable .Jumptable, wTempByteValue
|
||||||
|
.return
|
||||||
|
jr nc, .connected_block_not_in_range
|
||||||
|
ld a, [hl]
|
||||||
|
and UNIQUE_SPACE_METATILES_MASK
|
||||||
|
add FIRST_GREY_SPACE_METATILE
|
||||||
|
ld [hl], a
|
||||||
|
.connected_block_not_in_range
|
||||||
|
ld a, BANK(wDisabledSpacesBackups)
|
||||||
|
ld [rSVBK], a
|
||||||
|
pop hl
|
||||||
|
pop de
|
||||||
|
pop af
|
||||||
|
ret
|
||||||
|
|
||||||
|
.Jumptable:
|
||||||
|
dw .ActiveMap
|
||||||
|
dw .NorthConnectedMap
|
||||||
|
dw .SouthConnectedMap
|
||||||
|
dw .WestConnectedMap
|
||||||
|
dw .EastConnectedMap
|
||||||
|
|
||||||
|
.ActiveMap:
|
||||||
ld a, [wTempSpaceXCoord]
|
ld a, [wTempSpaceXCoord]
|
||||||
add 4
|
add 4
|
||||||
ld d, a
|
ld d, a
|
||||||
@ -443,13 +549,26 @@ LoadDisabledSpaces:
|
|||||||
add 4
|
add 4
|
||||||
ld e, a
|
ld e, a
|
||||||
call GetBlockLocation
|
call GetBlockLocation
|
||||||
ld a, [hl]
|
scf
|
||||||
and UNIQUE_SPACE_METATILES_MASK
|
ret
|
||||||
add FIRST_GREY_SPACE_METATILE
|
|
||||||
ld [hl], a
|
.NorthConnectedMap:
|
||||||
ld a, BANK(wDisabledSpacesBackups)
|
ld a, [wTempSpaceXCoord]
|
||||||
ld [rSVBK], a
|
ld d, a
|
||||||
pop hl
|
ld a, [wTempSpaceYCoord]
|
||||||
pop de
|
ld e, a
|
||||||
pop af
|
call GetNorthConnectedBlockLocation
|
||||||
|
ret
|
||||||
|
|
||||||
|
.SouthConnectedMap:
|
||||||
|
ld a, [wTempSpaceXCoord]
|
||||||
|
ld d, a
|
||||||
|
ld a, [wTempSpaceYCoord]
|
||||||
|
ld e, a
|
||||||
|
call GetSouthConnectedBlockLocation
|
||||||
|
ret
|
||||||
|
|
||||||
|
.WestConnectedMap:
|
||||||
|
.EastConnectedMap:
|
||||||
|
xor a
|
||||||
ret
|
ret
|
||||||
|
100
home/map.asm
100
home/map.asm
@ -463,6 +463,17 @@ CopyMapPartialAndAttributes::
|
|||||||
call GetMapConnections
|
call GetMapConnections
|
||||||
ret
|
ret
|
||||||
|
|
||||||
|
CopyMapPartialAndAttributesPartial::
|
||||||
|
ld a, [hROMBank]
|
||||||
|
push af
|
||||||
|
call CopyMapPartial
|
||||||
|
call SwitchToMapAttributesBank
|
||||||
|
call GetMapAttributesPointer
|
||||||
|
call CopyMapAttributesPartial
|
||||||
|
pop af
|
||||||
|
rst Bankswitch
|
||||||
|
ret
|
||||||
|
|
||||||
ReadMapEvents::
|
ReadMapEvents::
|
||||||
push af
|
push af
|
||||||
ld hl, wMapEventsPointer
|
ld hl, wMapEventsPointer
|
||||||
@ -503,6 +514,20 @@ CopyMapAttributes::
|
|||||||
jr nz, .loop
|
jr nz, .loop
|
||||||
ret
|
ret
|
||||||
|
|
||||||
|
CopyMapAttributesPartial::
|
||||||
|
; copy only: wMapScriptsBank, wMapScriptsPointer, wMapEventsPointer, wMapSpacesPointer
|
||||||
|
ld bc, wMapScriptsBank - wMapAttributes
|
||||||
|
add hl, bc
|
||||||
|
ld de, wMapScriptsBank
|
||||||
|
ld c, wMapSpacesPointer + $2 - wMapScriptsBank
|
||||||
|
.loop
|
||||||
|
ld a, [hli]
|
||||||
|
ld [de], a
|
||||||
|
inc de
|
||||||
|
dec c
|
||||||
|
jr nz, .loop
|
||||||
|
ret
|
||||||
|
|
||||||
GetMapConnections::
|
GetMapConnections::
|
||||||
ld a, $ff
|
ld a, $ff
|
||||||
ld [wNorthConnectedMapGroup], a
|
ld [wNorthConnectedMapGroup], a
|
||||||
@ -1966,6 +1991,81 @@ GetBlockLocation::
|
|||||||
add hl, bc
|
add hl, bc
|
||||||
ret
|
ret
|
||||||
|
|
||||||
|
GetSouthConnectedBlockLocation::
|
||||||
|
; ycoord / 2 <= 2
|
||||||
|
ld a, e
|
||||||
|
srl a
|
||||||
|
cp 3
|
||||||
|
ret nc
|
||||||
|
; [wSouthConnectionStripLocation]
|
||||||
|
ld hl, wSouthConnectionStripLocation
|
||||||
|
ld a, [hli]
|
||||||
|
ld h, [hl]
|
||||||
|
ld l, a
|
||||||
|
; + (xcoord / 2)
|
||||||
|
srl d
|
||||||
|
ld b, 0
|
||||||
|
ld c, d
|
||||||
|
add hl, bc
|
||||||
|
; + ([wMapWidth] + 6) * ycoord / 2
|
||||||
|
ld a, [wMapWidth]
|
||||||
|
add 6
|
||||||
|
ld c, a
|
||||||
|
ld b, 0
|
||||||
|
srl e
|
||||||
|
ld a, e
|
||||||
|
and a
|
||||||
|
jr z, .done
|
||||||
|
.loop
|
||||||
|
add hl, bc
|
||||||
|
dec a
|
||||||
|
jr nz, .loop
|
||||||
|
.done
|
||||||
|
scf
|
||||||
|
ret ; c
|
||||||
|
|
||||||
|
GetNorthConnectedBlockLocation::
|
||||||
|
; wNorthConnectedMapHeight >= 3
|
||||||
|
; ycoord / 2 >= ([wNorthConnectedMapHeight] - 3)
|
||||||
|
ld a, [wNorthConnectedMapHeight]
|
||||||
|
sub 3
|
||||||
|
jr c, .nope
|
||||||
|
ld c, a
|
||||||
|
ld a, e
|
||||||
|
srl a
|
||||||
|
sub c
|
||||||
|
jr c, .nope
|
||||||
|
ld e, a ; e = ycoord / 2 - ([wNorthConnectedMapHeight] - 3)
|
||||||
|
; [wNorthConnectionStripLocation]
|
||||||
|
ld hl, wNorthConnectionStripLocation
|
||||||
|
ld a, [hli]
|
||||||
|
ld h, [hl]
|
||||||
|
ld l, a
|
||||||
|
; + (xcoord / 2)
|
||||||
|
srl d
|
||||||
|
ld b, 0
|
||||||
|
ld c, d
|
||||||
|
add hl, bc
|
||||||
|
; + ([wMapWidth] + 6) * {ycoord / 2 - ([wNorthConnectedMapHeight] - 3)} --> + ([wMapWidth] + 6) * e
|
||||||
|
ld a, [wMapWidth]
|
||||||
|
add 6
|
||||||
|
ld c, a
|
||||||
|
ld b, 0
|
||||||
|
ld a, e
|
||||||
|
and a
|
||||||
|
jr z, .done
|
||||||
|
.loop
|
||||||
|
add hl, bc
|
||||||
|
dec a
|
||||||
|
jr nz, .loop
|
||||||
|
.done
|
||||||
|
scf
|
||||||
|
ret ; c
|
||||||
|
|
||||||
|
.nope
|
||||||
|
xor a
|
||||||
|
ret ; nc
|
||||||
|
|
||||||
CheckAndApplyAnchorPoint::
|
CheckAndApplyAnchorPoint::
|
||||||
; c = [wCurMapAnchorEventCount] (non-0)
|
; c = [wCurMapAnchorEventCount] (non-0)
|
||||||
; d = [wXCoord]
|
; d = [wXCoord]
|
||||||
|
@ -129,6 +129,7 @@ MACRO map_connection_struct
|
|||||||
\1ConnectionStripLocation:: dw
|
\1ConnectionStripLocation:: dw
|
||||||
\1ConnectionStripLength:: db
|
\1ConnectionStripLength:: db
|
||||||
\1ConnectedMapWidth:: db
|
\1ConnectedMapWidth:: db
|
||||||
|
\1ConnectedMapHeight:: db
|
||||||
\1ConnectionStripYOffset:: db
|
\1ConnectionStripYOffset:: db
|
||||||
\1ConnectionStripXOffset:: db
|
\1ConnectionStripXOffset:: db
|
||||||
\1ConnectionWindow:: dw
|
\1ConnectionWindow:: dw
|
||||||
|
Loading…
Reference in New Issue
Block a user