mirror of
https://github.com/Ninjdai1/pokeemerald.git
synced 2025-01-14 15:43:43 +01:00
Merge branch 'master' into battle_engine_v2
This commit is contained in:
commit
897592a8d4
@ -14,7 +14,7 @@ cache:
|
||||
apt: true
|
||||
install:
|
||||
- pushd $HOME
|
||||
- travis_retry wget https://github.com/devkitPro/buildscripts/releases/download/devkitARM_r49/devkitARM_r49-linux.tar.xz
|
||||
- travis_retry wget https://github.com/devkitPro/buildscripts/releases/download/devkitARM_r50/devkitARM_r50-linux.tar.xz
|
||||
- tar xJf devkitARM*.tar.xz
|
||||
- travis_retry git clone https://github.com/pret/agbcc.git
|
||||
- cd agbcc && ./build.sh && ./install.sh $TRAVIS_BUILD_DIR
|
||||
|
@ -1626,11 +1626,11 @@
|
||||
.endm
|
||||
|
||||
.macro switch var:req
|
||||
copyvar 0x8000, \var
|
||||
copyvar VAR_0x8000, \var
|
||||
.endm
|
||||
|
||||
.macro case condition:req, dest:req
|
||||
compare 0x8000, \condition
|
||||
compare VAR_0x8000, \condition
|
||||
goto_if_eq \dest
|
||||
.endm
|
||||
|
||||
@ -1650,13 +1650,13 @@
|
||||
.endm
|
||||
|
||||
.macro giveitem_std item:req, amount=1, function=0
|
||||
setorcopyvar 0x8000, \item
|
||||
setorcopyvar 0x8001, \amount
|
||||
setorcopyvar VAR_0x8000, \item
|
||||
setorcopyvar VAR_0x8001, \amount
|
||||
callstd \function
|
||||
.endm
|
||||
|
||||
.macro givedecoration_std decoration:req
|
||||
setorcopyvar 0x8000, \decoration
|
||||
setorcopyvar VAR_0x8000, \decoration
|
||||
callstd STD_OBTAIN_DECORATION
|
||||
.endm
|
||||
|
||||
|
8438
asm/trainer_card.s
8438
asm/trainer_card.s
File diff suppressed because it is too large
Load Diff
@ -1262,7 +1262,7 @@ VerdanturfTown_PokemonCenter_1F_EventScript_27191E:: @ 827191E
|
||||
lock
|
||||
faceplayer
|
||||
setvar VAR_0x8004, 0
|
||||
specialvar VAR_RESULT, sub_80C2E40
|
||||
specialvar VAR_RESULT, CountPlayerTrainerStars
|
||||
compare VAR_RESULT, 4
|
||||
goto_if_eq OldaleTown_PokemonCenter_1F_EventScript_271A68
|
||||
msgbox gUnknown_082726EB, MSGBOX_YESNO
|
||||
@ -1393,13 +1393,13 @@ OldaleTown_PokemonCenter_1F_Movement_271AD0: @ 8271AD0
|
||||
step_end
|
||||
|
||||
Std_ObtainItem:: @ 8271AD3
|
||||
giveitem VAR_0x8000, 32769
|
||||
giveitem VAR_0x8000, VAR_0x8001
|
||||
copyvar VAR_0x8007, VAR_RESULT
|
||||
call EventScript_271AE3
|
||||
return
|
||||
|
||||
EventScript_271AE3:: @ 8271AE3
|
||||
bufferitemnameplural 1, VAR_0x8000, 32769
|
||||
bufferitemnameplural 1, VAR_0x8000, VAR_0x8001
|
||||
checkitemtype VAR_0x8000
|
||||
call EventScript_271B08
|
||||
compare VAR_0x8007, 1
|
||||
@ -1498,9 +1498,9 @@ Std_FindItem:: @ 8271BFD
|
||||
waitse
|
||||
copyvar VAR_0x8004, VAR_0x8000
|
||||
copyvar VAR_0x8005, VAR_0x8001
|
||||
checkitemspace VAR_0x8000, 32769
|
||||
checkitemspace VAR_0x8000, VAR_0x8001
|
||||
copyvar VAR_0x8007, VAR_RESULT
|
||||
bufferitemnameplural 1, VAR_0x8000, 32769
|
||||
bufferitemnameplural 1, VAR_0x8000, VAR_0x8001
|
||||
checkitemtype VAR_0x8000
|
||||
call EventScript_271B08
|
||||
compare VAR_0x8007, 1
|
||||
@ -1512,7 +1512,7 @@ Std_FindItem:: @ 8271BFD
|
||||
|
||||
EventScript_271C3A:: @ 8271C3A
|
||||
removeobject VAR_LAST_TALKED
|
||||
giveitem VAR_0x8004, 32773
|
||||
giveitem VAR_0x8004, VAR_0x8005
|
||||
specialvar VAR_RESULT, sub_81398C0
|
||||
copyvar VAR_0x8008, VAR_RESULT
|
||||
compare VAR_0x8008, 1
|
||||
@ -1521,7 +1521,7 @@ EventScript_271C3A:: @ 8271C3A
|
||||
call_if_eq EventScript_271C9B
|
||||
waitfanfare
|
||||
waitmessage
|
||||
bufferitemnameplural 1, VAR_0x8004, 32773
|
||||
bufferitemnameplural 1, VAR_0x8004, VAR_0x8005
|
||||
setvar VAR_0x8004, 12
|
||||
special CallBattlePyramidFunction
|
||||
compare VAR_RESULT, 1
|
||||
@ -1534,7 +1534,7 @@ EventScript_271C86:: @ 8271C86
|
||||
return
|
||||
|
||||
EventScript_271C8F:: @ 8271C8F
|
||||
bufferitemnameplural 0, VAR_0x8004, 32773
|
||||
bufferitemnameplural 0, VAR_0x8004, VAR_0x8005
|
||||
message gUnknown_082731A9
|
||||
return
|
||||
|
||||
@ -3379,7 +3379,7 @@ LittlerootTown_ProfessorBirchsLab_EventScript_2737A0:: @ 82737A0
|
||||
MossdeepCity_StevensHouse_EventScript_2737A0:: @ 82737A0
|
||||
Route119_WeatherInstitute_2F_EventScript_2737A0:: @ 82737A0
|
||||
RustboroCity_DevonCorp_2F_EventScript_2737A0:: @ 82737A0
|
||||
bufferboxname 0, 16438
|
||||
bufferboxname 0, VAR_STORAGE_UNKNOWN
|
||||
bufferspeciesname 1, VAR_TEMP_1
|
||||
call_if_unset FLAG_SYS_PC_LANETTE, LittlerootTown_ProfessorBirchsLab_EventScript_2737BB
|
||||
call_if_set FLAG_SYS_PC_LANETTE, LittlerootTown_ProfessorBirchsLab_EventScript_2737E6
|
||||
@ -3394,7 +3394,7 @@ LittlerootTown_ProfessorBirchsLab_EventScript_2737BB:: @ 82737BB
|
||||
|
||||
LittlerootTown_ProfessorBirchsLab_EventScript_2737D4:: @ 82737D4
|
||||
specialvar VAR_RESULT, get_unknown_box_id
|
||||
bufferboxname 2, 32781
|
||||
bufferboxname 2, VAR_RESULT
|
||||
msgbox gText_PkmnBoxSomeonesPCFull, MSGBOX_DEFAULT
|
||||
return
|
||||
|
||||
@ -3407,7 +3407,7 @@ LittlerootTown_ProfessorBirchsLab_EventScript_2737E6:: @ 82737E6
|
||||
|
||||
LittlerootTown_ProfessorBirchsLab_EventScript_2737FF:: @ 82737FF
|
||||
specialvar VAR_RESULT, get_unknown_box_id
|
||||
bufferboxname 2, 32781
|
||||
bufferboxname 2, VAR_RESULT
|
||||
msgbox gText_PkmnBoxLanettesPCFull, MSGBOX_DEFAULT
|
||||
return
|
||||
|
||||
|
@ -157,7 +157,7 @@ LilycoveCity_EventScript_1E2D11:: @ 81E2D11
|
||||
|
||||
LilycoveCity_EventScript_1E2D1A:: @ 81E2D1A
|
||||
lockall
|
||||
specialvar VAR_0x8004, sub_80F8940
|
||||
specialvar VAR_0x8004, CountPlayerContestPaintings
|
||||
switch VAR_0x8004
|
||||
case 0, LilycoveCity_EventScript_1E2D3A
|
||||
msgbox LilycoveCity_Text_1E4571, MSGBOX_DEFAULT
|
||||
|
@ -100,7 +100,7 @@ LilycoveCity_ContestLobby_EventScript_21A314:: @ 821A314
|
||||
return
|
||||
|
||||
LilycoveCity_ContestLobby_EventScript_21A360:: @ 821A360
|
||||
specialvar VAR_0x8004, sub_80F8940
|
||||
specialvar VAR_0x8004, CountPlayerContestPaintings
|
||||
switch VAR_0x8004
|
||||
case 1, LilycoveCity_ContestLobby_EventScript_21A3A2
|
||||
case 2, LilycoveCity_ContestLobby_EventScript_21A3A6
|
||||
|
@ -6,7 +6,7 @@ LilycoveCity_CoveLilyMotel_2F_EventScript_2186D3:: @ 82186D3
|
||||
faceplayer
|
||||
call_if_unset FLAG_TEMP_2, LilycoveCity_CoveLilyMotel_2F_EventScript_2186F9
|
||||
call_if_set FLAG_TEMP_2, LilycoveCity_CoveLilyMotel_2F_EventScript_21870F
|
||||
specialvar VAR_RESULT, sub_80C08E4
|
||||
specialvar VAR_RESULT, HasAllHoennMons
|
||||
compare VAR_RESULT, 1
|
||||
goto_if_eq LilycoveCity_CoveLilyMotel_2F_EventScript_218702
|
||||
release
|
||||
|
@ -92,7 +92,7 @@ LilycoveCity_LilycoveMuseum_2F_Movement_219863: @ 8219863
|
||||
LilycoveCity_LilycoveMuseum_2F_EventScript_219866:: @ 8219866
|
||||
lockall
|
||||
goto_if_set FLAG_RECEIVED_GLASS_ORNAMENT, LilycoveCity_LilycoveMuseum_2F_EventScript_219921
|
||||
specialvar VAR_0x8004, sub_80F8940
|
||||
specialvar VAR_0x8004, CountPlayerContestPaintings
|
||||
switch VAR_0x8004
|
||||
case 1, LilycoveCity_LilycoveMuseum_2F_EventScript_2198BA
|
||||
case 2, LilycoveCity_LilycoveMuseum_2F_EventScript_2198BA
|
||||
|
@ -16,7 +16,7 @@ LittlerootTown_ProfessorBirchsLab_MapScript1_1F9CA1: @ 81F9CA1
|
||||
end
|
||||
|
||||
LittlerootTown_ProfessorBirchsLab_EventScript_1F9CCD:: @ 81F9CCD
|
||||
specialvar VAR_RESULT, sub_80C08E4
|
||||
specialvar VAR_RESULT, HasAllHoennMons
|
||||
compare VAR_RESULT, 1
|
||||
goto_if_eq LittlerootTown_ProfessorBirchsLab_EventScript_1F9CE9
|
||||
setobjectmovementtype 3, 3
|
||||
|
@ -60,7 +60,7 @@ PetalburgCity_Gym_EventScript_204955:: @ 8204955
|
||||
return
|
||||
|
||||
PetalburgCity_Gym_EventScript_20495D:: @ 820495D
|
||||
setorcopyvar 0x8015, 269
|
||||
setorcopyvar VAR_0x8015, 269
|
||||
specialvar VAR_RESULT, IsTrainerReadyForRematch
|
||||
compare VAR_RESULT, 1
|
||||
goto_if_eq PetalburgCity_Gym_EventScript_204985
|
||||
|
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
@ -249,15 +249,3 @@ gUnknown_0862608C:: @ 862608C
|
||||
|
||||
gUnknown_0862609C:: @ 862609C
|
||||
.incbin "data/unknown_jp_62609C.bin"
|
||||
|
||||
gUnknown_08626814:: @ 8626814
|
||||
.incbin "data/pokenav/unk_struct_1.bin"
|
||||
|
||||
gUnknown_086276FC:: @ 86276FC
|
||||
.incbin "data/pokenav/unk_struct_2.bin"
|
||||
|
||||
gUnknown_086285E4:: @ 86285E4
|
||||
.incbin "data/pokenav/unk_struct_3.bin"
|
||||
|
||||
gUnknown_086294CC:: @ 86294CC
|
||||
.incbin "data/pokenav/unk_struct_4.bin"
|
||||
|
@ -148,7 +148,7 @@ gSpecials:: @ 81DBA64
|
||||
def_special sub_80F88E8
|
||||
def_special sub_80F88DC
|
||||
def_special sub_80F8864
|
||||
def_special sub_80F8940
|
||||
def_special CountPlayerContestPaintings
|
||||
def_special ShowContestWinner
|
||||
def_special MauvilleGymSpecial2
|
||||
def_special MauvilleGymSpecial1
|
||||
@ -345,7 +345,7 @@ gSpecials:: @ 81DBA64
|
||||
def_special sub_80B05B4
|
||||
def_special SetPacifidlogTMReceivedDay
|
||||
def_special GetDaysUntilPacifidlogTMAvailable
|
||||
def_special sub_80C08E4
|
||||
def_special HasAllHoennMons
|
||||
def_special MonOTNameMatchesPlayer
|
||||
def_special BufferLottoTicketNumber
|
||||
def_special sub_81653CC
|
||||
@ -481,7 +481,7 @@ gSpecials:: @ 81DBA64
|
||||
def_special sub_813B7D8
|
||||
def_special sub_81C72A4
|
||||
def_special sp106_CreateStartMenu
|
||||
def_special sub_80C2E40
|
||||
def_special CountPlayerTrainerStars
|
||||
def_special sub_813AC7C
|
||||
def_special sub_813ADB8
|
||||
def_special sub_813ADD4
|
||||
|
@ -1,402 +0,0 @@
|
||||
.include "asm/macros.inc"
|
||||
.include "constants/constants.inc"
|
||||
|
||||
.section .rodata
|
||||
|
||||
.macro unk_trainer_card_struct text1, text2, short1, short2, short3, short4
|
||||
.4byte \text1
|
||||
.4byte \text2
|
||||
.2byte \short1
|
||||
.2byte \short2
|
||||
.2byte \short3
|
||||
.2byte \short4
|
||||
.endm
|
||||
|
||||
.align 2
|
||||
gUnknown_0856F018:: @ 856F018
|
||||
.incbin "graphics/trainer_card/stickers_fr.4bpp.lz"
|
||||
|
||||
.align 2
|
||||
gUnknown_0856F18C:: @ 856F18C
|
||||
.incbin "graphics/trainer_card/unknown_56F18C.gbapal"
|
||||
|
||||
.align 2
|
||||
gEmeraldTrainerCard1Star_Pal:: @ 856F1AC
|
||||
.incbin "graphics/trainer_card/one_star.gbapal"
|
||||
|
||||
.align 2
|
||||
gFireRedTrainerCard1Star_Pal:: @ 856F20C
|
||||
.incbin "graphics/trainer_card/one_star_fr.gbapal"
|
||||
|
||||
.align 2
|
||||
gEmeraldTrainerCard2Star_Pal:: @ 856F26C
|
||||
.incbin "graphics/trainer_card/two_stars.gbapal"
|
||||
|
||||
.align 2
|
||||
gFireRedTrainerCard2Star_Pal:: @ 856F2CC
|
||||
.incbin "graphics/trainer_card/two_stars_fr.gbapal"
|
||||
|
||||
.align 2
|
||||
gEmeraldTrainerCard3Star_Pal:: @ 856F32C
|
||||
.incbin "graphics/trainer_card/three_stars.gbapal"
|
||||
|
||||
.align 2
|
||||
gFireRedTrainerCard3Star_Pal:: @ 856F38C
|
||||
.incbin "graphics/trainer_card/three_stars_fr.gbapal"
|
||||
|
||||
.align 2
|
||||
gEmeraldTrainerCard4Star_Pal:: @ 856F3EC
|
||||
.incbin "graphics/trainer_card/four_stars.gbapal"
|
||||
|
||||
.align 2
|
||||
gFireRedTrainerCard4Star_Pal:: @ 856F44C
|
||||
.incbin "graphics/trainer_card/four_stars_fr.gbapal"
|
||||
|
||||
.align 2
|
||||
gUnknown_0856F4AC:: @ 856F4AC
|
||||
.incbin "graphics/trainer_card/female_bg.gbapal"
|
||||
|
||||
.align 2
|
||||
gUnknown_0856F4CC:: @ 856F4CC
|
||||
.incbin "graphics/trainer_card/female_bg_fr.gbapal"
|
||||
|
||||
.align 2
|
||||
gUnknown_0856F4EC:: @ 856F4EC
|
||||
.incbin "graphics/trainer_card/badges.gbapal"
|
||||
|
||||
.align 2
|
||||
gUnknown_0856F50C:: @ 856F50C
|
||||
.incbin "graphics/trainer_card/badges_fr.gbapal"
|
||||
|
||||
.align 2
|
||||
gUnknown_0856F52C:: @ 856F52C
|
||||
.incbin "graphics/trainer_card/gold.gbapal"
|
||||
|
||||
.align 2
|
||||
gUnknown_0856F54C:: @ 856F54C
|
||||
.incbin "graphics/trainer_card/stickers_fr1.gbapal"
|
||||
|
||||
.align 2
|
||||
gUnknown_0856F56C:: @ 856F56C
|
||||
.incbin "graphics/trainer_card/stickers_fr2.gbapal"
|
||||
|
||||
.align 2
|
||||
gUnknown_0856F58C:: @ 856F58C
|
||||
.incbin "graphics/trainer_card/stickers_fr3.gbapal"
|
||||
|
||||
.align 2
|
||||
gUnknown_0856F5AC:: @ 856F5AC
|
||||
.incbin "graphics/trainer_card/stickers_fr4.gbapal"
|
||||
|
||||
.align 2
|
||||
gUnknown_0856F5CC:: @ 856F5CC
|
||||
.incbin "graphics/trainer_card/badges.4bpp.lz"
|
||||
|
||||
.align 2
|
||||
gUnknown_0856F814:: @ 856F814
|
||||
.incbin "graphics/trainer_card/badges_fr.4bpp.lz"
|
||||
|
||||
.align 2
|
||||
gUnknown_0856FAB4:: @ 856FAB4
|
||||
.4byte 0x000025b0, 0x000001d9, 0x000031e2, 0x003011f3
|
||||
|
||||
.align 2
|
||||
gUnknown_0856FAC4:: @ 856FAC4
|
||||
window_template 0x01, 0x02, 0x0f, 0x1b, 0x04, 0x0f, 0x0253
|
||||
window_template 0x01, 0x01, 0x01, 0x1c, 0x12, 0x0f, 0x0001
|
||||
window_template 0x03, 0x13, 0x05, 0x09, 0x0a, 0x08, 0x0150
|
||||
null_window_template
|
||||
|
||||
.align 2
|
||||
gEmeraldTrainerCardStarPals:: @ 856FAE4
|
||||
.4byte gEmeraldTrainerCard0Star_Pal
|
||||
.4byte gEmeraldTrainerCard1Star_Pal
|
||||
.4byte gEmeraldTrainerCard2Star_Pal
|
||||
.4byte gEmeraldTrainerCard3Star_Pal
|
||||
.4byte gEmeraldTrainerCard4Star_Pal
|
||||
|
||||
.align 2
|
||||
gFireRedTrainerCardStarPals:: @ 856FAF8
|
||||
.4byte gFireRedTrainerCard0Star_Pal
|
||||
.4byte gFireRedTrainerCard1Star_Pal
|
||||
.4byte gFireRedTrainerCard2Star_Pal
|
||||
.4byte gFireRedTrainerCard3Star_Pal
|
||||
.4byte gFireRedTrainerCard4Star_Pal
|
||||
|
||||
gUnknown_0856FB0C:: @ 856FB0C
|
||||
.byte 0x00, 0x02, 0x03
|
||||
|
||||
gUnknown_0856FB0F:: @ 856FB0F
|
||||
.byte 0x00, 0x04, 0x05
|
||||
|
||||
gUnknown_0856FB12:: @ 856FB12
|
||||
.byte 0x00, 0x00, 0x00, 0x00, 0x00, 0x00
|
||||
|
||||
gUnknown_0856FB18:: @ 856FB18
|
||||
.byte 0x0d, 0x04, 0x0d, 0x04, 0x01, 0x00, 0x01, 0x00
|
||||
|
||||
gUnknown_0856FB20:: @ 856FB20
|
||||
.byte 0x4e, 0x4f, 0x50, 0x51, 0x3c, 0x3f
|
||||
|
||||
.align 2
|
||||
gUnknown_0856FB28:: @ 856FB28
|
||||
.4byte sub_80C4998
|
||||
.4byte sub_80C49D8
|
||||
.4byte sub_80C4B08
|
||||
.4byte sub_80C4C1C
|
||||
.4byte sub_80C4C84
|
||||
.4byte sub_80C4DB0
|
||||
|
||||
.align 2
|
||||
gUnknown_0856FB40:: @ 856FB40
|
||||
.4byte gUnknown_0856FB0C
|
||||
.4byte gUnknown_0856FB12
|
||||
|
||||
gUnknown_0856FB48:: @ 856FB48
|
||||
.byte 0x71, 0x68
|
||||
|
||||
gUnknown_0856FB4A:: @ 856FB4A
|
||||
.byte 0x81, 0x78
|
||||
|
||||
gUnknown_0856FB4C:: @ 856FB4C
|
||||
.byte 0xfd, 0x02, 0xf0, 0xfd, 0x03, 0xf0, 0xfd, 0x04, 0xff
|
||||
|
||||
gUnknown_0856FB55:: @ 856FB55
|
||||
.byte 0x08, 0x10
|
||||
|
||||
gUnknown_0856FB57:: @ 856FB57
|
||||
.byte 0xd8, 0xd8
|
||||
|
||||
.align 2
|
||||
gUnknown_0856FB5C:: @ 856FB5C
|
||||
.4byte gText_LinkBattles
|
||||
.4byte gText_LinkCableBattles
|
||||
.4byte gText_LinkBattles
|
||||
|
||||
gUnknown_0856FB68:: @ 856FB68
|
||||
.byte 0x05, 0x06, 0x07, 0x08, 0x09, 0x0a
|
||||
|
||||
gUnknown_0856FB6E:: @ 856FB6E
|
||||
.byte 0x00, 0x04, 0x08, 0x0c, 0x10, 0x14
|
||||
|
||||
gUnknown_0856FB74:: @ 856FB74
|
||||
.byte 0x0b, 0x0c, 0x0d, 0x0e
|
||||
|
||||
gUnknown_0856FB78:: @ 856FB78
|
||||
.byte 0x07, 0x07
|
||||
|
||||
.align 2
|
||||
gUnknown_0856FB7C:: @ 856FB7C
|
||||
.incbin "graphics/frontier_pass/map_heads.gbapal"
|
||||
|
||||
.align 2
|
||||
gUnknown_0856FB9C:: @ 856FB9C
|
||||
.incbin "graphics/frontier_pass/map_heads_female.gbapal"
|
||||
|
||||
.align 2
|
||||
gUnknown_0856FBBC:: @ 856FBBC
|
||||
.incbin "graphics/frontier_pass/map_screen.4bpp.lz"
|
||||
|
||||
.align 2
|
||||
gFrontierPassCursor_Gfx:: @ 8570BA8
|
||||
.incbin "graphics/frontier_pass/cursor.4bpp.lz"
|
||||
|
||||
.align 2
|
||||
gUnknown_08570C44:: @ 8570C44
|
||||
.incbin "graphics/frontier_pass/map_heads.4bpp.lz"
|
||||
|
||||
.align 2
|
||||
gFrontierPassMapCursor_Gfx:: @ 8570D00
|
||||
.incbin "graphics/frontier_pass/map_cursor.4bpp.lz"
|
||||
|
||||
.align 2
|
||||
gUnknown_08570E00:: @ 8570E00
|
||||
.incbin "graphics/frontier_pass/map_screen.bin.lz"
|
||||
|
||||
.align 2
|
||||
gUnknown_08571060:: @ 8571060
|
||||
.incbin "graphics/frontier_pass/small_map_and_card.bin.lz"
|
||||
|
||||
.align 2
|
||||
gUnknown_08571298:: @ 8571298
|
||||
.incbin "graphics/frontier_pass/unknown_571298.bin"
|
||||
|
||||
.align 2
|
||||
gUnknown_085712C0:: @ 85712C0
|
||||
.incbin "graphics/frontier_pass/record_frame.bin.lz"
|
||||
|
||||
.align 2
|
||||
gUnknown_085712F8:: @ 85712F8
|
||||
.incbin "graphics/frontier_pass/small_map_and_card_affine.bin.lz"
|
||||
|
||||
gUnknown_085713E0:: @ 85713E0
|
||||
.2byte 0x00d8, 0x0020, 0x00d8, 0x0080
|
||||
|
||||
.align 2
|
||||
gUnknown_085713E8:: @ 85713E8
|
||||
.4byte 0x000011f8, 0x000021e1, 0x00000bd6
|
||||
|
||||
.align 2
|
||||
gUnknown_085713F4:: @ 85713F4
|
||||
.4byte 0x000001f8, 0x000011e1, 0x000021d2
|
||||
|
||||
.align 2
|
||||
gUnknown_08571400:: @ 8571400
|
||||
window_template 0x00, 0x02, 0x03, 0x0c, 0x03, 0x0f, 0x0001
|
||||
window_template 0x00, 0x02, 0x0a, 0x0c, 0x03, 0x0f, 0x0026
|
||||
window_template 0x00, 0x02, 0x0d, 0x0c, 0x04, 0x0f, 0x004b
|
||||
window_template 0x00, 0x00, 0x12, 0x1e, 0x03, 0x0f, 0x007c
|
||||
window_template 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x0000
|
||||
|
||||
.align 2
|
||||
gUnknown_08571428:: @ 8571428
|
||||
window_template 0x00, 0x00, 0x01, 0x0f, 0x05, 0x0f, 0x0001
|
||||
window_template 0x00, 0x14, 0x01, 0x0a, 0x0e, 0x0f, 0x004d
|
||||
window_template 0x00, 0x02, 0x10, 0x1a, 0x04, 0x0f, 0x00da
|
||||
window_template 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x0000
|
||||
|
||||
gUnknown_08571448:: @ 8571448
|
||||
.byte 0x00, 0x02, 0x03
|
||||
|
||||
gUnknown_0857144B:: @ 857144B
|
||||
.byte 0x00, 0x01, 0x09
|
||||
|
||||
gUnknown_0857144E:: @ 857144E
|
||||
.byte 0x00, 0x04, 0x05
|
||||
|
||||
.align 2
|
||||
gUnknown_08571454:: @ 8571454
|
||||
.2byte 0x001c, 0x004c, 0x0084, 0x00dc, 0x0054, 0x0084, 0x0084, 0x00dc, 0x0050, 0x0066, 0x0014, 0x006c, 0x0000, 0x0010, 0x0098, 0x00f0
|
||||
.2byte 0x006c, 0x0086, 0x0014, 0x006c, 0x0018, 0x0030, 0x0014, 0x006c, 0x0032, 0x0042, 0x0014, 0x0024, 0x0042, 0x0052, 0x0020, 0x0030
|
||||
.2byte 0x0032, 0x0042, 0x002c, 0x003c, 0x0042, 0x0052, 0x0038, 0x0048, 0x0032, 0x0042, 0x0044, 0x0054, 0x0042, 0x0052, 0x0050, 0x0060
|
||||
.2byte 0x0032, 0x0042, 0x005c, 0x006c
|
||||
|
||||
.align 2
|
||||
gUnknown_085714BC:: @ 85714BC
|
||||
obj_tiles gFrontierPassCursor_Gfx, 0x100, 0
|
||||
obj_tiles gFrontierPassMapCursor_Gfx, 0x400, 1
|
||||
obj_tiles gFrontierPassMedals_Gfx, 0x380, 2
|
||||
|
||||
.align 2
|
||||
gUnknown_085714D4:: @ 85714D4
|
||||
obj_tiles gUnknown_08570C44, 0x100, 4
|
||||
null_obj_tiles
|
||||
|
||||
.align 2
|
||||
gUnknown_085714E4:: @ 85714E4
|
||||
obj_pal gFrontierPassCursor_Pal, 0
|
||||
obj_pal gFrontierPassMapCursor_Pal, 1
|
||||
obj_pal gFrontierPassMedalsSilver_Pal, 2
|
||||
obj_pal gFrontierPassMedalsGold_Pal, 3
|
||||
obj_pal gUnknown_0856FB7C, 4
|
||||
obj_pal gUnknown_0856FB9C, 5
|
||||
null_obj_pal
|
||||
|
||||
.align 2
|
||||
gSpriteAnim_857151C:: @ 857151C
|
||||
.2byte 0x0000, 0x0000, 0xffff, 0x0000
|
||||
|
||||
.align 2
|
||||
gSpriteAnim_8571524:: @ 8571524
|
||||
.2byte 0x0000, 0x0000, 0xffff, 0x0000
|
||||
|
||||
.align 2
|
||||
gSpriteAnim_857152C:: @ 857152C
|
||||
.2byte 0x0004, 0x0000, 0xffff, 0x0000
|
||||
|
||||
.align 2
|
||||
gSpriteAnim_8571534:: @ 8571534
|
||||
.2byte 0x0008, 0x0000, 0xffff, 0x0000
|
||||
|
||||
.align 2
|
||||
gSpriteAnim_857153C:: @ 857153C
|
||||
.2byte 0x000c, 0x0000, 0xffff, 0x0000
|
||||
|
||||
.align 2
|
||||
gSpriteAnim_8571544:: @ 8571544
|
||||
.2byte 0x0010, 0x0000, 0xffff, 0x0000
|
||||
|
||||
.align 2
|
||||
gSpriteAnim_857154C:: @ 857154C
|
||||
.2byte 0x0014, 0x0000, 0xffff, 0x0000
|
||||
|
||||
.align 2
|
||||
gSpriteAnim_8571554:: @ 8571554
|
||||
.2byte 0x0018, 0x0000, 0xffff, 0x0000
|
||||
|
||||
.align 2
|
||||
gSpriteAnim_857155C:: @ 857155C
|
||||
.2byte 0x0000, 0x002d, 0x0008, 0x002d, 0xfffe, 0x0000
|
||||
|
||||
.align 2
|
||||
gSpriteAnim_8571568:: @ 8571568
|
||||
.2byte 0x0010, 0x002d, 0x0018, 0x002d, 0xfffe, 0x0000
|
||||
|
||||
.align 2
|
||||
gSpriteAnimTable_08571574:: @ 8571574
|
||||
.4byte gSpriteAnim_8571524
|
||||
.4byte gSpriteAnim_857152C
|
||||
|
||||
.align 2
|
||||
gSpriteAnimTable_0857157C:: @ 857157C
|
||||
.4byte gSpriteAnim_8571524
|
||||
.4byte gSpriteAnim_857152C
|
||||
.4byte gSpriteAnim_8571534
|
||||
.4byte gSpriteAnim_857153C
|
||||
.4byte gSpriteAnim_8571544
|
||||
.4byte gSpriteAnim_857154C
|
||||
.4byte gSpriteAnim_8571554
|
||||
|
||||
.align 2
|
||||
gSpriteAnimTable_08571598:: @ 8571598
|
||||
.4byte gSpriteAnim_857155C
|
||||
.4byte gSpriteAnim_8571568
|
||||
|
||||
.align 2
|
||||
gSpriteAffineAnim_085715A0:: @ 85715A0
|
||||
.2byte 0x0100, 0x0100, 0x0000, 0x0000, 0x7fff, 0x0000, 0x0000, 0x0000
|
||||
|
||||
.align 2
|
||||
gSpriteAffineAnimTable_085715B0:: @ 85715B0
|
||||
.4byte gSpriteAffineAnim_085715A0
|
||||
|
||||
.align 2
|
||||
gUnknown_085715B4:: @ 85715B4
|
||||
spr_template 0, 0, gUnknown_0852490C, gSpriteAnimTable_08571574, NULL, gDummySpriteAffineAnimTable, SpriteCallbackDummy
|
||||
spr_template 1, 1, gUnknown_08524934, gSpriteAnimTable_08571598, NULL, gDummySpriteAffineAnimTable, SpriteCallbackDummy
|
||||
|
||||
.align 2
|
||||
gUnknown_085715E4:: @ 85715E4
|
||||
spr_template 2, 2, gUnknown_0852490C, gSpriteAnimTable_0857157C, NULL, gDummySpriteAffineAnimTable, SpriteCallbackDummy
|
||||
|
||||
.align 2
|
||||
gUnknown_085715FC:: @ 85715FC
|
||||
spr_template 4, 4, gUnknown_0852490C, gSpriteAnimTable_08571574, NULL, gDummySpriteAffineAnimTable, nullsub_39
|
||||
|
||||
.align 2
|
||||
gUnknown_08571614:: @ 8571614
|
||||
.4byte gUnknown_085EDA96
|
||||
.4byte gUnknown_085ED932
|
||||
.4byte gUnknown_085ED94D
|
||||
.4byte gUnknown_085ED961
|
||||
.4byte gUnknown_085ED977
|
||||
.4byte gUnknown_085ED993
|
||||
.4byte gUnknown_085ED9AF
|
||||
.4byte gUnknown_085ED9C7
|
||||
.4byte gUnknown_085ED9E5
|
||||
.4byte gUnknown_085EDA02
|
||||
.4byte gUnknown_085EDA21
|
||||
.4byte gUnknown_085EDA3C
|
||||
.4byte gUnknown_085EDA5E
|
||||
.4byte gUnknown_085EDA78
|
||||
.4byte gUnknown_085ED931
|
||||
|
||||
.align 2
|
||||
gUnknown_08571650:: @ 8571650
|
||||
unk_trainer_card_struct gUnknown_085EDAB1, gUnknown_085EDB0F, 0x59, 0x28, 1, 0
|
||||
unk_trainer_card_struct gUnknown_085EDABE, gUnknown_085EDB4E, 0x21, 0x2A, 1, 0
|
||||
unk_trainer_card_struct gUnknown_085EDACA, gUnknown_085EDB8B, 0x78, 0x56, 0, 0
|
||||
unk_trainer_card_struct gUnknown_085EDAD8, gUnknown_085EDBC2, 0x72, 0x3B, 0, 0
|
||||
unk_trainer_card_struct gUnknown_085EDAE5, gUnknown_085EDC00, 0x19, 0x43, 0, 0
|
||||
unk_trainer_card_struct gUnknown_085EDAF4, gUnknown_085EDC45, 0x39, 0x39, 1, 0
|
||||
unk_trainer_card_struct gUnknown_085EDB00, gUnknown_085EDC84, 0x86, 0x29, 1, 0
|
@ -61,7 +61,7 @@ s32 GetBgX(u8 bg);
|
||||
s32 ChangeBgY(u8 bg, s32 value, u8 op);
|
||||
s32 ChangeBgY_ScreenOff(u8 bg, u32 value, u8 op);
|
||||
s32 GetBgY(u8 bg);
|
||||
void SetBgAffine(u8 bg, u32 srcCenterX, u32 srcCenterY, s16 dispCenterX, s16 dispCenterY, s16 scaleX, s16 scaleY, u16 rotationAngle);
|
||||
void SetBgAffine(u8 bg, s32 srcCenterX, s32 srcCenterY, s16 dispCenterX, s16 dispCenterY, s16 scaleX, s16 scaleY, u16 rotationAngle);
|
||||
u8 Unused_AdjustBgMosaic(u8 a1, u8 a2);
|
||||
void SetBgTilemapBuffer(u8 bg, void *tilemap);
|
||||
void UnsetBgTilemapBuffer(u8 bg);
|
||||
|
@ -297,5 +297,6 @@
|
||||
#define VAR_MON_BOX_ID 0x8012
|
||||
#define VAR_MON_BOX_POS 0x8013
|
||||
#define VAR_0x8014 0x8014
|
||||
#define VAR_0x8015 0x8015
|
||||
|
||||
#endif // GUARD_CONSTANTS_VARS_H
|
||||
|
7
include/frontier_pass.h
Normal file
7
include/frontier_pass.h
Normal file
@ -0,0 +1,7 @@
|
||||
#ifndef GUARD_FRONTIER_PASS_H
|
||||
#define GUARD_FRONTIER_PASS_H
|
||||
|
||||
void ShowFrontierPass(void (*callback)(void));
|
||||
void CB2_ReshowFrontierPass(void);
|
||||
|
||||
#endif // GUARD_FRONTIER_PASS_H
|
@ -4851,4 +4851,32 @@ extern const u16 gUnknown_08DC64E8[];
|
||||
extern const u16 gUnknown_08DC64FC[];
|
||||
extern const u16 gUnknown_08DC6510[];
|
||||
|
||||
// Trainer Card.
|
||||
extern const u16 gEmeraldTrainerCard0Star_Pal[];
|
||||
extern const u32 gEmeraldTrainerCard_Gfx[];
|
||||
extern const u16 gFireRedTrainerCard0Star_Pal[];
|
||||
extern const u32 gFireRedTrainerCard_Gfx[];
|
||||
extern const u32 gUnknown_08DD2AE0[];
|
||||
extern const u32 gUnknown_08DD21B0[];
|
||||
extern const u32 gUnknown_08DD2D30[];
|
||||
extern const u32 gUnknown_08DD2010[];
|
||||
extern const u32 gUnknown_08DD2B78[];
|
||||
extern const u32 gUnknown_08DD228C[];
|
||||
extern const u32 gUnknown_08DD2E5C[];
|
||||
extern const u32 gUnknown_08DD1F78[];
|
||||
|
||||
// Frontier Pass
|
||||
extern const u32 gUnknown_08DE08C8[];
|
||||
extern const u32 gUnknown_08DE2084[];
|
||||
extern const u32 gUnknown_08DE3350[];
|
||||
extern const u32 gUnknown_08DE3374[];
|
||||
extern const u32 gUnknown_08DE3060[];
|
||||
extern const u32 gFrontierPassMedals_Gfx[];
|
||||
extern const u16 gUnknown_08DE07C8[][16];
|
||||
extern const u16 gFrontierPassCursor_Pal[];
|
||||
extern const u16 gFrontierPassMedalsGold_Pal[];
|
||||
extern const u16 gFrontierPassMedalsSilver_Pal[];
|
||||
extern const u16 gFrontierPassMapCursor_Pal[];
|
||||
|
||||
|
||||
#endif //GUARD_GRAPHICS_H
|
||||
|
@ -63,8 +63,12 @@ void TintPlttBuffer(u32, s8, s8, s8);
|
||||
void UnfadePlttBuffer(u32);
|
||||
void BeginFastPaletteFade(u8);
|
||||
void BeginHardwarePaletteFade(u8, u8, u8, u8, u8);
|
||||
void BlendPalettes(u32, u8, u16);
|
||||
void BlendPalettes(u32 selectedPalettes, u8 coeff, u16 color);
|
||||
void BlendPalettesUnfaded(u32, u8, u16);
|
||||
void sub_80A2C44(u32 a1, s8 a2, u8 a3, u8 a4, u16 a5, u8 a6, u8 a7);
|
||||
void TintPalette_GrayScale(u16 *palette, u16 count);
|
||||
void TintPalette_GrayScale2(u16 *palette, u16 count);
|
||||
void TintPalette_SepiaTone(u16 *palette, u16 count);
|
||||
void TintPalette_CustomTone(u16 *palette, u16 count, u16 rTone, u16 gTone, u16 bTone);
|
||||
|
||||
#endif // GUARD_PALETTE_H
|
||||
|
@ -41,5 +41,6 @@ u16 GetHoennPokedexCount(u8);
|
||||
u8 CreateDexDisplayMonDataTask(u16 dexNum, u32 trainerId, u32 personality);
|
||||
s8 GetSetPokedexFlag(u16 nationalNum, u8 caseId);
|
||||
u16 CreateMonSpriteFromNationalDexNumber(u16, s16, s16, u16);
|
||||
bool16 HasAllHoennMons(void);
|
||||
|
||||
#endif // GUARD_POKEDEX_H
|
||||
|
@ -25,6 +25,7 @@ struct PokemonStorage
|
||||
|
||||
extern struct PokemonStorage *gPokemonStoragePtr;
|
||||
|
||||
void sub_80C6D80(const u8 *string, void *dst, u8 arg2, u8 arg3, s32 arg4);
|
||||
u8 CountMonsInBox(u8 boxId);
|
||||
s16 GetFirstFreeBoxSpot(u8 boxId);
|
||||
u8 CountPartyAliveNonEggMonsExcept(u8 slotToIgnore);
|
||||
|
@ -4,5 +4,6 @@
|
||||
u16 sub_80F903C(void);
|
||||
void ReducePlayerPartyToSelectedMons(void);
|
||||
void HealPlayerParty(void);
|
||||
u8 CountPlayerContestPaintings(void);
|
||||
|
||||
#endif // GUARD_SCRIPT_POKEMON_UTIL_80F87D8_H
|
||||
|
@ -34,7 +34,7 @@ u8 *StringFill(u8 *dest, u8 c, u16 n);
|
||||
u8 *StringCopyPadded(u8 *dest, const u8 *src, u8 c, u16 n);
|
||||
u8 *StringFillWithTerminator(u8 *dest, u16 n);
|
||||
u8 *StringCopyN_Multibyte(u8 *dest, u8 *src, u32 n);
|
||||
u32 StringLength_Multibyte(u8 *str);
|
||||
u32 StringLength_Multibyte(const u8 *str);
|
||||
u8 *WriteColorChangeControlCode(u8 *dest, u32 colorType, u8 color);
|
||||
bool32 IsStringJapanese(u8 *str);
|
||||
bool32 sub_800924C(u8 *str, s32 n);
|
||||
|
@ -2222,4 +2222,65 @@ extern const u8 gText_PreliminaryResults[];
|
||||
extern const u8 gText_Round2Results[];
|
||||
extern const u8 gText_Var1sVar2Won[];
|
||||
|
||||
#endif //GUARD_STRINGS_H
|
||||
// Trainer Card
|
||||
extern const u8 gText_LinkCableBattles[];
|
||||
extern const u8 gText_LinkBattles[];
|
||||
extern const u8 gText_WaitingTrainerFinishReading[];
|
||||
extern const u8 gText_TrainerCardName[];
|
||||
extern const u8 gText_TrainerCardIDNo[];
|
||||
extern const u8 gText_TrainerCardMoney[];
|
||||
extern const u8 gText_PokedollarVar1[];
|
||||
extern const u8 gText_EmptyString6[];
|
||||
extern const u8 gText_TrainerCardPokedex[];
|
||||
extern const u8 gText_TrainerCardTime[];
|
||||
extern const u8 gText_Colon2[];
|
||||
extern const u8 gText_Var1sTrainerCard[];
|
||||
extern const u8 gText_HallOfFameDebut[];
|
||||
extern const u8 gText_WinsLosses[];
|
||||
extern const u8 gText_PokemonTrades[];
|
||||
extern const u8 gText_BerryCrush[];
|
||||
extern const u8 gText_UnionTradesAndBattles[];
|
||||
extern const u8 gText_Var1DarkGreyShadowLightGrey[];
|
||||
extern const u8 gText_PokeblocksWithFriends[];
|
||||
extern const u8 gText_WonContestsWFriends[];
|
||||
extern const u8 gText_WSlashStraightSlash[];
|
||||
extern const u8 gText_Var1DarkLightGreyBP[];
|
||||
extern const u8 gText_BattleTower[];
|
||||
extern const u8 gText_BattlePtsWon[];
|
||||
|
||||
// Frontier Pass
|
||||
extern const u8 gText_SymbolsEarned[];
|
||||
extern const u8 gText_BattleRecord[];
|
||||
extern const u8 gText_BattlePoints[];
|
||||
extern const u8 gUnknown_085EDA96[];
|
||||
extern const u8 gUnknown_085ED932[];
|
||||
extern const u8 gUnknown_085ED94D[];
|
||||
extern const u8 gUnknown_085ED961[];
|
||||
extern const u8 gUnknown_085ED977[];
|
||||
extern const u8 gUnknown_085ED993[];
|
||||
extern const u8 gUnknown_085ED9AF[];
|
||||
extern const u8 gUnknown_085ED9C7[];
|
||||
extern const u8 gUnknown_085ED9E5[];
|
||||
extern const u8 gUnknown_085EDA02[];
|
||||
extern const u8 gUnknown_085EDA21[];
|
||||
extern const u8 gUnknown_085EDA3C[];
|
||||
extern const u8 gUnknown_085EDA5E[];
|
||||
extern const u8 gUnknown_085EDA78[];
|
||||
extern const u8 gUnknown_085ED931[];
|
||||
extern const u8 gUnknown_085EDAB1[];
|
||||
extern const u8 gUnknown_085EDB0F[];
|
||||
extern const u8 gUnknown_085EDABE[];
|
||||
extern const u8 gUnknown_085EDB4E[];
|
||||
extern const u8 gUnknown_085EDACA[];
|
||||
extern const u8 gUnknown_085EDB8B[];
|
||||
extern const u8 gUnknown_085EDAD8[];
|
||||
extern const u8 gUnknown_085EDBC2[];
|
||||
extern const u8 gUnknown_085EDAE5[];
|
||||
extern const u8 gUnknown_085EDC00[];
|
||||
extern const u8 gUnknown_085EDAF4[];
|
||||
extern const u8 gUnknown_085EDC45[];
|
||||
extern const u8 gUnknown_085EDB00[];
|
||||
extern const u8 gUnknown_085EDC84[];
|
||||
|
||||
|
||||
#endif // GUARD_STRINGS_H
|
||||
|
@ -6,38 +6,47 @@ struct TrainerCard
|
||||
/*0x00*/ u8 gender;
|
||||
/*0x01*/ u8 stars;
|
||||
/*0x02*/ bool8 hasPokedex;
|
||||
/*0x03*/ bool8 var_3;
|
||||
/*0x04*/ bool8 var_4;
|
||||
/*0x05*/ u8 var_5;
|
||||
/*0x06*/ u16 firstHallOfFameA;
|
||||
/*0x08*/ u16 firstHallOfFameB;
|
||||
/*0x0A*/ u16 firstHallOfFameC;
|
||||
/*0x0C*/ u16 pokedexSeen;
|
||||
/*0x03*/ bool8 caughtAllHoenn;
|
||||
/*0x04*/ bool8 hasAllPaintings;
|
||||
/*0x06*/ u16 hofDebutHours;
|
||||
/*0x08*/ u16 hofDebutMinutes;
|
||||
/*0x0A*/ u16 hofDebutSeconds;
|
||||
/*0x0C*/ u16 caughtMonsCount;
|
||||
/*0x0E*/ u16 trainerId;
|
||||
/*0x10*/ u16 playTimeHours;
|
||||
/*0x12*/ u16 playTimeMinutes;
|
||||
/*0x14*/ u16 linkBattleWins;
|
||||
/*0x16*/ u16 linkBattleLosses;
|
||||
/*0x18*/ u16 battleTowerWins;
|
||||
/*0x1A*/ u16 battleTowerLosses;
|
||||
/*0x1A*/ u16 battleTowerStraightWins;
|
||||
/*0x1C*/ u16 contestsWithFriends;
|
||||
/*0x1E*/ u16 pokeblocksWithFriends;
|
||||
/*0x20*/ u16 pokemonTrades;
|
||||
/*0x22*/ u16 var_22;
|
||||
/*0x24*/ u32 money;
|
||||
/*0x28*/ u16 var_28[4];
|
||||
/*0x30*/ u8 playerName[8];
|
||||
/*0x38*/ u8 emeraldAddedUnknownFields[0x54-0x38];
|
||||
/*0x54*/ u16 monSpecies[2];
|
||||
/*0x58*/ u8 emeraldAddedUnknownFields2[0x64-0x58];
|
||||
/*0x30*/ u8 playerName[PLAYER_NAME_LENGTH + 1];
|
||||
/*0x38*/ u8 version;
|
||||
/*0x3A*/ u16 var_3A;
|
||||
/*0x3C*/ u32 berryCrushPoints;
|
||||
/*0x40*/ u32 unionRoomNum;
|
||||
/*0x44*/ u8 filler44[0x8];
|
||||
/*0x4C*/ u8 var_4C;
|
||||
/*0x4D*/ u8 var_4D;
|
||||
/*0x4E*/ u8 var_4E;
|
||||
/*0x4F*/ u8 var_4F;
|
||||
/*0x50*/ u8 var_50[0x4];
|
||||
/*0x54*/ u16 monSpecies[PARTY_SIZE];
|
||||
/*0x60*/ bool16 hasAllSymbols;
|
||||
/*0x62*/ u16 frontierBP;
|
||||
};
|
||||
|
||||
extern struct TrainerCard gTrainerCards[4];
|
||||
|
||||
void sub_80C3120(struct TrainerCard *arg0, u16 *arg1, u8 gameVersion);
|
||||
void TrainerCard_ShowLinkCard(u8 arg0, void (*callback)(void));
|
||||
u32 CountPlayerTrainerStars(void);
|
||||
u8 sub_80C4904(u8 cardId);
|
||||
void CopyTrainerCardData(struct TrainerCard *dst, u16 *src, u8 gameVersion);
|
||||
void ShowPlayerTrainerCard(void (*callback)(void));
|
||||
void ShowTrainerCardInLink(u8 arg0, void (*callback)(void));
|
||||
void TrainerCard_GenerateCardForPlayer(struct TrainerCard *);
|
||||
u8 sub_80C4904(u8);
|
||||
void sub_80C6D80(const u8 *, u8 *, u8, u8, u8);
|
||||
|
||||
#endif // GUARD_TRAINER_CARD_H
|
||||
|
@ -124,7 +124,8 @@ SECTIONS {
|
||||
src/scanline_effect.o(.text);
|
||||
src/option_menu.o(.text);
|
||||
src/pokedex.o(.text);
|
||||
asm/trainer_card.o(.text);
|
||||
src/trainer_card.o(.text);
|
||||
src/frontier_pass.o(.text);
|
||||
src/pokemon_storage_system.o(.text);
|
||||
src/pokemon_icon.o(.text);
|
||||
src/script_movement.o(.text);
|
||||
@ -458,7 +459,8 @@ SECTIONS {
|
||||
src/field_effect.o(.rodata);
|
||||
src/option_menu.o(.rodata);
|
||||
src/pokedex.o(.rodata);
|
||||
data/trainer_card.o(.rodata);
|
||||
src/trainer_card.o(.rodata);
|
||||
src/frontier_pass.o(.rodata);
|
||||
src/pokemon_storage_system.o(.rodata);
|
||||
src/pokemon_icon.o(.rodata);
|
||||
src/fldeff_cut.o(.rodata);
|
||||
|
4
src/bg.c
4
src/bg.c
@ -246,7 +246,7 @@ void SetTextModeAndHideBgs(void)
|
||||
SetGpuReg(REG_OFFSET_DISPCNT, GetGpuReg(REG_OFFSET_DISPCNT) & ~DISPCNT_ALL_BG_AND_MODE_BITS);
|
||||
}
|
||||
|
||||
static void SetBgAffineInternal(u8 bg, u32 srcCenterX, u32 srcCenterY, s16 dispCenterX, s16 dispCenterY, s16 scaleX, s16 scaleY, u16 rotationAngle)
|
||||
static void SetBgAffineInternal(u8 bg, s32 srcCenterX, s32 srcCenterY, s16 dispCenterX, s16 dispCenterY, s16 scaleX, s16 scaleY, u16 rotationAngle)
|
||||
{
|
||||
struct BgAffineSrcData src;
|
||||
struct BgAffineDstData dest;
|
||||
@ -777,7 +777,7 @@ s32 GetBgY(u8 bg)
|
||||
return sGpuBgConfigs2[bg].bg_y;
|
||||
}
|
||||
|
||||
void SetBgAffine(u8 bg, u32 srcCenterX, u32 srcCenterY, s16 dispCenterX, s16 dispCenterY, s16 scaleX, s16 scaleY, u16 rotationAngle)
|
||||
void SetBgAffine(u8 bg, s32 srcCenterX, s32 srcCenterY, s16 dispCenterX, s16 dispCenterY, s16 scaleX, s16 scaleY, u16 rotationAngle)
|
||||
{
|
||||
SetBgAffineInternal(bg, srcCenterX, srcCenterY, dispCenterX, dispCenterY, scaleX, scaleY, rotationAngle);
|
||||
}
|
||||
|
@ -498,7 +498,7 @@ static void sub_80B2C30(u8 taskId)
|
||||
|
||||
for (index = 0; index < GetLinkPlayerCount(); index++)
|
||||
{
|
||||
sub_80C3120(&gTrainerCards[index], gBlockRecvBuffer[index], gLinkPlayers[index].version);
|
||||
CopyTrainerCardData(&gTrainerCards[index], gBlockRecvBuffer[index], gLinkPlayers[index].version);
|
||||
}
|
||||
|
||||
SetSuppressLinkErrorMessage(FALSE);
|
||||
@ -1176,7 +1176,7 @@ static void sub_80B39A4(void)
|
||||
|
||||
void sp02A_crash_sound(void)
|
||||
{
|
||||
TrainerCard_ShowLinkCard(gSpecialVar_0x8006, CB2_ReturnToFieldContinueScriptPlayMapMusic);
|
||||
ShowTrainerCardInLink(gSpecialVar_0x8006, CB2_ReturnToFieldContinueScriptPlayMapMusic);
|
||||
}
|
||||
|
||||
bool32 sub_80B39D4(u8 linkPlayerIndex)
|
||||
|
4857
src/data/battle_frontier/trainer_hill.h
Normal file
4857
src/data/battle_frontier/trainer_hill.h
Normal file
File diff suppressed because it is too large
Load Diff
1709
src/frontier_pass.c
Normal file
1709
src/frontier_pass.c
Normal file
File diff suppressed because it is too large
Load Diff
@ -1599,7 +1599,7 @@ const u32 gUnknown_08DE0644[] = INCBIN_U32("graphics/title_screen/title_screen2.
|
||||
|
||||
// more trainer card stuff
|
||||
|
||||
const u16 gUnknown_08DE07C8[] = INCBIN_U16("graphics/frontier_pass/tiles.gbapal");// size in LoadPalette calls is reported as 0xD0 << 1, which is 0x1A0, but palette is only 0x100 bytes long so it loads garbage as well
|
||||
const u16 gUnknown_08DE07C8[][16] = INCBIN_U16("graphics/frontier_pass/tiles.gbapal");// size in LoadPalette calls is reported as 0xD0 << 1, which is 0x1A0, but palette is only 0x100 bytes long so it loads garbage as well
|
||||
const u32 gUnknown_08DE08C8[] = INCBIN_U32("graphics/frontier_pass/tiles.4bpp.lz");
|
||||
const u32 gUnknown_08DE2084[] = INCBIN_U32("graphics/frontier_pass/tiles2.8bpp.lz");
|
||||
const u32 gUnknown_08DE3060[] = INCBIN_U32("graphics/frontier_pass/tiles.bin.lz");
|
||||
|
106
src/pokedex.c
106
src/pokedex.c
@ -4271,46 +4271,46 @@ s8 GetSetPokedexFlag(u16 nationalDexNo, u8 caseID)
|
||||
retVal = 0;
|
||||
switch (caseID)
|
||||
{
|
||||
case FLAG_GET_SEEN:
|
||||
if (gSaveBlock2Ptr->pokedex.seen[index] & mask)
|
||||
case FLAG_GET_SEEN:
|
||||
if (gSaveBlock2Ptr->pokedex.seen[index] & mask)
|
||||
{
|
||||
if ((gSaveBlock2Ptr->pokedex.seen[index] & mask) == (gSaveBlock1Ptr->seen1[index] & mask)
|
||||
&& (gSaveBlock2Ptr->pokedex.seen[index] & mask) == (gSaveBlock1Ptr->seen2[index] & mask))
|
||||
retVal = 1;
|
||||
else
|
||||
{
|
||||
if ((gSaveBlock2Ptr->pokedex.seen[index] & mask) == (gSaveBlock1Ptr->seen1[index] & mask)
|
||||
&& (gSaveBlock2Ptr->pokedex.seen[index] & mask) == (gSaveBlock1Ptr->seen2[index] & mask))
|
||||
retVal = 1;
|
||||
else
|
||||
{
|
||||
gSaveBlock2Ptr->pokedex.seen[index] &= ~mask;
|
||||
gSaveBlock1Ptr->seen1[index] &= ~mask;
|
||||
gSaveBlock1Ptr->seen2[index] &= ~mask;
|
||||
retVal = 0;
|
||||
}
|
||||
gSaveBlock2Ptr->pokedex.seen[index] &= ~mask;
|
||||
gSaveBlock1Ptr->seen1[index] &= ~mask;
|
||||
gSaveBlock1Ptr->seen2[index] &= ~mask;
|
||||
retVal = 0;
|
||||
}
|
||||
break;
|
||||
case FLAG_GET_CAUGHT:
|
||||
if (gSaveBlock2Ptr->pokedex.owned[index] & mask)
|
||||
}
|
||||
break;
|
||||
case FLAG_GET_CAUGHT:
|
||||
if (gSaveBlock2Ptr->pokedex.owned[index] & mask)
|
||||
{
|
||||
if ((gSaveBlock2Ptr->pokedex.owned[index] & mask) == (gSaveBlock2Ptr->pokedex.seen[index] & mask)
|
||||
&& (gSaveBlock2Ptr->pokedex.owned[index] & mask) == (gSaveBlock1Ptr->seen1[index] & mask)
|
||||
&& (gSaveBlock2Ptr->pokedex.owned[index] & mask) == (gSaveBlock1Ptr->seen2[index] & mask))
|
||||
retVal = 1;
|
||||
else
|
||||
{
|
||||
if ((gSaveBlock2Ptr->pokedex.owned[index] & mask) == (gSaveBlock2Ptr->pokedex.seen[index] & mask)
|
||||
&& (gSaveBlock2Ptr->pokedex.owned[index] & mask) == (gSaveBlock1Ptr->seen1[index] & mask)
|
||||
&& (gSaveBlock2Ptr->pokedex.owned[index] & mask) == (gSaveBlock1Ptr->seen2[index] & mask))
|
||||
retVal = 1;
|
||||
else
|
||||
{
|
||||
gSaveBlock2Ptr->pokedex.owned[index] &= ~mask;
|
||||
gSaveBlock2Ptr->pokedex.seen[index] &= ~mask;
|
||||
gSaveBlock1Ptr->seen1[index] &= ~mask;
|
||||
gSaveBlock1Ptr->seen2[index] &= ~mask;
|
||||
retVal = 0;
|
||||
}
|
||||
gSaveBlock2Ptr->pokedex.owned[index] &= ~mask;
|
||||
gSaveBlock2Ptr->pokedex.seen[index] &= ~mask;
|
||||
gSaveBlock1Ptr->seen1[index] &= ~mask;
|
||||
gSaveBlock1Ptr->seen2[index] &= ~mask;
|
||||
retVal = 0;
|
||||
}
|
||||
break;
|
||||
case FLAG_SET_SEEN:
|
||||
gSaveBlock2Ptr->pokedex.seen[index] |= mask;
|
||||
gSaveBlock1Ptr->seen1[index] |= mask;
|
||||
gSaveBlock1Ptr->seen2[index] |= mask;
|
||||
break;
|
||||
case FLAG_SET_CAUGHT:
|
||||
gSaveBlock2Ptr->pokedex.owned[index] |= mask;
|
||||
break;
|
||||
}
|
||||
break;
|
||||
case FLAG_SET_SEEN:
|
||||
gSaveBlock2Ptr->pokedex.seen[index] |= mask;
|
||||
gSaveBlock1Ptr->seen1[index] |= mask;
|
||||
gSaveBlock1Ptr->seen2[index] |= mask;
|
||||
break;
|
||||
case FLAG_SET_CAUGHT:
|
||||
gSaveBlock2Ptr->pokedex.owned[index] |= mask;
|
||||
break;
|
||||
}
|
||||
return retVal;
|
||||
}
|
||||
@ -4324,14 +4324,14 @@ u16 GetNationalPokedexCount(u8 caseID)
|
||||
{
|
||||
switch (caseID)
|
||||
{
|
||||
case FLAG_GET_SEEN:
|
||||
if (GetSetPokedexFlag(i + 1, FLAG_GET_SEEN))
|
||||
count++;
|
||||
break;
|
||||
case FLAG_GET_CAUGHT:
|
||||
if (GetSetPokedexFlag(i + 1, FLAG_GET_CAUGHT))
|
||||
count++;
|
||||
break;
|
||||
case FLAG_GET_SEEN:
|
||||
if (GetSetPokedexFlag(i + 1, FLAG_GET_SEEN))
|
||||
count++;
|
||||
break;
|
||||
case FLAG_GET_CAUGHT:
|
||||
if (GetSetPokedexFlag(i + 1, FLAG_GET_CAUGHT))
|
||||
count++;
|
||||
break;
|
||||
}
|
||||
}
|
||||
return count;
|
||||
@ -4346,14 +4346,14 @@ u16 GetHoennPokedexCount(u8 caseID)
|
||||
{
|
||||
switch (caseID)
|
||||
{
|
||||
case FLAG_GET_SEEN:
|
||||
if (GetSetPokedexFlag(HoennToNationalOrder(i + 1), FLAG_GET_SEEN))
|
||||
count++;
|
||||
break;
|
||||
case FLAG_GET_CAUGHT:
|
||||
if (GetSetPokedexFlag(HoennToNationalOrder(i + 1), FLAG_GET_CAUGHT))
|
||||
count++;
|
||||
break;
|
||||
case FLAG_GET_SEEN:
|
||||
if (GetSetPokedexFlag(HoennToNationalOrder(i + 1), FLAG_GET_SEEN))
|
||||
count++;
|
||||
break;
|
||||
case FLAG_GET_CAUGHT:
|
||||
if (GetSetPokedexFlag(HoennToNationalOrder(i + 1), FLAG_GET_CAUGHT))
|
||||
count++;
|
||||
break;
|
||||
}
|
||||
}
|
||||
return count;
|
||||
@ -4381,7 +4381,7 @@ u16 sub_80C089C(u8 caseID)
|
||||
return count;
|
||||
}
|
||||
|
||||
bool8 sub_80C08E4(void)
|
||||
bool16 HasAllHoennMons(void)
|
||||
{
|
||||
u16 i;
|
||||
|
||||
|
@ -463,8 +463,6 @@ EWRAM_DATA static u8 sMovingMonOrigBoxId = 0;
|
||||
EWRAM_DATA static u8 sMovingMonOrigBoxPos = 0;
|
||||
EWRAM_DATA static bool8 sCanOnlyMove = 0;
|
||||
|
||||
extern void sub_80C6D80(u8 *arg0, void *arg1, u8 arg2, u8 arg3, s32 arg4);
|
||||
|
||||
extern const struct CompressedSpriteSheet gMonFrontPicTable[];
|
||||
|
||||
// This file's functions.
|
||||
@ -1543,6 +1541,76 @@ static const u8 gHandCursorTiles[] = INCBIN_U8("graphics/pokemon_storage/hand_cu
|
||||
static const u8 gHandCursorShadowTiles[] = INCBIN_U8("graphics/pokemon_storage/hand_cursor_shadow.4bpp");
|
||||
|
||||
// code
|
||||
void sub_80C6D80(const u8 *string, void *dst, u8 arg2, u8 arg3, s32 arg4)
|
||||
{
|
||||
s32 i, val, val2;
|
||||
u16 windowId;
|
||||
u8 txtColor[3];
|
||||
u8 *tileData1, *tileData2;
|
||||
struct WindowTemplate winTemplate = {0};
|
||||
|
||||
winTemplate.width = 24;
|
||||
winTemplate.height = 2;
|
||||
windowId = AddWindow(&winTemplate);
|
||||
FillWindowPixelBuffer(windowId, (arg3 << 4) | arg3);
|
||||
tileData1 = (u8*) GetWindowAttribute(windowId, WINDOW_TILE_DATA);
|
||||
tileData2 = (winTemplate.width * 32) + tileData1;
|
||||
|
||||
if (!arg2)
|
||||
txtColor[0] = 0;
|
||||
else
|
||||
txtColor[0] = arg3;
|
||||
txtColor[1] = 0xF;
|
||||
txtColor[2] = 0xE;
|
||||
AddTextPrinterParameterized4(windowId, 1, 0, 1, 0, 0, txtColor, -1, string);
|
||||
|
||||
val = arg4;
|
||||
if (val > 6u)
|
||||
val = 6;
|
||||
val2 = arg4 - 6;
|
||||
if (val > 0)
|
||||
{
|
||||
for (i = val; i != 0; i--)
|
||||
{
|
||||
CpuCopy16(tileData1, dst, 0x80);
|
||||
CpuCopy16(tileData2, dst + 0x80, 0x80);
|
||||
tileData1 += 0x80;
|
||||
tileData2 += 0x80;
|
||||
dst += 0x100;
|
||||
}
|
||||
}
|
||||
|
||||
if (val2 > 0)
|
||||
CpuFill16((arg3 << 4) | arg3, dst, (u32)(val2) * 0x100);
|
||||
|
||||
RemoveWindow(windowId);
|
||||
}
|
||||
|
||||
// Unused
|
||||
void sub_80C6EAC(const u8 *string, void *dst, u16 arg2, u8 arg3, u8 clr2, u8 clr3)
|
||||
{
|
||||
u32 var;
|
||||
u8 windowId;
|
||||
u8 txtColor[3];
|
||||
u8 *tileData1, *tileData2;
|
||||
struct WindowTemplate winTemplate = {0};
|
||||
|
||||
winTemplate.width = StringLength_Multibyte(string);
|
||||
winTemplate.height = 2;
|
||||
var = winTemplate.width * 32;
|
||||
windowId = AddWindow(&winTemplate);
|
||||
FillWindowPixelBuffer(windowId, (arg3 << 4) | arg3);
|
||||
tileData1 = (u8*) GetWindowAttribute(windowId, WINDOW_TILE_DATA);
|
||||
tileData2 = (winTemplate.width * 32) + tileData1;
|
||||
txtColor[0] = arg3;
|
||||
txtColor[1] = clr2;
|
||||
txtColor[2] = clr3;
|
||||
AddTextPrinterParameterized4(windowId, 1, 0, 2, 0, 0, txtColor, -1, string);
|
||||
CpuCopy16(tileData1, dst, var);
|
||||
CpuCopy16(tileData2, dst + arg2, var);
|
||||
RemoveWindow(windowId);
|
||||
}
|
||||
|
||||
u8 CountMonsInBox(u8 boxId)
|
||||
{
|
||||
u16 i, count;
|
||||
|
@ -1577,7 +1577,7 @@ void sub_80140E0(u8 taskId)
|
||||
for (i = 0; i < GetLinkPlayerCount(); i++)
|
||||
{
|
||||
recvBuff = gBlockRecvBuffer[i];
|
||||
sub_80C3120(&gTrainerCards[i], recvBuff, gLinkPlayers[i].version);
|
||||
CopyTrainerCardData(&gTrainerCards[i], recvBuff, gLinkPlayers[i].version);
|
||||
}
|
||||
|
||||
if (GetLinkPlayerCount() == 2)
|
||||
@ -1607,7 +1607,7 @@ void sub_80141A4(void)
|
||||
break;
|
||||
case 1:
|
||||
if (!FuncIsActiveTask(sub_80140E0))
|
||||
TrainerCard_ShowLinkCard(GetMultiplayerId() ^ 1, CB2_ReturnToField);
|
||||
ShowTrainerCardInLink(GetMultiplayerId() ^ 1, CB2_ReturnToField);
|
||||
break;
|
||||
}
|
||||
|
||||
|
@ -128,18 +128,18 @@ void sub_80F88E8(void)
|
||||
}
|
||||
}
|
||||
|
||||
u8 sub_80F8940(void)
|
||||
u8 CountPlayerContestPaintings(void)
|
||||
{
|
||||
int i;
|
||||
u8 var0 = 0;
|
||||
u8 count = 0;
|
||||
|
||||
for (i = 0; i < 5; i++)
|
||||
{
|
||||
if (gSaveBlock1Ptr->contestWinners[8 + i].species)
|
||||
var0++;
|
||||
count++;
|
||||
}
|
||||
|
||||
return var0;
|
||||
return count;
|
||||
}
|
||||
|
||||
void sub_80F8970(void)
|
||||
|
@ -9,6 +9,8 @@
|
||||
#include "strings.h"
|
||||
#include "bg.h"
|
||||
#include "field_effect.h"
|
||||
#include "party_menu.h"
|
||||
#include "frontier_pass.h"
|
||||
#include "task.h"
|
||||
#include "overworld.h"
|
||||
#include "link.h"
|
||||
@ -30,6 +32,7 @@
|
||||
#include "scanline_effect.h"
|
||||
#include "text_window.h"
|
||||
#include "load_save.h"
|
||||
#include "trainer_card.h"
|
||||
#include "international_string_util.h"
|
||||
#include "constants/songs.h"
|
||||
#include "field_player_avatar.h"
|
||||
@ -89,11 +92,7 @@ extern void var_800D_set_xB(void);
|
||||
extern void sub_808B864(void);
|
||||
extern void CB2_Pokedex(void);
|
||||
extern void PlayRainSoundEffect(void);
|
||||
extern void CB2_PartyMenuFromStartMenu(void);
|
||||
extern void CB2_PokeNav(void);
|
||||
extern void sub_80C4DDC(void (*)(void));
|
||||
extern void sub_80C51C4(void (*)(void));
|
||||
extern void TrainerCard_ShowLinkCard(u8, void (*)(void));
|
||||
extern void ScriptUnfreezeEventObjects(void);
|
||||
extern void sub_81A9EC8(void);
|
||||
extern void save_serialize_map(void);
|
||||
@ -422,16 +421,19 @@ static bool32 PrintStartMenuActions(s8 *pIndex, u32 count)
|
||||
|
||||
do
|
||||
{
|
||||
if (sStartMenuItems[sCurrentStartMenuActions[index]].func.u8_void == StartMenuPlayerNameCallback) {
|
||||
if (sStartMenuItems[sCurrentStartMenuActions[index]].func.u8_void == StartMenuPlayerNameCallback)
|
||||
{
|
||||
PrintPlayerNameOnWindow(GetStartMenuWindowId(), sStartMenuItems[sCurrentStartMenuActions[index]].text, 8, (index << 4) + 9);
|
||||
}
|
||||
else {
|
||||
else
|
||||
{
|
||||
StringExpandPlaceholders(gStringVar4, sStartMenuItems[sCurrentStartMenuActions[index]].text);
|
||||
AddTextPrinterParameterized(GetStartMenuWindowId(), 1, gStringVar4, 8, (index << 4) + 9, 0xFF, NULL);
|
||||
}
|
||||
|
||||
index++;
|
||||
if (index >= sNumStartMenuActions) {
|
||||
if (index >= sNumStartMenuActions)
|
||||
{
|
||||
*pIndex = index;
|
||||
return TRUE;
|
||||
}
|
||||
@ -465,21 +467,14 @@ static bool32 InitStartMenuStep(void)
|
||||
break;
|
||||
case 3:
|
||||
if (GetSafariZoneFlag())
|
||||
{
|
||||
ShowSafariBallsWindow();
|
||||
}
|
||||
if (InBattlePyramid())
|
||||
{
|
||||
ShowPyramidFloorWindow();
|
||||
}
|
||||
sUnknown_02037619[0]++;
|
||||
break;
|
||||
case 4:
|
||||
if (!PrintStartMenuActions(&sUnknown_02037619[1], 2))
|
||||
{
|
||||
break;
|
||||
}
|
||||
sUnknown_02037619[0]++;
|
||||
if (PrintStartMenuActions(&sUnknown_02037619[1], 2))
|
||||
sUnknown_02037619[0]++;
|
||||
break;
|
||||
case 5:
|
||||
sStartMenuCursorPos = sub_81983AC(GetStartMenuWindowId(), 1, 0, 9, 16, sNumStartMenuActions, sStartMenuCursorPos);
|
||||
@ -494,15 +489,14 @@ static void InitStartMenu(void)
|
||||
{
|
||||
sUnknown_02037619[0] = 0;
|
||||
sUnknown_02037619[1] = 0;
|
||||
while (!InitStartMenuStep());
|
||||
while (!InitStartMenuStep())
|
||||
;
|
||||
}
|
||||
|
||||
static void StartMenuTask(u8 taskId)
|
||||
{
|
||||
if (InitStartMenuStep() == TRUE)
|
||||
{
|
||||
SwitchTaskToFollowupFunc(taskId);
|
||||
}
|
||||
}
|
||||
|
||||
static void CreateStartMenuTask(TaskFunc followupFunc)
|
||||
@ -541,18 +535,14 @@ void sub_809FA34(u8 taskId) // Referenced in field_screen.s and rom_8011DC0.s
|
||||
{
|
||||
case 0:
|
||||
if (InUnionRoom() == TRUE)
|
||||
{
|
||||
var_800D_set_xB();
|
||||
}
|
||||
|
||||
gMenuCallback = HandleStartMenuInput;
|
||||
task->data[0]++;
|
||||
break;
|
||||
case 1:
|
||||
if (gMenuCallback() == TRUE)
|
||||
{
|
||||
DestroyTask(taskId);
|
||||
}
|
||||
break;
|
||||
}
|
||||
}
|
||||
@ -588,9 +578,8 @@ static bool8 HandleStartMenuInput(void)
|
||||
PlaySE(SE_SELECT);
|
||||
if (sStartMenuItems[sCurrentStartMenuActions[sStartMenuCursorPos]].func.u8_void == StartMenuPokedexCallback)
|
||||
{
|
||||
if (GetNationalPokedexCount(0) == 0) {
|
||||
if (GetNationalPokedexCount(0) == 0)
|
||||
return FALSE;
|
||||
}
|
||||
}
|
||||
|
||||
gMenuCallback = sStartMenuItems[sCurrentStartMenuActions[sStartMenuCursorPos]].func.u8_void;
|
||||
@ -686,17 +675,11 @@ static bool8 StartMenuPlayerNameCallback(void)
|
||||
CleanupOverworldWindowsAndTilemaps();
|
||||
|
||||
if (is_c1_link_related_active() || InUnionRoom())
|
||||
{
|
||||
sub_80C4DDC(CB2_ReturnToFieldWithOpenMenu); // Display trainer card
|
||||
}
|
||||
ShowPlayerTrainerCard(CB2_ReturnToFieldWithOpenMenu); // Display trainer card
|
||||
else if (FlagGet(FLAG_SYS_FRONTIER_PASS))
|
||||
{
|
||||
sub_80C51C4(CB2_ReturnToFieldWithOpenMenu); // Display frontier pass
|
||||
}
|
||||
ShowFrontierPass(CB2_ReturnToFieldWithOpenMenu); // Display frontier pass
|
||||
else
|
||||
{
|
||||
sub_80C4DDC(CB2_ReturnToFieldWithOpenMenu); // Display trainer card
|
||||
}
|
||||
ShowPlayerTrainerCard(CB2_ReturnToFieldWithOpenMenu); // Display trainer card
|
||||
|
||||
return TRUE;
|
||||
}
|
||||
@ -707,9 +690,7 @@ static bool8 StartMenuPlayerNameCallback(void)
|
||||
static bool8 StartMenuSaveCallback(void)
|
||||
{
|
||||
if (InBattlePyramid())
|
||||
{
|
||||
RemoveExtraStartMenuWindows();
|
||||
}
|
||||
|
||||
gMenuCallback = SaveStartCallback; // Display save menu
|
||||
|
||||
@ -755,7 +736,7 @@ static bool8 StartMenuLinkModePlayerNameCallback(void)
|
||||
{
|
||||
PlayRainSoundEffect();
|
||||
CleanupOverworldWindowsAndTilemaps();
|
||||
TrainerCard_ShowLinkCard(gUnknown_03005DB4, CB2_ReturnToFieldWithOpenMenu);
|
||||
ShowTrainerCardInLink(gUnknown_03005DB4, CB2_ReturnToFieldWithOpenMenu);
|
||||
|
||||
return TRUE;
|
||||
}
|
||||
|
@ -587,7 +587,7 @@ u8 *StringCopyN_Multibyte(u8 *dest, u8 *src, u32 n)
|
||||
return dest;
|
||||
}
|
||||
|
||||
u32 StringLength_Multibyte(u8 *str)
|
||||
u32 StringLength_Multibyte(const u8 *str)
|
||||
{
|
||||
u32 length = 0;
|
||||
|
||||
|
@ -26,6 +26,7 @@
|
||||
#include "pokedex.h"
|
||||
#include "pokemon_icon.h"
|
||||
#include "pokemon_summary_screen.h"
|
||||
#include "pokemon_storage_system.h"
|
||||
#include "random.h"
|
||||
#include "rom_8011DC0.h"
|
||||
#include "save.h"
|
||||
|
1856
src/trainer_card.c
Executable file
1856
src/trainer_card.c
Executable file
File diff suppressed because it is too large
Load Diff
@ -24,8 +24,11 @@
|
||||
#include "constants/event_object_movement_constants.h"
|
||||
#include "constants/event_objects.h"
|
||||
#include "constants/items.h"
|
||||
#include "constants/moves.h"
|
||||
#include "constants/maps.h"
|
||||
#include "constants/species.h"
|
||||
#include "constants/trainers.h"
|
||||
#include "constants/easy_chat.h"
|
||||
|
||||
extern bool32 sub_81D3B34(void);
|
||||
|
||||
@ -118,11 +121,7 @@ static void sub_81D642C(struct Pokemon *mon, u8 level);
|
||||
static u16 sub_81D6640(void);
|
||||
|
||||
// const data
|
||||
// I will decompile these soon, no worries :)
|
||||
extern const struct TrHillTag gUnknown_08626814;
|
||||
extern const struct TrHillTag gUnknown_086276FC;
|
||||
extern const struct TrHillTag gUnknown_086285E4;
|
||||
extern const struct TrHillTag gUnknown_086294CC;
|
||||
#include "data/battle_frontier/trainer_hill.h"
|
||||
|
||||
struct
|
||||
{
|
||||
@ -246,10 +245,10 @@ static const u8 sRecordWinColors[] = {0, 2, 3};
|
||||
|
||||
static const struct TrHillTag *const sDataPerTag[] =
|
||||
{
|
||||
&gUnknown_08626814,
|
||||
&gUnknown_086276FC,
|
||||
&gUnknown_086285E4,
|
||||
&gUnknown_086294CC,
|
||||
&sDataTagNormal,
|
||||
&sDataTagVariety,
|
||||
&sDataTagUnique,
|
||||
&sDataTagExpert,
|
||||
};
|
||||
|
||||
// Unused.
|
||||
|
@ -153,21 +153,8 @@ gUnknown_02039B6E: @ 2039B6E
|
||||
gUnknown_02039B88: @ 2039B88
|
||||
.space 0x160
|
||||
|
||||
gUnknown_02039CE8: @ 2039CE8
|
||||
.space 0x4
|
||||
|
||||
gUnknown_02039CEC: @ 2039CEC
|
||||
.space 0x4
|
||||
|
||||
gUnknown_02039CF0: @ 2039CF0
|
||||
.space 0x4
|
||||
|
||||
gUnknown_02039CF4: @ 2039CF4
|
||||
.space 0x4
|
||||
|
||||
gUnknown_02039CF8: @ 2039CF8
|
||||
.space 0x8
|
||||
|
||||
.include "src/trainer_card.o"
|
||||
.include "src/frontier_pass.o"
|
||||
.include "src/pokemon_storage_system.o"
|
||||
.include "src/script_movement.o"
|
||||
.include "src/fldeff_cut.o"
|
||||
|
Loading…
x
Reference in New Issue
Block a user