[intro] refactor expansion intro

This commit is contained in:
sbird 2023-02-08 22:32:54 +01:00
parent 8ac3197c85
commit 4bcbb7c9e1
16 changed files with 178 additions and 193 deletions

View file

@ -1,7 +1,7 @@
JASC-PAL JASC-PAL
0100 0100
256 256
198 231 214 0 0 0
255 255 255 255 255 255
222 222 222 222 222 222
222 222 214 222 222 214

View file

Before

Width:  |  Height:  |  Size: 336 B

After

Width:  |  Height:  |  Size: 336 B

View file

Before

Width:  |  Height:  |  Size: 1.7 KiB

After

Width:  |  Height:  |  Size: 1.7 KiB

View file

Before

Width:  |  Height:  |  Size: 1.1 KiB

After

Width:  |  Height:  |  Size: 1.1 KiB

View file

Before

Width:  |  Height:  |  Size: 1.4 KiB

After

Width:  |  Height:  |  Size: 1.4 KiB

View file

@ -74,6 +74,6 @@
#define GEN_LATEST GEN_8 #define GEN_LATEST GEN_8
// General settings // General settings
#define RHH_COPYRIGHT_INTRO TRUE // If TRUE, a custom RHH intro will play instead of the vanilla copyright screen. #define EXPANSION_INTRO TRUE // If TRUE, a custom RHH intro will play after the vanilla copyright screen.
#endif // GUARD_CONFIG_H #endif // GUARD_CONFIG_H

View file

@ -0,0 +1,9 @@
#ifndef GUARD_EXPANSION_INTRO_H
#define GUARD_EXPANSION_INTRO_H
#if EXPANSION_INTRO == TRUE
void CB2_ExpansionIntro(void);
void Task_HandleExpansionIntro(u8 taskId);
#endif
#endif /* GUARD_EXPANSION_INTRO_H */

View file

@ -9,5 +9,8 @@
void CB2_InitCopyrightScreenAfterBootup(void); void CB2_InitCopyrightScreenAfterBootup(void);
void CB2_InitCopyrightScreenAfterTitleScreen(void); void CB2_InitCopyrightScreenAfterTitleScreen(void);
void PanFadeAndZoomScreen(u16, u16, u16, u16); void PanFadeAndZoomScreen(u16, u16, u16, u16);
void MainCB2_Intro(void);
void Task_Scene1_Load(u8);
#endif // GUARD_INTRO_H #endif // GUARD_INTRO_H

View file

@ -1,13 +0,0 @@
#ifndef GUARD_RHH_COPYRIGHT_H
#define GUARD_RHH_COPYRIGHT_H
#if RHH_COPYRIGHT_INTRO == TRUE
void RhhIntro_InitCopyrightBgs();
void RhhIntro_LoadCopyrightBgGraphics();
void RhhIntro_ShowRhhCredits();
void RhhIntro_LoadCopyrightSpriteGraphics();
void RhhIntro_CreateCopyRightSprites();
void RhhIntro_DestroyRhhCreditSprites();
#endif
#endif /* GUARD_RHH_COPYRIGHT_H */

View file

@ -343,7 +343,7 @@ SECTIONS {
src/battle_transition_frontier.o(.text); src/battle_transition_frontier.o(.text);
src/international_string_util.o(.text); src/international_string_util.o(.text);
src/pokemon_debug.o(.text); src/pokemon_debug.o(.text);
src/rhh_copyright.o(.text); src/expansion_intro.o(.text);
} =0 } =0
script_data : script_data :
@ -710,7 +710,7 @@ SECTIONS {
src/m4a_tables.o(.rodata); src/m4a_tables.o(.rodata);
data/sound_data.o(.rodata); data/sound_data.o(.rodata);
src/pokemon_debug.o(.rodata); src/pokemon_debug.o(.rodata);
src/rhh_copyright.o(.rodata); src/expansion_intro.o(.rodata);
} =0 } =0
song_data : song_data :

View file

