From 65d081334e932460d47d7e8fa5c3857ee91634c3 Mon Sep 17 00:00:00 2001 From: IIMarckus Date: Tue, 8 Jan 2013 21:33:38 -0700 Subject: [PATCH 1/2] Add string pointers and coordinates for town map locations. --- main.asm | 393 ++++++++++++++++++++++++++++++++++++++++++++++++++++++- 1 file changed, 392 insertions(+), 1 deletion(-) diff --git a/main.asm b/main.asm index fcadb57c1..5058d465e 100644 --- a/main.asm +++ b/main.asm @@ -136104,109 +136104,500 @@ MoveNames: db "WHIRLPOOL@" db "BEAT UP@" -INCBIN "baserom.gbc",$1CA896,$1CAA43-$1CA896 +INCBIN "baserom.gbc",$1CA896,$1ca8c3-$1CA896 +Landmarks: ; 0x1ca8c3 + db 0,0 + dw SpecialMapString + + db 148,116 + dw NewBarkString + + db 136,116 + dw Route29String + + db 108,116 + dw CherrygroveString + + db 108,96 + dw Route30String + + db 104,76 + dw Route31String + + db 92,76 + dw VioletString + + db 93,74 + dw SproutString + + db 92,108 + dw Route32String + + db 84,92 + dw RuinsString + + db 92,140 + dw UnionString + + db 90,140 + dw Route33String + + db 76,140 + dw AzaleaString + + db 78,138 + dw WellString + + db 60,136 + dw IlexString + + db 60,128 + dw Route34String + + db 60,108 + dw GoldenrodString + + db 58,108 + dw RadioTowerString + + db 60,92 + dw Route35String + + db 60,76 + dw ParkString + + db 72,76 + dw Route36String + + db 76,68 + dw Route37String + + db 76,60 + dw EcruteakString + + db 78,58 + dw TinString + + db 74,58 + dw BurnedTowerString + + db 60,60 + dw Route38String + + db 44,64 + dw Route39String + + db 44,76 + dw OlivineString + + db 46,78 + dw LighthouseString + + db 36,72 + dw BattleTowerString + + db 36,80 + dw Route40String + + db 36,108 + dw WhirlString + + db 36,116 + dw Route41String + + db 28,116 + dw CianwoodString + + db 100,60 + dw Route42String + + db 92,60 + dw MortarString + + db 116,60 + dw MahoganyString + + db 116,52 + dw Route43String + + db 116,44 + dw LakeString + + db 128,60 + dw Route44String + + db 138,54 + dw PathString + + db 140,60 + dw BlackthornString + + db 140,52 + dw DenString + + db 140,80 + dw Route45String + + db 120,88 + dw DarkString + + db 132,104 + dw Route46String + + db 156,84 + dw SilverCaveString + + db 60,124 + dw PalletString + + db 60,108 + dw Route1String + + db 60,92 + dw ViridianString + + db 60,80 + dw Route2String + + db 60,68 + dw PewterString + + db 72,68 + dw Route3String + + db 84,68 + dw MoonString + + db 96,68 + dw Route4String + + db 108,68 + dw CeruleanString + + db 108,60 + dw Route24String + + db 116,52 + dw Route25String + + db 108,76 + dw Route5String + + db 116,92 + dw UndergroundString + + db 108,92 + dw Route6String + + db 108,100 + dw VermilionString + + db 96,76 + dw DiglettsCaveString + + db 96,84 + dw Route7String + + db 124,84 + dw Route8String + + db 124,68 + dw Route9String + + db 140,68 + dw TunnelString + + db 140,72 + dw Route10String + + db 140,76 + dw PlantString + + db 140,84 + dw LavenderString + + db 148,84 + dw LavTowerString + + db 84,84 + dw CeladonString + + db 108,84 + dw SaffronString + + db 124,100 + dw Route11String + + db 140,96 + dw Route12String + + db 132,116 + dw Route13String + + db 124,128 + dw Route14String + + db 112,132 + dw Route15String + + db 76,84 + dw Route16String + + db 76,108 + dw Route17String + + db 88,132 + dw Route18String + + db 100,132 + dw FuchsiaString + + db 100,144 + dw Route19String + + db 84,148 + dw Route20String + + db 76,148 + dw SeafoamString + + db 60,148 + dw CinnabarString + + db 60,136 + dw Route21String + + db 44,84 + dw Route22String + + db 36,68 + dw RoadString + + db 36,60 + dw Route23String + + db 36,52 + dw IndigoString + + db 36,108 + dw Route26String + + db 28,116 + dw Route27String + + db 20,116 + dw FallsString + + db 28,84 + dw Route28String + + db 148,132 + dw AquaString + +NewBarkString: db "NEW BARK",$1F,"TOWN@" +CherrygroveString: db "CHERRYGROVE",$1F,"CITY@" +VioletString: db "VIOLET CITY@" +AzaleaString: db "AZALEA TOWN@" +GoldenrodString: db "GOLDENROD",$1F,"CITY@" +EcruteakString: db "ECRUTEAK",$1F,"CITY@" +OlivineString: db "OLIVINE",$1F,"CITY@" +CianwoodString: db "CIANWOOD",$1F,"CITY@" +MahoganyString: db "MAHOGANY",$1F,"TOWN@" +BlackthornString: db "BLACKTHORN",$1F,"CITY@" +LakeString: db "LAKE OF",$1F,"RAGE@" +SilverCaveString: db "SILVER CAVE@" +SproutString: db "SPROUT",$1F,"TOWER@" +RuinsString: db "RUINS",$1F,"OF ALPH@" +UnionString: db "UNION CAVE@" +WellString: db "SLOWPOKE",$1F,"WELL@" +RadioTowerString: db "RADIO TOWER@" +PlantString: db "POWER PLANT@" +ParkString: db "NATIONAL",$1F,"PARK@" +TinString: db "TIN TOWER@" +LighthouseString: db "LIGHTHOUSE@" +WhirlString: db "WHIRL",$1F,"ISLANDS@" +MortarString: db "MT.MORTAR@" +DenString: db "DRAGON'S",$1F,"DEN@" +PathString: db "ICE PATH@" +NotApplicableString: db "N/A@" +PalletString: db "PALLET TOWN@" +ViridianString: db "VIRIDIAN",$1F,"CITY@" +PewterString: db "PEWTER CITY@" +CeruleanString: db "CERULEAN",$1F,"CITY@" +LavenderString: db "LAVENDER",$1F,"TOWN@" +VermilionString: db "VERMILION",$1F,"CITY@" +CeladonString: db "CELADON",$1F,"CITY@" +SaffronString: db "SAFFRON",$1F,"CITY@" +FuchsiaString: db "FUCHSIA",$1F,"CITY@" +CinnabarString: db "CINNABAR",$1F,"ISLAND@" +IndigoString: db "INDIGO",$1F,"PLATEAU@" +RoadString: db "VICTORY",$1F,"ROAD@" +MoonString: db "MT.MOON@" +TunnelString: db "ROCK TUNNEL@" +LavTowerString: db "LAV",$1F,"RADIO TOWER@" +SilphString: db "SILPH CO.@" +ZoneString: db "SAFARI ZONE@" +SeafoamString: db "SEAFOAM",$1F,"ISLANDS@" +MansionString: db "#MON",$1F,"MANSION@" +DungeonString: db "CERULEAN",$1F,"CAVE@" +Route1String: db "ROUTE 1@" +Route2String: db "ROUTE 2@" +Route3String: db "ROUTE 3@" +Route4String: db "ROUTE 4@" +Route5String: db "ROUTE 5@" +Route6String: db "ROUTE 6@" +Route7String: db "ROUTE 7@" +Route8String: db "ROUTE 8@" +Route9String: db "ROUTE 9@" +Route10String: db "ROUTE 10@" +Route11String: db "ROUTE 11@" +Route12String: db "ROUTE 12@" +Route13String: db "ROUTE 13@" +Route14String: db "ROUTE 14@" +Route15String: db "ROUTE 15@" +Route16String: db "ROUTE 16@" +Route17String: db "ROUTE 17@" +Route18String: db "ROUTE 18@" +Route19String: db "ROUTE 19@" +Route20String: db "ROUTE 20@" +Route21String: db "ROUTE 21@" +Route22String: db "ROUTE 22@" +Route23String: db "ROUTE 23@" +Route24String: db "ROUTE 24@" +Route25String: db "ROUTE 25@" +Route26String: db "ROUTE 26@" +Route27String: db "ROUTE 27@" +Route28String: db "ROUTE 28@" +Route29String: db "ROUTE 29@" +Route30String: db "ROUTE 30@" +Route31String: db "ROUTE 31@" +Route32String: db "ROUTE 32@" +Route33String: db "ROUTE 33@" +Route34String: db "ROUTE 34@" +Route35String: db "ROUTE 35@" +Route36String: db "ROUTE 36@" +Route37String: db "ROUTE 37@" +Route38String: db "ROUTE 38@" +Route39String: db "ROUTE 39@" +Route40String: db "ROUTE 40@" +Route41String: db "ROUTE 41@" +Route42String: db "ROUTE 42@" +Route43String: db "ROUTE 43@" +Route44String: db "ROUTE 44@" +Route45String: db "ROUTE 45@" +Route46String: db "ROUTE 46@" +DarkString: db "DARK CAVE@" +IlexString: db "ILEX",$1F,"FOREST@" +BurnedTowerString: db "BURNED",$1F,"TOWER@" +AquaString: db "FAST SHIP@" +ViridianForestString: db "VIRIDIAN",$1F,"FOREST@" +DiglettsCaveString: db "DIGLETT'S",$1F,"CAVE@" +FallsString: db "TOHJO FALLS@" +UndergroundString: db "UNDERGROUND@" +BattleTowerString: db "BATTLE",$1F,"TOWER@" +SpecialMapString: db "SPECIAL@" RegionCheck: ; 0x1caea1 From 29cce49fcb04fb0bbed867083e8a44cebc043e8c Mon Sep 17 00:00:00 2001 From: IIMarckus Date: Tue, 8 Jan 2013 22:45:27 -0700 Subject: [PATCH 2/2] Pull out some code related to map names / item descriptions. --- main.asm | 337 ++++++++++++++++++++++++++++++++++++++++++++++++++++++- 1 file changed, 332 insertions(+), 5 deletions(-) diff --git a/main.asm b/main.asm index 5058d465e..8ef24f7cf 100644 --- a/main.asm +++ b/main.asm @@ -135096,7 +135096,294 @@ ItemNames: db "TERU-SAMA@" db "?@" -INCBIN "baserom.gbc",$1C8955,$1C8B85-$1C8955 +GetItemDescription: ; 0x1c8955 + ld a, [$cf60] + cp TM_01 + jr c, .nomovedesc ; if not a TM, use a predefined string + ld [$d106], a + push de + ld a, $b ; XXX replace this with BANK(label) + ld hl, $47b6 ; XXX replace this with label + rst $8 + pop hl + ld a, [$d265] + ld [$cf60], a + ld a, $11 + call Predef + ret + +.nomovedesc + push de + ld hl, ItemDescriptions + ld a, [$cf60] + dec a + ld c, a + ld b, $0 + add hl, bc + add hl, bc + ld e, [hl] + inc hl + ld d, [hl] + pop hl + jp PlaceString +; 0x1c8987 + +ItemDescriptions: + dw MasterBallDesc + dw UltraBallDesc + dw BrightpowderDesc + dw GreatBallDesc + dw PokeBallDesc + dw TeruSama1Desc + dw BicycleDesc + dw MoonStoneDesc + dw AntidoteDesc + dw BurnHealDesc + dw IceHealDesc + dw AwakeningDesc + dw ParlyzHealDesc + dw FullRestoreDesc + dw MaxPotionDesc + dw HyperPotionDesc + dw SuperPotionDesc + dw PotionDesc + dw EscapeRopeDesc + dw RepelDesc + dw MaxElixerDesc + dw FireStoneDesc + dw ThunderStoneDesc + dw WaterStoneDesc + dw TeruSama2Desc + dw HPUpDesc + dw ProteinDesc + dw IronDesc + dw CarbosDesc + dw LuckyPunchDesc + dw CalciumDesc + dw RareCandyDesc + dw XAccuracyDesc + dw LeafStoneDesc + dw MetalPowderDesc + dw NuggetDesc + dw PokeDollDesc + dw FullHealDesc + dw ReviveDesc + dw MaxReviveDesc + dw GuardSpecDesc + dw SuperRepelDesc + dw MaxRepelDesc + dw DireHitDesc + dw TeruSama3Desc + dw FreshWaterDesc + dw SodaPopDesc + dw LemonadeDesc + dw XAttackDesc + dw TeruSama4Desc + dw XDefendDesc + dw XSpeedDesc + dw XSpecialDesc + dw CoinCaseDesc + dw ItemfinderDesc + dw TeruSama5Desc + dw ExpShareDesc + dw OldRodDesc + dw GoodRodDesc + dw SilverLeafDesc + dw SuperRodDesc + dw PPUpDesc + dw EtherDesc + dw MaxEtherDesc + dw ElixerDesc + dw RedScaleDesc + dw SecretPotionDesc + dw SSTicketDesc + dw MysteryEggDesc + dw ClearBellDesc + dw SilverWingDesc + dw MoomooMilkDesc + dw QuickClawDesc + dw PsnCureBerryDesc + dw GoldLeafDesc + dw SoftSandDesc + dw SharpBeakDesc + dw PrzCureBerryDesc + dw BurntBerryDesc + dw IceBerryDesc + dw PoisonBarbDesc + dw KingsRockDesc + dw BitterBerryDesc + dw MintBerryDesc + dw RedApricornDesc + dw TinyMushroomDesc + dw BigMushroomDesc + dw SilverPowderDesc + dw BluApricornDesc + dw TeruSama6Desc + dw AmuletCoinDesc + dw YlwApricornDesc + dw GrnApricornDesc + dw CleanseTagDesc + dw MysticWaterDesc + dw TwistedSpoonDesc + dw WhtApricornDesc + dw BlackbeltDesc + dw BlkApricornDesc + dw TeruSama7Desc + dw PnkApricornDesc + dw BlackGlassesDesc + dw SlowpokeTailDesc + dw PinkBowDesc + dw StickDesc + dw SmokeBallDesc + dw NeverMeltIceDesc + dw MagnetDesc + dw MiracleBerryDesc + dw PearlDesc + dw BigPearlDesc + dw EverStoneDesc + dw SpellTagDesc + dw RageCandyBarDesc + dw GSBallDesc + dw BlueCardDesc + dw MiracleSeedDesc + dw ThickClubDesc + dw FocusBandDesc + dw TeruSama8Desc + dw EnergyPowderDesc + dw EnergyRootDesc + dw HealPowderDesc + dw RevivalHerbDesc + dw HardStoneDesc + dw LuckyEggDesc + dw CardKeyDesc + dw MachinePartDesc + dw EggTicketDesc + dw LostItemDesc + dw StardustDesc + dw StarPieceDesc + dw BasementKeyDesc + dw PassDesc + dw TeruSama9Desc + dw TeruSama10Desc + dw TeruSama11Desc + dw CharcoalDesc + dw BerryJuiceDesc + dw ScopeLensDesc + dw TeruSama12Desc + dw TeruSama13Desc + dw MetalCoatDesc + dw DragonFangDesc + dw TeruSama14Desc + dw LeftoversDesc + dw TeruSama15Desc + dw TeruSama16Desc + dw TeruSama17Desc + dw MysteryBerryDesc + dw DragonScaleDesc + dw BerserkGeneDesc + dw TeruSama18Desc + dw TeruSama19Desc + dw TeruSama20Desc + dw SacredAshDesc + dw HeavyBallDesc + dw FlowerMailDesc + dw LevelBallDesc + dw LureBallDesc + dw FastBallDesc + dw TeruSama21Desc + dw LightBallDesc + dw FriendBallDesc + dw MoonBallDesc + dw LoveBallDesc + dw NormalBoxDesc + dw GorgeousBoxDesc + dw SunStoneDesc + dw PolkadotBowDesc + dw TeruSama22Desc + dw UpGradeDesc + dw BerryDesc + dw GoldBerryDesc + dw SquirtBottleDesc + dw TeruSama23Desc + dw ParkBallDesc + dw RainbowWingDesc + dw TeruSama24Desc + dw BrickPieceDesc + dw SurfMailDesc + dw LiteBlueMailDesc + dw PortraitMailDesc + dw LovelyMailDesc + dw EonMailDesc + dw MorphMailDesc + dw BlueSkyMailDesc + dw MusicMailDesc + dw MewMailDesc + dw TeruSama25Desc + dw TeruSama26Desc + dw TeruSama26Desc + dw TeruSama26Desc + dw TeruSama26Desc + dw TeruSama26Desc + dw TeruSama27Desc + dw TeruSama27Desc + dw TeruSama27Desc + dw TeruSama27Desc + dw TeruSama27Desc + dw TeruSama27Desc + dw TeruSama27Desc + dw TeruSama27Desc + dw TeruSama27Desc + dw TeruSama27Desc + dw TeruSama27Desc + dw TeruSama27Desc + dw TeruSama27Desc + dw TeruSama27Desc + dw TeruSama27Desc + dw TeruSama27Desc + dw TeruSama27Desc + dw TeruSama27Desc + dw TeruSama27Desc + dw TeruSama27Desc + dw TeruSama27Desc + dw TeruSama27Desc + dw TeruSama27Desc + dw TeruSama27Desc + dw TeruSama27Desc + dw TeruSama28Desc + dw TeruSama28Desc + dw TeruSama28Desc + dw TeruSama28Desc + dw TeruSama28Desc + dw TeruSama28Desc + dw TeruSama28Desc + dw TeruSama28Desc + dw TeruSama28Desc + dw TeruSama28Desc + dw TeruSama28Desc + dw TeruSama28Desc + dw TeruSama28Desc + dw TeruSama28Desc + dw TeruSama28Desc + dw TeruSama28Desc + dw TeruSama28Desc + dw TeruSama28Desc + dw TeruSama28Desc + dw TeruSama28Desc + dw TeruSama28Desc + dw TeruSama28Desc + dw TeruSama28Desc + dw TeruSama28Desc + dw TeruSama28Desc + dw TeruSama28Desc + dw TeruSama28Desc + dw TeruSama28Desc + dw TeruSama28Desc + dw TeruSama28Desc + dw TeruSama29Desc + dw TeruSama30Desc + dw TeruSama31Desc + dw TeruSama32Desc + dw TeruSama33Desc MasterBallDesc: db "The best BALL. It",$4E @@ -136104,9 +136391,52 @@ MoveNames: db "WHIRLPOOL@" db "BEAT UP@" -INCBIN "baserom.gbc",$1CA896,$1ca8c3-$1CA896 +GetLandmarkCoords: ; 0x1ca896 +; given a landmark id in e, return the y coord in d, and the x coord in e. + push hl + ld l, e + ld h, $0 + add hl, hl + add hl, hl + ld de, Landmarks + add hl, de + ld a, [hli] + ld e, a + ld d, [hl] + pop hl + ret + + +GetLandmarkName: ; 0x1ca8a5 +; given a landmark id in e, copy its name to $d073. + push hl + push de + push bc + ld l, e + ld h, $0 + add hl, hl + add hl, hl + ld de, Landmarks + 2 ; skip the coordinates, we only want the string + add hl, de + ld a, [hli] + ld h, [hl] + ld l, a + ld de, $d073 + ld c, 18 +.loop + ld a, [hli] + ld [de], a + inc de + dec c + jr nz, .loop + pop bc + pop de + pop hl + ret Landmarks: ; 0x1ca8c3 +;db x coord, y coord +;dw pointer to name db 0,0 dw SpecialMapString @@ -137146,7 +137476,6 @@ SunfloraPokedexEntry: ; 0x1cdaef db "#MON's face", $4e, "become more vivid", $4e, "and lively.@" ; 0x1cdb51 -INCBIN "baserom.gbc",$1cdb51,$24af SECTION "bank74",DATA,BANK[$74] @@ -137622,8 +137951,6 @@ CelebiPokedexEntry: ; 0x1d18cc db "appears wherever", $4e, "beautiful forests", $4e, "exist.@" ; 0x1d1931 -INCBIN "baserom.gbc",$1d1931,$26cf - SECTION "bank75",DATA,BANK[$75] SECTION "bank76",DATA,BANK[$76]