@ -8,23 +8,13 @@
#include "task.h" #include "task.h"
#include "gpu_regs.h" #include "gpu_regs.h"
#include "trig.h" #include "trig.h"
#include "rhh_copyright.h" #include "main.h"
#include "intro.h"
#include "expansion_intro.h"
#include "constants/rgb.h" #include "constants/rgb.h"
#include "constants/songs.h" #include "constants/songs.h"
#if RHH_COPYRIGHT_INTRO == TRUE #if EXPANSION_INTRO == TRUE
static const u32 sBgTiles_PoweredBy[] = INCBIN_U32("graphics/rhh_copyright/powered_by.4bpp.lz");
static const u32 sBgTiles_RhhCredits[] = INCBIN_U32("graphics/rhh_copyright/rhh_credits.8bpp.lz");
static const u32 sBgMap_PoweredBy[] = INCBIN_U32("graphics/rhh_copyright/powered_by.bin.lz");
static const u32 sBgMap_RhhCredits[] = INCBIN_U32("graphics/rhh_copyright/rhh_credits.bin.lz");
static const u32 sBgPal_Credits[] = INCBIN_U32("graphics/rhh_copyright/credits.gbapal.lz");
static const u32 sSpriteTiles_DizzyEgg[] = INCBIN_U32("graphics/rhh_copyright/sprites/dizzy_egg.4bpp.lz");
static const u32 sSpriteTiles_Porygon[] = INCBIN_U32("graphics/rhh_copyright/sprites/porygon.4bpp.lz");
static const u16 sSpritePal_DizzyEgg[] = INCBIN_U16("graphics/rhh_copyright/sprites/dizzy_egg.gbapal");
static const u16 sSpritePal_Porygon[] = INCBIN_U16("graphics/rhh_copyright/sprites/porygon.gbapal");
static const u16 sSpritePal_PorygonShiny[] = INCBIN_U16("graphics/rhh_copyright/sprites/shiny.gbapal");
#define TAG_DIZZY 20000 #define TAG_DIZZY 20000
#define TAG_PORYGON 20001 #define TAG_PORYGON 20001
@ -43,10 +33,47 @@ static const u16 sSpritePal_PorygonShiny[] = INCBIN_U16("graphics/rhh_copyright/
#define DIZZY_ANIM_SPEED 4 #define DIZZY_ANIM_SPEED 4
#define DIZZY_STARS_SPEED 12 #define DIZZY_STARS_SPEED 12
static void SpriteCallbacK_DizzyWalking(struct Sprite* sprite); enum
static void SpriteCallback_PorygonFlying(struct Sprite* sprite); {
EXPANSION_INTRO_BG2,
EXPANSION_INTRO_BG3
};
static const union AnimCmd sAnimCmd_DizzyWalking[] = { enum
{
ANIM_PORY_IDLE,
ANIM_PORY_HIT,
ANIM_PORY_GO_UP
};
enum
{
ANIM_DIZZY_WALKING,
ANIM_DIZZY_DIZZY
};
static const u32 sBgTiles_PoweredBy[] = INCBIN_U32("graphics/expansion_intro/powered_by.4bpp.lz");
static const u32 sBgTiles_RhhCredits[] = INCBIN_U32("graphics/expansion_intro/rhh_credits.8bpp.lz");
static const u32 sBgMap_PoweredBy[] = INCBIN_U32("graphics/expansion_intro/powered_by.bin.lz");
static const u32 sBgMap_RhhCredits[] = INCBIN_U32("graphics/expansion_intro/rhh_credits.bin.lz");
static const u32 sBgPal_Credits[] = INCBIN_U32("graphics/expansion_intro/credits.gbapal.lz");
static const u32 sSpriteTiles_DizzyEgg[] = INCBIN_U32("graphics/expansion_intro/sprites/dizzy_egg.4bpp.lz");
static const u32 sSpriteTiles_Porygon[] = INCBIN_U32("graphics/expansion_intro/sprites/porygon.4bpp.lz");
static const u16 sSpritePal_DizzyEgg[] = INCBIN_U16("graphics/expansion_intro/sprites/dizzy_egg.gbapal");
static const u16 sSpritePal_Porygon[] = INCBIN_U16("graphics/expansion_intro/sprites/porygon.gbapal");
static const u16 sSpritePal_PorygonShiny[] = INCBIN_U16("graphics/expansion_intro/sprites/shiny.gbapal");
static void SpriteCallback_DizzyWalking(struct Sprite* sprite);
static void SpriteCallback_PorygonFlying(struct Sprite* sprite);
static void Task_ExpansionIntro_HandleBlend(u8 taskId);
static void VBlankCB_ExpansionIntro(void);
static void ExpansionIntro_InitBgs();
static void ExpansionIntro_StartBlend();
static void ExpansionIntro_LoadGraphics();
static void ExpansionIntro_CreateSprites();
static const union AnimCmd sAnimCmd_DizzyWalking[] =
{
ANIMCMD_FRAME(32, DIZZY_ANIM_SPEED), ANIMCMD_FRAME(32, DIZZY_ANIM_SPEED),
ANIMCMD_FRAME(16, DIZZY_ANIM_SPEED), ANIMCMD_FRAME(16, DIZZY_ANIM_SPEED),
ANIMCMD_FRAME(0, DIZZY_ANIM_SPEED), ANIMCMD_FRAME(0, DIZZY_ANIM_SPEED),
@ -58,7 +85,8 @@ static const union AnimCmd sAnimCmd_DizzyWalking[] = {
ANIMCMD_JUMP(0), ANIMCMD_JUMP(0),
}; };
static const union AnimCmd sAnimCmd_DizzyisDizzy[] = { static const union AnimCmd sAnimCmd_DizzyisDizzy[] =
{
ANIMCMD_FRAME(80, DIZZY_STARS_SPEED), ANIMCMD_FRAME(80, DIZZY_STARS_SPEED),
ANIMCMD_FRAME(96, DIZZY_STARS_SPEED), ANIMCMD_FRAME(96, DIZZY_STARS_SPEED),
ANIMCMD_FRAME(112, DIZZY_STARS_SPEED), ANIMCMD_FRAME(112, DIZZY_STARS_SPEED),
@ -66,69 +94,77 @@ static const union AnimCmd sAnimCmd_DizzyisDizzy[] = {
ANIMCMD_JUMP(0), ANIMCMD_JUMP(0),
}; };
enum {ANIM_DIZZY_WALKING, ANIM_DIZZY_DIZZY}; static const union AnimCmd *const sAnimCmdTable_DizzyEgg[] =
{
static const union AnimCmd *const sAnimCmdTable_DizzyEgg[] = {
[ANIM_DIZZY_WALKING] = sAnimCmd_DizzyWalking, [ANIM_DIZZY_WALKING] = sAnimCmd_DizzyWalking,
[ANIM_DIZZY_DIZZY] = sAnimCmd_DizzyisDizzy, [ANIM_DIZZY_DIZZY] = sAnimCmd_DizzyisDizzy,
}; };
static const union AnimCmd sAnimCmd_PorygonIdle[] = { static const union AnimCmd sAnimCmd_PorygonIdle[] =
{
ANIMCMD_FRAME(0, 0), ANIMCMD_FRAME(0, 0),
ANIMCMD_END, ANIMCMD_END,
}; };
static const union AnimCmd sAnimCmd_PorygonHitted[] = { static const union AnimCmd sAnimCmd_PorygonHitted[] =
{
ANIMCMD_FRAME(64, 0), ANIMCMD_FRAME(64, 0),
ANIMCMD_END, ANIMCMD_END,
}; };
static const union AnimCmd sAnimCmd_PorygonGoUp[] = { static const union AnimCmd sAnimCmd_PorygonGoUp[] =
{
ANIMCMD_FRAME(64, 20), ANIMCMD_FRAME(64, 20),
ANIMCMD_FRAME(128, 10), ANIMCMD_FRAME(128, 10),
ANIMCMD_END, ANIMCMD_END,
}; };
enum {ANIM_PORY_IDLE, ANIM_PORY_HIT, ANIM_PORY_GO_UP}; static const union AnimCmd *const sAnimCmdTable_Porygon[] =
{
static const union AnimCmd *const sAnimCmdTable_Porygon[] = {
[ANIM_PORY_IDLE] = sAnimCmd_PorygonIdle, [ANIM_PORY_IDLE] = sAnimCmd_PorygonIdle,
[ANIM_PORY_HIT] = sAnimCmd_PorygonHitted, [ANIM_PORY_HIT] = sAnimCmd_PorygonHitted,
[ANIM_PORY_GO_UP] = sAnimCmd_PorygonGoUp, [ANIM_PORY_GO_UP] = sAnimCmd_PorygonGoUp,
}; };
static const union AffineAnimCmd sAffineAnimCmd_PorygonScale[] = { static const union AffineAnimCmd sAffineAnimCmd_PorygonScale[] =
{
AFFINEANIMCMD_FRAME(0x100, 0x100, 0, 0), AFFINEANIMCMD_FRAME(0x100, 0x100, 0, 0),
AFFINEANIMCMD_END, AFFINEANIMCMD_END,
}; };
static const union AffineAnimCmd *const sAffineAnimCmdTable_Porygon[] = { static const union AffineAnimCmd *const sAffineAnimCmdTable_Porygon[] =
{
sAffineAnimCmd_PorygonScale, sAffineAnimCmd_PorygonScale,
}; };
static const struct CompressedSpriteSheet sSpriteSheet_DizzyEgg = { static const struct CompressedSpriteSheet sSpriteSheet_DizzyEgg =
{
.data = sSpriteTiles_DizzyEgg, .data = sSpriteTiles_DizzyEgg,
.size = 0x1000, .size = 0x1000,
.tag = TAG_DIZZY, .tag = TAG_DIZZY,
}; };
static const struct CompressedSpriteSheet sSpriteSheet_Porygon = { static const struct CompressedSpriteSheet sSpriteSheet_Porygon =
{
.data = sSpriteTiles_Porygon, .data = sSpriteTiles_Porygon,
.size = 0x2800, .size = 0x2800,
.tag = PAL_TAG_PORYGON, .tag = PAL_TAG_PORYGON,
}; };
static const struct SpritePalette sSpritePalette_DizzyEgg = { static const struct SpritePalette sSpritePalette_DizzyEgg =
{
.data = sSpritePal_DizzyEgg, .data = sSpritePal_DizzyEgg,
.tag = PAL_TAG_DIZZY, .tag = PAL_TAG_DIZZY,
}; };
static const struct SpritePalette sSpritePalette_Porygon = { static const struct SpritePalette sSpritePalette_Porygon =
{
.data = sSpritePal_Porygon, .data = sSpritePal_Porygon,
.tag = PAL_TAG_PORYGON, .tag = PAL_TAG_PORYGON,
}; };
static const struct OamData sOamData_DizzyEgg = { static const struct OamData sOamData_DizzyEgg =
{
.affineMode = ST_OAM_AFFINE_OFF, .affineMode = ST_OAM_AFFINE_OFF,
.objMode = ST_OAM_OBJ_NORMAL, .objMode = ST_OAM_OBJ_NORMAL,
.mosaic = 0, .mosaic = 0,
@ -138,7 +174,8 @@ static const struct OamData sOamData_DizzyEgg = {
.priority = 0, .priority = 0,
}; };
static const struct OamData sOamData_Porygon = { static const struct OamData sOamData_Porygon =
{
.affineMode = ST_OAM_AFFINE_NORMAL, .affineMode = ST_OAM_AFFINE_NORMAL,
.objMode = ST_OAM_OBJ_NORMAL, .objMode = ST_OAM_OBJ_NORMAL,
.mosaic = 0, .mosaic = 0,
@ -148,17 +185,19 @@ static const struct OamData sOamData_Porygon = {
.priority = 0, .priority = 0,
}; };
static const struct SpriteTemplate sSpriteTemplate_DizzyEgg = { static const struct SpriteTemplate sSpriteTemplate_DizzyEgg =
{
.tileTag = TAG_DIZZY, .tileTag = TAG_DIZZY,
.paletteTag = PAL_TAG_DIZZY, .paletteTag = PAL_TAG_DIZZY,
.oam = &sOamData_DizzyEgg, .oam = &sOamData_DizzyEgg,
.anims = sAnimCmdTable_DizzyEgg, .anims = sAnimCmdTable_DizzyEgg,
.images = NULL, .images = NULL,
.affineAnims = gDummySpriteAffineAnimTable, .affineAnims = gDummySpriteAffineAnimTable,
.callback = SpriteCallbacK_DizzyWalking, .callback = SpriteCallback_DizzyWalking,
}; };
static const struct SpriteTemplate sSpriteTemplate_Porygon = { static const struct SpriteTemplate sSpriteTemplate_Porygon =
{
.tileTag = TAG_PORYGON, .tileTag = TAG_PORYGON,
.paletteTag = PAL_TAG_PORYGON, .paletteTag = PAL_TAG_PORYGON,
.oam = &sOamData_Porygon, .oam = &sOamData_Porygon,
@ -168,53 +207,75 @@ static const struct SpriteTemplate sSpriteTemplate_Porygon = {
.callback = SpriteCallback_PorygonFlying, .callback = SpriteCallback_PorygonFlying,
}; };
enum {BG_0, BG_1, BG_2, BG_3}; static const struct BgTemplate sBgTemplates_RhhCopyrightScreen[] =
{
static const struct BgTemplate sBgTemplates_RhhCopyrightScreen[] = { [EXPANSION_INTRO_BG2] = {
[BG_0] = { .bg = 2,
.bg = BG_0,
.charBaseIndex = 3,
.mapBaseIndex = 24,
.screenSize = 2,
.paletteMode = 0,
.priority = 0,
.baseTile = 0,
},
[BG_1] = {
.bg = BG_1,
.charBaseIndex = 3,
.mapBaseIndex = 24,
.screenSize = 2,
.paletteMode = 0,
.priority = 0,
.baseTile = 0,
},
[BG_2] = {
.bg = BG_2,
.charBaseIndex = 1, .charBaseIndex = 1,
.mapBaseIndex = 20, .mapBaseIndex = 20,
.screenSize = 2, .screenSize = 2,
.paletteMode = 1, .paletteMode = 1
.priority = 0,
.baseTile = 0,
}, },
[BG_3] = { [EXPANSION_INTRO_BG3] = {
.bg = BG_3, .bg = 3,
.charBaseIndex = 0,
.mapBaseIndex = 22, .mapBaseIndex = 22,
.screenSize = 2, .screenSize = 2
.paletteMode = 0,
.priority = 0,
.baseTile = 0,
}, },
}; };
static EWRAM_DATA u8 sDizzyId = 0; void CB2_ExpansionIntro(void)
static EWRAM_DATA u8 sPoryId = 0; {
RunTasks();
AnimateSprites();
BuildOamBuffer();
UpdatePaletteFade();
}
static void Task_ShowRhhCredits(u8 taskId); #define tState gTasks[taskId].data[0]
#define tFrameCounter gTasks[taskId].data[1]
void Task_HandleExpansionIntro(u8 taskId)
{
switch (tState)
{
case 0:
SetVBlankCallback(VBlankCB_ExpansionIntro);
ExpansionIntro_InitBgs();
ExpansionIntro_LoadGraphics();
CpuFastFill16(RGB_BLACK, gPlttBufferFaded, 32);
ShowBg(3);
BeginNormalPaletteFade(1, 0, 16, 0, RGB_BLACK);
ExpansionIntro_StartBlend();
ExpansionIntro_CreateSprites();
tState++;
break;
case 1:
if (!gPaletteFade.active)
tState++;
break;
case 2:
if (tFrameCounter == 208 || gMain.newKeys != 0)
tState++;
else
tFrameCounter++;
break;
case 3:
ResetSpriteData();
DestroyTask(taskId);
CreateTask(Task_Scene1_Load, 0);
SetMainCallback2(MainCB2_Intro);
break;
}
}
#undef tState
void RhhIntro_InitCopyrightBgs() static void VBlankCB_ExpansionIntro(void)
{
LoadOam();
ProcessSpriteCopyRequests();
TransferPlttBuffer();
}
static void ExpansionIntro_InitBgs(void)
{ {
ResetBgsAndClearDma3BusyFlags(0); ResetBgsAndClearDma3BusyFlags(0);
InitBgsFromTemplates(0, sBgTemplates_RhhCopyrightScreen, ARRAY_COUNT(sBgTemplates_RhhCopyrightScreen)); InitBgsFromTemplates(0, sBgTemplates_RhhCopyrightScreen, ARRAY_COUNT(sBgTemplates_RhhCopyrightScreen));
@ -224,42 +285,41 @@ void RhhIntro_InitCopyrightBgs()
HideBg(0); HideBg(0);
HideBg(1); HideBg(1);
HideBg(2); HideBg(2);
ShowBg(3); HideBg(3);
} }
void RhhIntro_LoadCopyrightBgGraphics() static void ExpansionIntro_LoadGraphics(void)
{ {
LZ77UnCompVram(sBgTiles_PoweredBy, (void*) BG_CHAR_ADDR(sBgTemplates_RhhCopyrightScreen[BG_3].charBaseIndex)); LZ77UnCompVram(sBgTiles_PoweredBy, (void*) BG_CHAR_ADDR(sBgTemplates_RhhCopyrightScreen[EXPANSION_INTRO_BG3].charBaseIndex));
LZ77UnCompVram(sBgMap_PoweredBy, (u16*) BG_SCREEN_ADDR(sBgTemplates_RhhCopyrightScreen[BG_3].mapBaseIndex)); LZ77UnCompVram(sBgMap_PoweredBy, (u16*) BG_SCREEN_ADDR(sBgTemplates_RhhCopyrightScreen[EXPANSION_INTRO_BG3].mapBaseIndex));
LZ77UnCompVram(sBgTiles_RhhCredits, (void*) BG_CHAR_ADDR(sBgTemplates_RhhCopyrightScreen[BG_2].charBaseIndex)); LZ77UnCompVram(sBgTiles_RhhCredits, (void*) BG_CHAR_ADDR(sBgTemplates_RhhCopyrightScreen[EXPANSION_INTRO_BG2].charBaseIndex));
LZ77UnCompVram(sBgMap_RhhCredits, (u16*) BG_SCREEN_ADDR(sBgTemplates_RhhCopyrightScreen[BG_2].mapBaseIndex)); LZ77UnCompVram(sBgMap_RhhCredits, (u16*) BG_SCREEN_ADDR(sBgTemplates_RhhCopyrightScreen[EXPANSION_INTRO_BG2].mapBaseIndex));
LoadCompressedPalette(sBgPal_Credits, 0x00, 0x60); LoadCompressedPalette(sBgPal_Credits, 0x00, 0x60);
}
void RhhIntro_LoadCopyrightSpriteGraphics()
{
LoadCompressedSpriteSheet(&sSpriteSheet_DizzyEgg); LoadCompressedSpriteSheet(&sSpriteSheet_DizzyEgg);
LoadCompressedSpriteSheet(&sSpriteSheet_Porygon); LoadCompressedSpriteSheet(&sSpriteSheet_Porygon);
LoadSpritePalette(&sSpritePalette_DizzyEgg); LoadSpritePalette(&sSpritePalette_DizzyEgg);
LoadSpritePalette(&sSpritePalette_Porygon); LoadSpritePalette(&sSpritePalette_Porygon);
} }
void RhhIntro_CreateCopyRightSprites() static void ExpansionIntro_CreateSprites(void)
{ {
sDizzyId = CreateSprite(&sSpriteTemplate_DizzyEgg, 0, DIZZY_POS_Y, 0); u32 dizzyId, poryId;
gSprites[sDizzyId].x2 = DIZZY_POS_X;
sPoryId = CreateSprite(&sSpriteTemplate_Porygon, 0, PORY_POS_Y, 0); dizzyId = CreateSprite(&sSpriteTemplate_DizzyEgg, 0, DIZZY_POS_Y, 0);
gSprites[sPoryId].x2 = PORY_POS_X; gSprites[dizzyId].x2 = DIZZY_POS_X;
poryId = CreateSprite(&sSpriteTemplate_Porygon, 0, PORY_POS_Y, 0);
gSprites[poryId].x2 = PORY_POS_X;
} }
void RhhIntro_ShowRhhCredits() static void ExpansionIntro_StartBlend(void)
{ {
ShowBg(2); ShowBg(2);
CreateTask(Task_ShowRhhCredits, 0); CreateTask(Task_ExpansionIntro_HandleBlend, 0);
} }
static void Task_ShowRhhCredits(u8 taskId) static void Task_ExpansionIntro_HandleBlend(u8 taskId)
{ {
if (GetGpuReg(REG_OFFSET_BLDY) != 0) if (GetGpuReg(REG_OFFSET_BLDY) != 0)
{ {
@ -273,7 +333,7 @@ static void Task_ShowRhhCredits(u8 taskId)
} }
#define sTimer data[0] #define sTimer data[0]
static void SpriteCallbacK_DizzyWalking(struct Sprite* sprite) static void SpriteCallback_DizzyWalking(struct Sprite* sprite)
{ {
sprite->x2--; sprite->x2--;
@ -336,10 +396,4 @@ static void SpriteCallback_PorygonFlying(struct Sprite* sprite)
} }
#undef sTimer #undef sTimer
void RhhIntro_DestroyRhhCreditSprites() #endif //EXPANSION_INTRO
{
DestroySpriteAndFreeResources(&gSprites[sDizzyId]);
DestroySpriteAndFreeResources(&gSprites[sPoryId]);
}
#endif //RHH_COPYRIGHT_INTRO

View file

@ -23,7 +23,7 @@
#include "sound.h" #include "sound.h"
#include "util.h" #include "util.h"
#include "title_screen.h" #include "title_screen.h"
#include "rhh_copyright.h" #include "expansion_intro.h"
#include "constants/rgb.h" #include "constants/rgb.h"
#include "constants/battle_anim.h" #include "constants/battle_anim.h"
@ -38,7 +38,6 @@
*/ */
// Scene 1 main tasks // Scene 1 main tasks
static void Task_Scene1_Load(u8);
static void Task_Scene1_FadeIn(u8); static void Task_Scene1_FadeIn(u8);
static void Task_Scene1_WaterDrops(u8); static void Task_Scene1_WaterDrops(u8);
static void Task_Scene1_PanUp(u8); static void Task_Scene1_PanUp(u8);
@ -1025,18 +1024,6 @@ static const struct SpritePalette sSpritePalette_RayquazaOrb[] =
{}, {},
}; };
#if RHH_COPYRIGHT_INTRO == TRUE
static void VBlankCB_PretIntro()
{
LoadOam();
ProcessSpriteCopyRequests();
TransferPlttBuffer();
ScanlineEffect_InitHBlankDmaTransfer();
RunTasks();
AnimateSprites();
BuildOamBuffer();
}
#endif
static void VBlankCB_Intro(void) static void VBlankCB_Intro(void)
{ {
@ -1046,7 +1033,7 @@ static void VBlankCB_Intro(void)
ScanlineEffect_InitHBlankDmaTransfer(); ScanlineEffect_InitHBlankDmaTransfer();
} }
static void MainCB2_Intro(void) void MainCB2_Intro(void)
{ {
RunTasks(); RunTasks();
AnimateSprites(); AnimateSprites();
@ -1093,14 +1080,11 @@ static u8 SetUpCopyrightScreen(void)
CpuFill32(0, (void *)OAM, OAM_SIZE); CpuFill32(0, (void *)OAM, OAM_SIZE);
CpuFill16(0, (void *)(PLTT + 2), PLTT_SIZE - 2); CpuFill16(0, (void *)(PLTT + 2), PLTT_SIZE - 2);
ResetPaletteFade(); ResetPaletteFade();
#if RHH_COPYRIGHT_INTRO == FALSE
LoadCopyrightGraphics(0, 0x3800, BG_PLTT_ID(0)); LoadCopyrightGraphics(0, 0x3800, BG_PLTT_ID(0));
#endif
ScanlineEffect_Stop(); ScanlineEffect_Stop();
ResetTasks(); ResetTasks();
ResetSpriteData(); ResetSpriteData();
FreeAllSpritePalettes(); FreeAllSpritePalettes();
#if RHH_COPYRIGHT_INTRO == FALSE
BeginNormalPaletteFade(PALETTES_ALL, 0, 16, 0, RGB_WHITEALPHA); BeginNormalPaletteFade(PALETTES_ALL, 0, 16, 0, RGB_WHITEALPHA);
SetGpuReg(REG_OFFSET_BG0CNT, BGCNT_PRIORITY(0) SetGpuReg(REG_OFFSET_BG0CNT, BGCNT_PRIORITY(0)
| BGCNT_CHARBASE(0) | BGCNT_CHARBASE(0)
@ -1110,59 +1094,14 @@ static u8 SetUpCopyrightScreen(void)
EnableInterrupts(INTR_FLAG_VBLANK); EnableInterrupts(INTR_FLAG_VBLANK);
SetVBlankCallback(VBlankCB_Intro); SetVBlankCallback(VBlankCB_Intro);
REG_DISPCNT = DISPCNT_MODE_0 | DISPCNT_OBJ_1D_MAP | DISPCNT_BG0_ON; REG_DISPCNT = DISPCNT_MODE_0 | DISPCNT_OBJ_1D_MAP | DISPCNT_BG0_ON;
#else
SetGpuReg(REG_OFFSET_BG0CNT, BGCNT_PRIORITY(0)
| BGCNT_CHARBASE(0)
| BGCNT_SCREENBASE(7)
| BGCNT_16COLOR
| BGCNT_TXT256x256);
EnableInterrupts(INTR_FLAG_VBLANK);
REG_DISPCNT = DISPCNT_MODE_0 | DISPCNT_OBJ_1D_MAP | DISPCNT_BG0_ON;
gMain.state++;
break;
case 1:
RhhIntro_InitCopyrightBgs();
BeginNormalPaletteFade(PALETTES_ALL, 0, 0x10, 0, RGB_WHITEALPHA);
SetVBlankCallback(VBlankCB_PretIntro);
#endif
SetSerialCallback(SerialCB_CopyrightScreen); SetSerialCallback(SerialCB_CopyrightScreen);
GameCubeMultiBoot_Init(&gMultibootProgramStruct); GameCubeMultiBoot_Init(&gMultibootProgramStruct);
default: default:
#if RHH_COPYRIGHT_INTRO == TRUE
RunTasks();
UpdatePaletteFade();
gMain.state++;
GameCubeMultiBoot_Main(&gMultibootProgramStruct);
break;
case 30:
RhhIntro_LoadCopyrightBgGraphics();
BeginNormalPaletteFade(0x00000001, 0, 0x10, 0, RGB_BLACK);
UpdatePaletteFade();
GameCubeMultiBoot_Main(&gMultibootProgramStruct);
gMain.state++;
break;
case 31:
RhhIntro_LoadCopyrightSpriteGraphics();
RhhIntro_CreateCopyRightSprites();
UpdatePaletteFade();
GameCubeMultiBoot_Main(&gMultibootProgramStruct);
gMain.state++;
break;
case 45:
RhhIntro_ShowRhhCredits();
UpdatePaletteFade();
GameCubeMultiBoot_Main(&gMultibootProgramStruct);
gMain.state++;
break;
case 253:
#else
UpdatePaletteFade(); UpdatePaletteFade();
gMain.state++; gMain.state++;
GameCubeMultiBoot_Main(&gMultibootProgramStruct); GameCubeMultiBoot_Main(&gMultibootProgramStruct);
break; break;
case 140: case 140:
#endif
GameCubeMultiBoot_Main(&gMultibootProgramStruct); GameCubeMultiBoot_Main(&gMultibootProgramStruct);
if (gMultibootProgramStruct.gcmb_field_2 != 1) if (gMultibootProgramStruct.gcmb_field_2 != 1)
{ {
@ -1170,22 +1109,16 @@ static u8 SetUpCopyrightScreen(void)
gMain.state++; gMain.state++;
} }
break; break;
#if RHH_COPYRIGHT_INTRO == TRUE
case 254:
if (UpdatePaletteFade())
break;
RhhIntro_DestroyRhhCreditSprites();
gMain.state++;
break;
case 255:
#else
case 141: case 141:
if (UpdatePaletteFade()) if (UpdatePaletteFade())
break; break;
#endif #if EXPANSION_INTRO == TRUE
SetMainCallback2(CB2_ExpansionIntro);
CreateTask(Task_HandleExpansionIntro, 0);
#else
CreateTask(Task_Scene1_Load, 0); CreateTask(Task_Scene1_Load, 0);
SetMainCallback2(MainCB2_Intro); SetMainCallback2(MainCB2_Intro);
#endif
if (gMultibootProgramStruct.gcmb_field_2 != 0) if (gMultibootProgramStruct.gcmb_field_2 != 0)
{ {
if (gMultibootProgramStruct.gcmb_field_2 == 2) if (gMultibootProgramStruct.gcmb_field_2 == 2)
@ -1232,7 +1165,7 @@ void CB2_InitCopyrightScreenAfterTitleScreen(void)
#define sBigDropSpriteId data[0] #define sBigDropSpriteId data[0]
static void Task_Scene1_Load(u8 taskId) void Task_Scene1_Load(u8 taskId)
{ {
SetVBlankCallback(NULL); SetVBlankCallback(NULL);
sIntroCharacterGender = Random() & 1; sIntroCharacterGender = Random() & 1;

View file

@ -149,4 +149,3 @@
.include "src/trainer_hill.o" .include "src/trainer_hill.o"
.include "src/rayquaza_scene.o" .include "src/rayquaza_scene.o"
.include "src/debug.o" .include "src/debug.o"
.include "src/rhh_copyright.o"