re3-wiiu/src/core/main.cpp

2097 lines
52 KiB
C++
Raw Normal View History

2019-05-24 19:58:32 +02:00
#include "common.h"
#include "rpmatfx.h"
#include "rphanim.h"
2020-04-10 18:36:39 +02:00
#include "rpskin.h"
2020-08-14 17:57:23 +02:00
#include "rtbmp.h"
2020-04-17 15:31:11 +02:00
2019-06-17 10:30:02 +02:00
#include "main.h"
#include "CdStream.h"
2019-06-18 09:50:26 +02:00
#include "General.h"
#include "RwHelper.h"
#include "Clouds.h"
#include "Draw.h"
#include "Sprite2d.h"
2019-05-15 16:52:37 +02:00
#include "Renderer.h"
#include "Coronas.h"
#include "WaterLevel.h"
#include "Weather.h"
#include "Glass.h"
#include "WaterCannon.h"
#include "SpecialFX.h"
#include "Shadows.h"
#include "Skidmarks.h"
#include "Antennas.h"
#include "Rubbish.h"
#include "Particle.h"
#include "Pickups.h"
#include "WeaponEffects.h"
#include "PointLights.h"
#include "Fluff.h"
#include "Replay.h"
#include "Camera.h"
#include "World.h"
#include "Ped.h"
#include "Font.h"
#include "Pad.h"
#include "Hud.h"
#include "User.h"
#include "Messages.h"
#include "Darkel.h"
#include "Garages.h"
#include "MusicManager.h"
2019-05-31 11:44:43 +02:00
#include "VisibilityPlugins.h"
2019-06-12 14:35:15 +02:00
#include "NodeName.h"
2019-05-31 11:44:43 +02:00
#include "DMAudio.h"
#include "CutsceneMgr.h"
#include "Lights.h"
#include "Credits.h"
2019-07-07 13:09:11 +02:00
#include "ZoneCull.h"
2019-06-30 12:53:39 +02:00
#include "Timecycle.h"
2019-06-01 23:17:39 +02:00
#include "TxdStore.h"
#include "FileMgr.h"
#include "Text.h"
#include "RpAnimBlend.h"
#include "Frontend.h"
2019-08-15 16:51:39 +02:00
#include "AnimViewer.h"
2020-02-24 19:17:15 +01:00
#include "Script.h"
2020-04-10 18:36:39 +02:00
#include "PathFind.h"
2020-03-22 15:23:40 +01:00
#include "Debug.h"
#include "Console.h"
2020-03-31 12:30:13 +02:00
#include "timebars.h"
#include "GenericGameStorage.h"
2020-06-27 23:01:51 +02:00
#include "MemoryCard.h"
2020-04-13 20:50:56 +02:00
#include "SceneEdit.h"
2020-04-24 13:27:02 +02:00
#include "debugmenu.h"
2020-08-14 17:57:23 +02:00
#include "Clock.h"
2020-11-19 16:23:52 +01:00
#include "postfx.h"
2020-08-18 10:58:15 +02:00
#include "custompipes.h"
2020-11-19 16:23:52 +01:00
#include "screendroplets.h"
2020-10-28 03:11:34 +01:00
#include "frontendoption.h"
2020-11-26 16:47:19 +01:00
#include "MemoryHeap.h"
2020-04-17 07:54:14 +02:00
GlobalScene Scene;
2019-06-17 10:30:02 +02:00
2019-06-12 16:52:26 +02:00
uint8 work_buff[55000];
2020-04-17 07:54:14 +02:00
char gString[256];
char gString2[512];
wchar gUString[256];
wchar gUString2[256];
2019-07-24 18:55:43 +02:00
float FramesPerSecond = 30.0f;
bool gbPrintShite = false;
2020-04-17 07:54:14 +02:00
bool gbModelViewer;
2020-05-29 12:03:32 +02:00
#ifdef TIMEBARS
bool gbShowTimebars;
#endif
2019-07-24 18:55:43 +02:00
int32 frameCount;
RwRGBA gColourTop;
bool gameAlreadyInitialised;
2019-05-31 11:44:43 +02:00
float NumberOfChunksLoaded;
#ifdef GTA_PS2
#define TOTALNUMCHUNKS 48.0f
#else
#define TOTALNUMCHUNKS 73.0f
#endif
bool g_SlowMode = false;
char version_name[64];
2019-05-31 11:44:43 +02:00
2019-06-01 23:17:39 +02:00
void GameInit(void);
void SystemInit(void);
void TheGame(void);
2019-06-01 23:17:39 +02:00
2020-05-09 15:06:13 +02:00
#ifdef DEBUGMENU
2019-06-27 10:58:51 +02:00
void DebugMenuPopulate(void);
2020-05-09 15:06:13 +02:00
#endif
2019-05-31 11:44:43 +02:00
#ifndef FINAL
bool gbPrintMemoryUsage;
#endif
2020-11-26 16:47:19 +01:00
2020-12-04 01:12:58 +01:00
#ifdef PS2_MENU
2020-11-26 16:47:19 +01:00
#define WANT_TO_LOAD TheMemoryCard.m_bWantToLoad
#define FOUND_GAME_TO_LOAD TheMemoryCard.b_FoundRecentSavedGameWantToLoad
#else
#define WANT_TO_LOAD FrontEndMenuManager.m_bWantToLoad
#define FOUND_GAME_TO_LOAD b_FoundRecentSavedGameWantToLoad
#endif
2019-06-28 19:23:28 +02:00
void
ValidateVersion()
2019-06-28 19:23:28 +02:00
{
int32 file = CFileMgr::OpenFile("models\\coll\\peds.col", "rb");
char buff[128];
2019-06-28 19:23:28 +02:00
if ( file != -1 )
{
CFileMgr::Seek(file, 100, SEEK_SET);
for ( int i = 0; i < 128; i++ )
{
CFileMgr::Read(file, &buff[i], sizeof(char));
buff[i] -= 23;
if ( buff[i] == '\0' )
break;
CFileMgr::Seek(file, 99, SEEK_CUR);
}
if ( !strncmp(buff, "grandtheftauto3", 15) )
{
strncpy(version_name, &buff[15], 64);
CFileMgr::CloseFile(file);
return;
}
}
2019-08-15 16:51:39 +02:00
LoadingScreen("Invalid version", NULL, NULL);
while(true)
{
;
}
2019-08-15 16:51:39 +02:00
}
bool
DoRWStuffStartOfFrame(int16 TopRed, int16 TopGreen, int16 TopBlue, int16 BottomRed, int16 BottomGreen, int16 BottomBlue, int16 Alpha)
2019-05-31 11:44:43 +02:00
{
CRGBA TopColor(TopRed, TopGreen, TopBlue, Alpha);
CRGBA BottomColor(BottomRed, BottomGreen, BottomBlue, Alpha);
2020-05-24 15:41:29 +02:00
#ifndef ASPECT_RATIO_SCALE
CameraSize(Scene.camera, nil, SCREEN_VIEWWINDOW, (CMenuManager::m_PrefsUseWideScreen ? 16.f / 9.f : 4.f / 3.f));
#else
CameraSize(Scene.camera, nil, SCREEN_VIEWWINDOW, SCREEN_ASPECT_RATIO);
2020-05-24 15:41:29 +02:00
#endif
CVisibilityPlugins::SetRenderWareCamera(Scene.camera);
2020-05-24 15:41:29 +02:00
RwCameraClear(Scene.camera, &TopColor.rwRGBA, rwCAMERACLEARZ);
2020-03-31 12:30:13 +02:00
if(!RsCameraBeginUpdate(Scene.camera))
return false;
2020-03-31 12:30:13 +02:00
2019-05-31 11:44:43 +02:00
CSprite2d::InitPerFrame();
2020-03-31 12:30:13 +02:00
if(Alpha != 0)
CSprite2d::DrawRect(CRect(0.0f, 0.0f, SCREEN_WIDTH, SCREEN_HEIGHT), BottomColor, BottomColor, TopColor, TopColor);
return true;
}
2020-03-31 12:30:13 +02:00
bool
DoRWStuffStartOfFrame_Horizon(int16 TopRed, int16 TopGreen, int16 TopBlue, int16 BottomRed, int16 BottomGreen, int16 BottomBlue, int16 Alpha)
{
2020-05-24 15:41:29 +02:00
#ifndef ASPECT_RATIO_SCALE
CameraSize(Scene.camera, nil, SCREEN_VIEWWINDOW, (CMenuManager::m_PrefsUseWideScreen ? 16.f/9.f : 4.f/3.f));
#else
CameraSize(Scene.camera, nil, SCREEN_VIEWWINDOW, SCREEN_ASPECT_RATIO);
2020-05-24 15:41:29 +02:00
#endif
CVisibilityPlugins::SetRenderWareCamera(Scene.camera);
RwCameraClear(Scene.camera, &gColourTop, rwCAMERACLEARZ);
2020-03-31 12:30:13 +02:00
if(!RsCameraBeginUpdate(Scene.camera))
return false;
2019-05-31 11:44:43 +02:00
TheCamera.m_viewMatrix.Update();
CClouds::RenderBackground(TopRed, TopGreen, TopBlue, BottomRed, BottomGreen, BottomBlue, Alpha);
2019-05-31 11:44:43 +02:00
return true;
}
2019-05-31 11:44:43 +02:00
// This is certainly a very useful function
void
DoRWRenderHorizon(void)
{
CClouds::RenderHorizon();
}
2019-05-31 11:44:43 +02:00
void
DoFade(void)
{
if(CTimer::GetIsPaused())
2019-05-31 11:44:43 +02:00
return;
2020-06-27 23:01:51 +02:00
#ifdef PS2_MENU
if(TheMemoryCard.JustLoadedDontFadeInYet){
TheMemoryCard.JustLoadedDontFadeInYet = false;
TheMemoryCard.TimeStartedCountingForFade = CTimer::GetTimeInMilliseconds();
}
#else
if(JustLoadedDontFadeInYet){
JustLoadedDontFadeInYet = false;
TimeStartedCountingForFade = CTimer::GetTimeInMilliseconds();
}
2020-06-27 23:01:51 +02:00
#endif
2019-05-31 11:44:43 +02:00
2020-06-27 23:01:51 +02:00
#ifdef PS2_MENU
if(TheMemoryCard.StillToFadeOut){
if(CTimer::GetTimeInMilliseconds() - TheMemoryCard.TimeStartedCountingForFade > TheMemoryCard.TimeToStayFadedBeforeFadeOut){
TheMemoryCard.StillToFadeOut = false;
#else
if(StillToFadeOut){
if(CTimer::GetTimeInMilliseconds() - TimeStartedCountingForFade > TimeToStayFadedBeforeFadeOut){
StillToFadeOut = false;
2020-06-27 23:01:51 +02:00
#endif
TheCamera.Fade(3.0f, FADE_IN);
TheCamera.ProcessFade();
TheCamera.ProcessMusicFade();
2019-05-31 11:44:43 +02:00
}else{
TheCamera.SetFadeColour(0, 0, 0);
TheCamera.Fade(0.0f, FADE_OUT);
TheCamera.ProcessFade();
2019-05-31 11:44:43 +02:00
}
}
2019-05-31 11:44:43 +02:00
if(CDraw::FadeValue != 0 || CMenuManager::m_PrefsBrightness < 256){
CSprite2d *splash = LoadSplash(nil);
2019-05-31 11:44:43 +02:00
CRGBA fadeColor;
CRect rect;
int fadeValue = CDraw::FadeValue;
2020-04-19 18:34:08 +02:00
float brightness = Min(CMenuManager::m_PrefsBrightness, 256);
if(brightness <= 50)
brightness = 50;
if(FrontEndMenuManager.m_bMenuActive)
brightness = 256;
2019-05-31 11:44:43 +02:00
if(TheCamera.m_FadeTargetIsSplashScreen)
fadeValue = 0;
2019-05-31 11:44:43 +02:00
float fade = fadeValue + 256 - brightness;
if(fade == 0){
fadeColor.r = 0;
fadeColor.g = 0;
fadeColor.b = 0;
fadeColor.a = 0;
}else{
fadeColor.r = fadeValue * CDraw::FadeRed / fade;
fadeColor.g = fadeValue * CDraw::FadeGreen / fade;
fadeColor.b = fadeValue * CDraw::FadeBlue / fade;
int alpha = 255 - brightness*(256 - fadeValue)/256;
if(alpha < 0)
alpha = 0;
fadeColor.a = alpha;
}
2020-03-31 12:30:13 +02:00
if(TheCamera.m_WideScreenOn
#ifdef CUTSCENE_BORDERS_SWITCH
&& CMenuManager::m_PrefsCutsceneBorders
#endif
){
// what's this?
float y = SCREEN_HEIGHT/2 * TheCamera.m_ScreenReductionPercentage/100.0f;
rect.left = 0.0f;
rect.right = SCREEN_WIDTH;
#ifdef FIX_BUGS
rect.top = y - SCREEN_SCALE_Y(8.0f);
rect.bottom = SCREEN_HEIGHT - y - SCREEN_SCALE_Y(8.0f);
#else
rect.top = y - 8.0f;
rect.bottom = SCREEN_HEIGHT - y - 8.0f;
#endif // FIX_BUGS
}else{
rect.left = 0.0f;
rect.right = SCREEN_WIDTH;
rect.top = 0.0f;
rect.bottom = SCREEN_HEIGHT;
}
CSprite2d::DrawRect(rect, fadeColor);
2019-05-31 11:44:43 +02:00
if(CDraw::FadeValue != 0 && TheCamera.m_FadeTargetIsSplashScreen){
fadeColor.r = 255;
fadeColor.g = 255;
fadeColor.b = 255;
fadeColor.a = CDraw::FadeValue;
splash->Draw(CRect(0.0f, 0.0f, SCREEN_WIDTH, SCREEN_HEIGHT), fadeColor, fadeColor, fadeColor, fadeColor);
}
}
2019-05-31 11:44:43 +02:00
}
2020-08-14 17:57:23 +02:00
bool
RwGrabScreen(RwCamera *camera, RwChar *filename)
{
char temp[255];
RwImage *pImage = RsGrabScreen(camera);
bool result = true;
if (pImage == nil)
return false;
strcpy(temp, CFileMgr::GetRootDirName());
strcat(temp, filename);
if (RtBMPImageWrite(pImage, &temp[0]) == nil)
result = false;
RwImageDestroy(pImage);
return result;
}
#define TILE_WIDTH 576
#define TILE_HEIGHT 432
2019-05-31 11:44:43 +02:00
void
DoRWStuffEndOfFrame(void)
2019-05-31 11:44:43 +02:00
{
CDebug::DisplayScreenStrings(); // custom
CDebug::DebugDisplayTextBuffer();
FlushObrsPrintfs();
RwCameraEndUpdate(Scene.camera);
RsCameraShowRaster(Scene.camera);
2020-08-14 17:57:23 +02:00
#ifndef MASTER
char s[48];
if (CPad::GetPad(1)->GetLeftShockJustDown()) {
// try using both controllers for this thing... crazy bastards
if (CPad::GetPad(0)->GetRightStickY() > 0) {
sprintf(s, "screen%d%d.ras", CClock::ms_nGameClockHours, CClock::ms_nGameClockMinutes);
// TODO
//RtTileRender(Scene.camera, TILE_WIDTH * 2, TILE_HEIGHT * 2, TILE_WIDTH, TILE_HEIGHT, &NewTileRendererCB, nil, s);
} else {
sprintf(s, "screen%d%d.bmp", CClock::ms_nGameClockHours, CClock::ms_nGameClockMinutes);
RwGrabScreen(Scene.camera, s);
}
}
#endif // !MASTER
}
2019-05-31 11:44:43 +02:00
static RwBool
PluginAttach(void)
{
if( !RpWorldPluginAttach() )
{
printf("Couldn't attach world plugin\n");
return FALSE;
}
if( !RpSkinPluginAttach() )
{
printf("Couldn't attach RpSkin plugin\n");
return FALSE;
}
if( !RpHAnimPluginAttach() )
{
printf("Couldn't attach RpHAnim plugin\n");
return FALSE;
}
if( !NodeNamePluginAttach() )
{
printf("Couldn't attach node name plugin\n");
return FALSE;
}
if( !CVisibilityPlugins::PluginAttach() )
{
printf("Couldn't attach visibility plugins\n");
return FALSE;
}
if( !RpAnimBlendPluginAttach() )
{
printf("Couldn't attach RpAnimBlend plugin\n");
return FALSE;
}
if( !RpMatFXPluginAttach() )
{
printf("Couldn't attach RpMatFX plugin\n");
return FALSE;
}
2020-08-18 10:58:15 +02:00
#ifdef EXTENDED_PIPELINES
CustomPipes::CustomPipeRegister();
#endif
2019-05-31 11:44:43 +02:00
return TRUE;
2019-05-31 11:44:43 +02:00
}
static RwBool
Initialise3D(void *param)
2019-06-01 23:17:39 +02:00
{
2020-05-23 11:34:40 +02:00
if (RsRwInitialize(param))
{
2020-05-09 15:06:13 +02:00
#ifdef DEBUGMENU
DebugMenuInit();
DebugMenuPopulate();
2020-05-09 15:06:13 +02:00
#endif // !DEBUGMENU
2020-10-28 03:11:34 +01:00
#ifdef CUSTOM_FRONTEND_OPTIONS
// Apparently this func. can be run multiple times at the start.
if (numCustomFrontendOptions == 0 && numCustomFrontendScreens == 0) {
// needs stored language and TheText to be loaded, and last TheText reload is at the start of here
CustomFrontendOptionsPopulate();
}
#endif
2020-08-18 10:58:15 +02:00
bool ret = CGame::InitialiseRenderWare();
#ifdef EXTENDED_PIPELINES
CustomPipes::CustomPipeInit(); // need Scene.world for this
2020-11-19 16:23:52 +01:00
#endif
#ifdef SCREEN_DROPLETS
ScreenDroplets::InitDraw();
2020-08-18 10:58:15 +02:00
#endif
return ret;
}
2019-06-01 23:17:39 +02:00
return (FALSE);
}
2019-06-01 23:17:39 +02:00
static void
Terminate3D(void)
{
2020-11-19 16:23:52 +01:00
#ifdef SCREEN_DROPLETS
ScreenDroplets::Shutdown();
#endif
2020-08-18 10:58:15 +02:00
#ifdef EXTENDED_PIPELINES
CustomPipes::CustomPipeShutdown();
#endif
CGame::ShutdownRenderWare();
2020-05-09 15:06:13 +02:00
#ifdef DEBUGMENU
2020-04-25 00:40:14 +02:00
DebugMenuShutdown();
2020-05-09 15:06:13 +02:00
#endif // !DEBUGMENU
RsRwTerminate();
2019-06-01 23:17:39 +02:00
return;
2019-06-01 23:17:39 +02:00
}
CSprite2d splash;
int splashTxdId = -1;
CSprite2d*
LoadSplash(const char *name)
2019-05-31 11:44:43 +02:00
{
RwTexDictionary *txd;
char filename[140];
RwTexture *tex = nil;
2019-05-31 11:44:43 +02:00
if(name == nil)
return &splash;
if(splashTxdId == -1)
splashTxdId = CTxdStore::AddTxdSlot("splash");
2019-05-31 11:44:43 +02:00
txd = CTxdStore::GetSlot(splashTxdId)->texDict;
if(txd)
tex = RwTexDictionaryFindNamedTexture(txd, name);
// if texture is found, splash was already set up below
2019-05-31 11:44:43 +02:00
if(tex == nil){
CFileMgr::SetDir("TXD\\");
sprintf(filename, "%s.txd", name);
if(splash.m_pTexture)
splash.Delete();
if(txd)
CTxdStore::RemoveTxd(splashTxdId);
CTxdStore::LoadTxd(splashTxdId, filename);
CTxdStore::AddRef(splashTxdId);
CTxdStore::PushCurrentTxd();
CTxdStore::SetCurrentTxd(splashTxdId);
splash.SetTexture(name);
CTxdStore::PopCurrentTxd();
CFileMgr::SetDir("");
}
2019-05-31 11:44:43 +02:00
return &splash;
2019-05-31 11:44:43 +02:00
}
void
DestroySplashScreen(void)
2019-05-15 16:52:37 +02:00
{
splash.Delete();
if(splashTxdId != -1)
CTxdStore::RemoveTxdSlot(splashTxdId);
splashTxdId = -1;
2019-05-15 16:52:37 +02:00
}
2020-05-12 01:24:57 +02:00
Const char*
GetRandomSplashScreen(void)
2019-05-15 16:52:37 +02:00
{
int index;
static int index2 = 0;
static char splashName[128];
static int splashIndex[24] = {
25, 22, 4, 13,
1, 21, 14, 16,
10, 12, 5, 9,
11, 18, 3, 2,
19, 23, 7, 17,
15, 6, 8, 20
};
index = splashIndex[4*index2 + CGeneral::GetRandomNumberInRange(0, 3)];
index2++;
if(index2 == 6)
index2 = 0;
sprintf(splashName, "loadsc%d", index);
return splashName;
2019-05-15 16:52:37 +02:00
}
2020-05-12 01:24:57 +02:00
Const char*
GetLevelSplashScreen(int level)
2019-05-24 19:58:32 +02:00
{
2020-05-12 01:24:57 +02:00
static Const char *splashScreens[4] = {
nil,
"splash1",
"splash2",
"splash3",
};
return splashScreens[level];
2019-05-24 19:58:32 +02:00
}
void
ResetLoadingScreenBar()
2019-05-15 16:52:37 +02:00
{
NumberOfChunksLoaded = 0.0f;
2019-05-15 16:52:37 +02:00
}
void
LoadingScreen(const char *str1, const char *str2, const char *splashscreen)
2019-05-15 16:52:37 +02:00
{
CSprite2d *splash;
2020-07-09 20:48:43 +02:00
#ifdef DISABLE_LOADING_SCREEN
if (str1 && str2)
return;
#endif
#ifndef RANDOMSPLASH
if(CGame::frenchGame || CGame::germanGame || !CGame::nastyGame)
splashscreen = "mainsc2";
else
splashscreen = "mainsc1";
#endif
splash = LoadSplash(splashscreen);
2020-04-09 05:20:44 +02:00
#ifndef GTA_PS2
if(RsGlobal.quit)
return;
2020-04-09 05:20:44 +02:00
#endif
if(DoRWStuffStartOfFrame(0, 0, 0, 0, 0, 0, 255)){
CSprite2d::SetRecipNearClip();
CSprite2d::InitPerFrame();
CFont::InitPerFrame();
DefinedState();
RwRenderStateSet(rwRENDERSTATETEXTUREADDRESS, (void*)rwTEXTUREADDRESSCLAMP);
splash->Draw(CRect(0.0f, 0.0f, SCREEN_WIDTH, SCREEN_HEIGHT), CRGBA(255, 255, 255, 255));
if(str1){
NumberOfChunksLoaded += 1;
float hpos = SCREEN_SCALE_X(40);
float length = SCREEN_WIDTH - SCREEN_SCALE_X(100);
float vpos = SCREEN_HEIGHT - SCREEN_SCALE_Y(13);
float height = SCREEN_SCALE_Y(7);
CSprite2d::DrawRect(CRect(hpos, vpos, hpos + length, vpos + height), CRGBA(40, 53, 68, 255));
2019-05-15 16:52:37 +02:00
length *= NumberOfChunksLoaded/TOTALNUMCHUNKS;
CSprite2d::DrawRect(CRect(hpos, vpos, hpos + length, vpos + height), CRGBA(81, 106, 137, 255));
2019-05-31 11:44:43 +02:00
// this is done by the game but is unused
CFont::SetScale(SCREEN_SCALE_X(2), SCREEN_SCALE_Y(2));
CFont::SetPropOn();
CFont::SetRightJustifyOn();
CFont::SetFontStyle(FONT_HEADING);
2019-05-15 16:52:37 +02:00
#ifdef CHATTYSPLASH
// my attempt
static wchar tmpstr[80];
float yscale = SCREEN_SCALE_Y(0.9f);
vpos -= 45*yscale;
CFont::SetScale(SCREEN_SCALE_X(0.75f), yscale);
CFont::SetPropOn();
CFont::SetRightJustifyOff();
CFont::SetFontStyle(FONT_BANK);
CFont::SetColor(CRGBA(255, 255, 255, 255));
AsciiToUnicode(str1, tmpstr);
CFont::PrintString(hpos, vpos, tmpstr);
vpos += 22*yscale;
if (str2) {
AsciiToUnicode(str2, tmpstr);
CFont::PrintString(hpos, vpos, tmpstr);
}
#endif
}
2019-05-15 16:52:37 +02:00
CFont::DrawFonts();
DoRWStuffEndOfFrame();
}
}
2019-05-15 16:52:37 +02:00
void
LoadingIslandScreen(const char *levelName)
{
CSprite2d *splash;
wchar *name;
char str[100];
wchar wstr[80];
CRGBA col;
splash = LoadSplash(nil);
name = TheText.Get(levelName);
if(!DoRWStuffStartOfFrame(0, 0, 0, 0, 0, 0, 255))
return;
2019-05-15 16:52:37 +02:00
CSprite2d::SetRecipNearClip();
CSprite2d::InitPerFrame();
CFont::InitPerFrame();
DefinedState();
col = CRGBA(255, 255, 255, 255);
splash->Draw(CRect(0.0f, 0.0f, SCREEN_WIDTH, SCREEN_HEIGHT), col, col, col, col);
CFont::SetBackgroundOff();
CFont::SetScale(1.5f, 1.5f);
CFont::SetPropOn();
CFont::SetRightJustifyOn();
CFont::SetRightJustifyWrap(SCREEN_SCALE_X(150.0f));
CFont::SetFontStyle(FONT_HEADING);
sprintf(str, "WELCOME TO");
AsciiToUnicode(str, wstr);
CFont::SetDropColor(CRGBA(0, 0, 0, 255));
CFont::SetDropShadowPosition(3);
CFont::SetColor(CRGBA(243, 237, 71, 255));
CFont::SetScale(SCREEN_SCALE_X(1.2f), SCREEN_SCALE_Y(1.2f));
CFont::PrintString(SCREEN_SCALE_FROM_RIGHT(20.0f), SCREEN_STRETCH_FROM_BOTTOM(110.0f), TheText.Get("WELCOME"));
TextCopy(wstr, name);
TheText.UpperCase(wstr);
CFont::SetColor(CRGBA(243, 237, 71, 255));
CFont::SetScale(SCREEN_SCALE_X(1.2f), SCREEN_SCALE_Y(1.2f));
CFont::PrintString(SCREEN_SCALE_FROM_RIGHT(20.0f), SCREEN_STRETCH_FROM_BOTTOM(80.0f), wstr);
CFont::DrawFonts();
DoRWStuffEndOfFrame();
}
2019-05-15 16:52:37 +02:00
void
ProcessSlowMode(void)
{
int16 lX = CPad::GetPad(0)->NewState.LeftStickX;
int16 lY = CPad::GetPad(0)->NewState.LeftStickY;
int16 rX = CPad::GetPad(0)->NewState.RightStickX;
int16 rY = CPad::GetPad(0)->NewState.RightStickY;
int16 L1 = CPad::GetPad(0)->NewState.LeftShoulder1;
int16 L2 = CPad::GetPad(0)->NewState.LeftShoulder2;
int16 R1 = CPad::GetPad(0)->NewState.RightShoulder1;
int16 R2 = CPad::GetPad(0)->NewState.RightShoulder2;
int16 up = CPad::GetPad(0)->NewState.DPadUp;
int16 down = CPad::GetPad(0)->NewState.DPadDown;
int16 left = CPad::GetPad(0)->NewState.DPadLeft;
int16 right = CPad::GetPad(0)->NewState.DPadRight;
int16 start = CPad::GetPad(0)->NewState.Start;
int16 select = CPad::GetPad(0)->NewState.Select;
int16 square = CPad::GetPad(0)->NewState.Square;
int16 triangle = CPad::GetPad(0)->NewState.Triangle;
int16 cross = CPad::GetPad(0)->NewState.Cross;
int16 circle = CPad::GetPad(0)->NewState.Circle;
int16 L3 = CPad::GetPad(0)->NewState.LeftShock;
int16 R3 = CPad::GetPad(0)->NewState.RightShock;
int16 networktalk = CPad::GetPad(0)->NewState.NetworkTalk;
int16 stop = true;
do
{
if ( CPad::GetPad(1)->GetLeftShoulder1JustDown() || CPad::GetPad(1)->GetRightShoulder1() )
break;
if ( stop )
{
CTimer::Stop();
stop = false;
}
CPad::UpdatePads();
RwCameraBeginUpdate(Scene.camera);
RwCameraEndUpdate(Scene.camera);
if ( CPad::GetPad(1)->GetLeftShoulder1JustDown() || CPad::GetPad(1)->GetRightShoulder1() )
break;
} while (!CPad::GetPad(1)->GetRightShoulder1());
CPad::GetPad(0)->OldState.LeftStickX = lX;
CPad::GetPad(0)->OldState.LeftStickY = lY;
CPad::GetPad(0)->OldState.RightStickX = rX;
CPad::GetPad(0)->OldState.RightStickY = rY;
CPad::GetPad(0)->OldState.LeftShoulder1 = L1;
CPad::GetPad(0)->OldState.LeftShoulder2 = L2;
CPad::GetPad(0)->OldState.RightShoulder1 = R1;
CPad::GetPad(0)->OldState.RightShoulder2 = R2;
CPad::GetPad(0)->OldState.DPadUp = up;
CPad::GetPad(0)->OldState.DPadDown = down;
CPad::GetPad(0)->OldState.DPadLeft = left;
CPad::GetPad(0)->OldState.DPadRight = right;
CPad::GetPad(0)->OldState.Start = start;
CPad::GetPad(0)->OldState.Select = select;
CPad::GetPad(0)->OldState.Square = square;
CPad::GetPad(0)->OldState.Triangle = triangle;
CPad::GetPad(0)->OldState.Cross = cross;
CPad::GetPad(0)->OldState.Circle = circle;
CPad::GetPad(0)->OldState.LeftShock = L3;
CPad::GetPad(0)->OldState.RightShock = R3;
CPad::GetPad(0)->OldState.NetworkTalk = networktalk;
CPad::GetPad(0)->NewState.LeftStickX = lX;
CPad::GetPad(0)->NewState.LeftStickY = lY;
CPad::GetPad(0)->NewState.RightStickX = rX;
CPad::GetPad(0)->NewState.RightStickY = rY;
CPad::GetPad(0)->NewState.LeftShoulder1 = L1;
CPad::GetPad(0)->NewState.LeftShoulder2 = L2;
CPad::GetPad(0)->NewState.RightShoulder1 = R1;
CPad::GetPad(0)->NewState.RightShoulder2 = R2;
CPad::GetPad(0)->NewState.DPadUp = up;
CPad::GetPad(0)->NewState.DPadDown = down;
CPad::GetPad(0)->NewState.DPadLeft = left;
CPad::GetPad(0)->NewState.DPadRight = right;
CPad::GetPad(0)->NewState.Start = start;
CPad::GetPad(0)->NewState.Select = select;
CPad::GetPad(0)->NewState.Square = square;
CPad::GetPad(0)->NewState.Triangle = triangle;
CPad::GetPad(0)->NewState.Cross = cross;
CPad::GetPad(0)->NewState.Circle = circle;
CPad::GetPad(0)->NewState.LeftShock = L3;
CPad::GetPad(0)->NewState.RightShock = R3;
CPad::GetPad(0)->NewState.NetworkTalk = networktalk;
}
2019-05-15 16:52:37 +02:00
float FramesPerSecondCounter;
int32 FrameSamples;
struct tZonePrint
{
char name[12];
CRect rect;
};
2019-07-24 18:55:43 +02:00
tZonePrint ZonePrint[] =
{
{ "suburban", CRect(-1639.4f, 1014.3f, -226.23f, -1347.9f) },
{ "comntop", CRect(-223.52f, 203.62f, 616.79f, -413.6f) },
{ "comnbtm", CRect(-227.24f, -413.6f, 620.51f, -911.84f) },
{ "comse", CRect( 200.35f, -911.84f, 620.51f, -1737.3f) },
{ "comsw", CRect(-223.52f, -911.84f, 200.35f, -1737.3f) },
{ "industsw", CRect( 744.05f, -473.0f, 1067.5f, -1331.5f) },
{ "industne", CRect( 1067.5f, 282.19f, 1915.3f, -473.0f) },
{ "industnw", CRect( 744.05f, 324.95f, 1067.5f, -473.0f) },
{ "industse", CRect( 1070.3f, -473.0f, 1918.1f, -1331.5f) },
{ "no zone", CRect( 0.0f, 0.0f, 0.0f, 0.0f) }
};
#ifndef MASTER
2020-11-26 16:47:19 +01:00
void
PrintMemoryUsage(void)
{
// little hack
if(CPools::GetPtrNodePool() == nil)
return;
// Style taken from LCS, modified for III
// CFont::SetFontStyle(FONT_PAGER);
CFont::SetFontStyle(FONT_BANK);
CFont::SetBackgroundOff();
CFont::SetWrapx(640.0f);
// CFont::SetScale(0.5f, 0.75f);
CFont::SetScale(0.4f, 0.75f);
CFont::SetCentreOff();
CFont::SetCentreSize(640.0f);
CFont::SetJustifyOff();
CFont::SetPropOn();
CFont::SetColor(CRGBA(200, 200, 200, 200));
CFont::SetBackGroundOnlyTextOff();
CFont::SetDropShadowPosition(0);
float y;
#ifdef USE_CUSTOM_ALLOCATOR
y = 24.0f;
sprintf(gString, "Total: %d blocks, %d bytes", gMainHeap.m_totalBlocksUsed, gMainHeap.m_totalMemUsed);
AsciiToUnicode(gString, gUString);
CFont::PrintString(24.0f, y, gUString);
y += 12.0f;
sprintf(gString, "Game: %d blocks, %d bytes", gMainHeap.GetBlocksUsed(MEMID_GAME), gMainHeap.GetMemoryUsed(MEMID_GAME));
AsciiToUnicode(gString, gUString);
CFont::PrintString(24.0f, y, gUString);
y += 12.0f;
sprintf(gString, "World: %d blocks, %d bytes", gMainHeap.GetBlocksUsed(MEMID_WORLD), gMainHeap.GetMemoryUsed(MEMID_WORLD));
AsciiToUnicode(gString, gUString);
CFont::PrintString(24.0f, y, gUString);
y += 12.0f;
sprintf(gString, "Render: %d blocks, %d bytes", gMainHeap.GetBlocksUsed(MEMID_RENDER), gMainHeap.GetMemoryUsed(MEMID_RENDER));
AsciiToUnicode(gString, gUString);
CFont::PrintString(24.0f, y, gUString);
y += 12.0f;
sprintf(gString, "Render List: %d blocks, %d bytes", gMainHeap.GetBlocksUsed(MEMID_RENDERLIST), gMainHeap.GetMemoryUsed(MEMID_RENDERLIST));
AsciiToUnicode(gString, gUString);
CFont::PrintString(24.0f, y, gUString);
y += 12.0f;
sprintf(gString, "Default Models: %d blocks, %d bytes", gMainHeap.GetBlocksUsed(MEMID_DEF_MODELS), gMainHeap.GetMemoryUsed(MEMID_DEF_MODELS));
AsciiToUnicode(gString, gUString);
CFont::PrintString(24.0f, y, gUString);
y += 12.0f;
sprintf(gString, "Textures: %d blocks, %d bytes", gMainHeap.GetBlocksUsed(MEMID_TEXTURES), gMainHeap.GetMemoryUsed(MEMID_TEXTURES));
AsciiToUnicode(gString, gUString);
CFont::PrintString(24.0f, y, gUString);
y += 12.0f;
sprintf(gString, "Streaming: %d blocks, %d bytes", gMainHeap.GetBlocksUsed(MEMID_STREAM), gMainHeap.GetMemoryUsed(MEMID_STREAM));
AsciiToUnicode(gString, gUString);
CFont::PrintString(24.0f, y, gUString);
y += 12.0f;
sprintf(gString, "Streamed Models: %d blocks, %d bytes", gMainHeap.GetBlocksUsed(MEMID_STREAM_MODELS), gMainHeap.GetMemoryUsed(MEMID_STREAM_MODELS));
AsciiToUnicode(gString, gUString);
CFont::PrintString(24.0f, y, gUString);
y += 12.0f;
sprintf(gString, "Streamed Textures: %d blocks, %d bytes", gMainHeap.GetBlocksUsed(MEMID_STREAM_TEXUTRES), gMainHeap.GetMemoryUsed(MEMID_STREAM_TEXUTRES));
AsciiToUnicode(gString, gUString);
CFont::PrintString(24.0f, y, gUString);
y += 12.0f;
sprintf(gString, "Animation: %d blocks, %d bytes", gMainHeap.GetBlocksUsed(MEMID_ANIMATION), gMainHeap.GetMemoryUsed(MEMID_ANIMATION));
AsciiToUnicode(gString, gUString);
CFont::PrintString(24.0f, y, gUString);
y += 12.0f;
sprintf(gString, "Pools: %d blocks, %d bytes", gMainHeap.GetBlocksUsed(MEMID_POOLS), gMainHeap.GetMemoryUsed(MEMID_POOLS));
AsciiToUnicode(gString, gUString);
CFont::PrintString(24.0f, y, gUString);
y += 12.0f;
sprintf(gString, "Collision: %d blocks, %d bytes", gMainHeap.GetBlocksUsed(MEMID_COLLISION), gMainHeap.GetMemoryUsed(MEMID_COLLISION));
AsciiToUnicode(gString, gUString);
CFont::PrintString(24.0f, y, gUString);
y += 12.0f;
sprintf(gString, "Game Process: %d blocks, %d bytes", gMainHeap.GetBlocksUsed(MEMID_GAME_PROCESS), gMainHeap.GetMemoryUsed(MEMID_GAME_PROCESS));
AsciiToUnicode(gString, gUString);
CFont::PrintString(24.0f, y, gUString);
y += 12.0f;
sprintf(gString, "Script: %d blocks, %d bytes", gMainHeap.GetBlocksUsed(MEMID_SCRIPT), gMainHeap.GetMemoryUsed(MEMID_SCRIPT));
AsciiToUnicode(gString, gUString);
CFont::PrintString(24.0f, y, gUString);
y += 12.0f;
sprintf(gString, "Cars: %d blocks, %d bytes", gMainHeap.GetBlocksUsed(MEMID_CARS), gMainHeap.GetMemoryUsed(MEMID_CARS));
AsciiToUnicode(gString, gUString);
CFont::PrintString(24.0f, y, gUString);
y += 12.0f;
sprintf(gString, "Frontend: %d blocks, %d bytes", gMainHeap.GetBlocksUsed(MEMID_FRONTEND), gMainHeap.GetMemoryUsed(MEMID_FRONTEND));
AsciiToUnicode(gString, gUString);
CFont::PrintString(24.0f, y, gUString);
y += 12.0f;
#endif
y = 132.0f;
AsciiToUnicode("Pools usage:", gUString);
CFont::PrintString(400.0f, y, gUString);
y += 12.0f;
sprintf(gString, "PtrNode: %d/%d", CPools::GetPtrNodePool()->GetNoOfUsedSpaces(), CPools::GetPtrNodePool()->GetSize());
AsciiToUnicode(gString, gUString);
CFont::PrintString(400.0f, y, gUString);
y += 12.0f;
sprintf(gString, "EntryInfoNode: %d/%d", CPools::GetEntryInfoNodePool()->GetNoOfUsedSpaces(), CPools::GetEntryInfoNodePool()->GetSize());
AsciiToUnicode(gString, gUString);
CFont::PrintString(400.0f, y, gUString);
y += 12.0f;
sprintf(gString, "Ped: %d/%d", CPools::GetPedPool()->GetNoOfUsedSpaces(), CPools::GetPedPool()->GetSize());
AsciiToUnicode(gString, gUString);
CFont::PrintString(400.0f, y, gUString);
y += 12.0f;
sprintf(gString, "Vehicle: %d/%d", CPools::GetVehiclePool()->GetNoOfUsedSpaces(), CPools::GetVehiclePool()->GetSize());
AsciiToUnicode(gString, gUString);
CFont::PrintString(400.0f, y, gUString);
y += 12.0f;
sprintf(gString, "Building: %d/%d", CPools::GetBuildingPool()->GetNoOfUsedSpaces(), CPools::GetBuildingPool()->GetSize());
AsciiToUnicode(gString, gUString);
CFont::PrintString(400.0f, y, gUString);
y += 12.0f;
sprintf(gString, "Treadable: %d/%d", CPools::GetTreadablePool()->GetNoOfUsedSpaces(), CPools::GetTreadablePool()->GetSize());
AsciiToUnicode(gString, gUString);
CFont::PrintString(400.0f, y, gUString);
y += 12.0f;
sprintf(gString, "Object: %d/%d", CPools::GetObjectPool()->GetNoOfUsedSpaces(), CPools::GetObjectPool()->GetSize());
AsciiToUnicode(gString, gUString);
CFont::PrintString(400.0f, y, gUString);
y += 12.0f;
sprintf(gString, "Dummy: %d/%d", CPools::GetDummyPool()->GetNoOfUsedSpaces(), CPools::GetDummyPool()->GetSize());
AsciiToUnicode(gString, gUString);
CFont::PrintString(400.0f, y, gUString);
y += 12.0f;
sprintf(gString, "AudioScriptObjects: %d/%d", CPools::GetAudioScriptObjectPool()->GetNoOfUsedSpaces(), CPools::GetAudioScriptObjectPool()->GetSize());
AsciiToUnicode(gString, gUString);
CFont::PrintString(400.0f, y, gUString);
y += 12.0f;
}
2019-07-24 18:55:43 +02:00
void
DisplayGameDebugText()
{
static bool bDisplayPosn = false;
2019-07-24 19:30:09 +02:00
static bool bDisplayRate = false;
2020-09-25 23:24:30 +02:00
#ifndef FINAL
2019-07-24 18:55:43 +02:00
{
SETTWEAKPATH("GameDebugText");
TWEAKBOOL(bDisplayPosn);
TWEAKBOOL(bDisplayRate);
}
if(gbPrintMemoryUsage)
PrintMemoryUsage();
#endif
2019-07-24 18:55:43 +02:00
char str[200];
wchar ustr[200];
#ifdef DRAW_GAME_VERSION_TEXT
2019-07-24 18:55:43 +02:00
wchar ver[200];
AsciiToUnicode(version_name, ver);
CFont::SetPropOn();
CFont::SetBackgroundOff();
CFont::SetFontStyle(FONT_BANK);
2020-04-15 18:19:45 +02:00
CFont::SetScale(SCREEN_SCALE_X(0.5f), SCREEN_SCALE_Y(0.5f));
2019-07-24 18:55:43 +02:00
CFont::SetCentreOff();
CFont::SetRightJustifyOff();
CFont::SetWrapx(SCREEN_WIDTH);
CFont::SetJustifyOff();
CFont::SetBackGroundOnlyTextOff();
CFont::SetColor(CRGBA(255, 108, 0, 255));
2020-04-15 18:19:45 +02:00
CFont::PrintString(SCREEN_SCALE_X(10.0f), SCREEN_SCALE_Y(10.0f), ver);
#endif
2019-07-24 18:55:43 +02:00
FrameSamples++;
FramesPerSecondCounter += 1000.0f / (CTimer::GetTimeStepNonClippedInSeconds() * 1000.0f);
FramesPerSecond = FramesPerSecondCounter / FrameSamples;
if ( FrameSamples > 30 )
{
FramesPerSecondCounter = 0.0f;
FrameSamples = 0;
}
if ( !TheCamera.WorldViewerBeingUsed
&& CPad::GetPad(1)->GetSquare()
&& CPad::GetPad(1)->GetTriangle()
&& CPad::GetPad(1)->GetLeftShoulder2JustDown() )
{
bDisplayPosn = !bDisplayPosn;
}
if ( CPad::GetPad(1)->GetSquare()
&& CPad::GetPad(1)->GetTriangle()
&& CPad::GetPad(1)->GetRightShoulder2JustDown() )
{
bDisplayRate = !bDisplayRate;
}
if ( bDisplayPosn || bDisplayRate )
{
CVector pos = FindPlayerCoors();
int32 ZoneId = ARRAY_SIZE(ZonePrint)-1; // no zone
for ( int32 i = 0; i < ARRAY_SIZE(ZonePrint)-1; i++ )
{
if ( pos.x > ZonePrint[i].rect.left
&& pos.x < ZonePrint[i].rect.right
&& pos.y > ZonePrint[i].rect.bottom
&& pos.y < ZonePrint[i].rect.top )
{
ZoneId = i;
}
}
//NOTE: fps should be 30, but its 29 due to different fp2int conversion
if ( bDisplayRate )
sprintf(str, "X:%5.1f, Y:%5.1f, Z:%5.1f, F-%d, %s", pos.x, pos.y, pos.z, (int32)FramesPerSecond, ZonePrint[ZoneId].name);
else
sprintf(str, "X:%5.1f, Y:%5.1f, Z:%5.1f, %s", pos.x, pos.y, pos.z, ZonePrint[ZoneId].name);
AsciiToUnicode(str, ustr);
2020-04-15 18:19:45 +02:00
// Let's not scale those numbers, they look better that way :eyes:
2019-07-24 18:55:43 +02:00
CFont::SetPropOff();
CFont::SetBackgroundOff();
CFont::SetScale(0.7f, 1.5f);
CFont::SetCentreOff();
CFont::SetRightJustifyOff();
CFont::SetJustifyOff();
CFont::SetBackGroundOnlyTextOff();
CFont::SetWrapx(SCREEN_STRETCH_X(DEFAULT_SCREEN_WIDTH));
2019-07-24 18:55:43 +02:00
CFont::SetFontStyle(FONT_HEADING);
CFont::SetColor(CRGBA(0, 0, 0, 255));
CFont::PrintString(42.0f, 42.0f, ustr);
CFont::SetColor(CRGBA(255, 108, 0, 255));
CFont::PrintString(40.0f, 40.0f, ustr);
}
}
#endif
void
RenderScene(void)
{
CClouds::Render();
DoRWRenderHorizon();
CRenderer::RenderRoads();
CCoronas::RenderReflections();
RwRenderStateSet(rwRENDERSTATEFOGENABLE, (void*)TRUE);
CRenderer::RenderEverythingBarRoads();
CRenderer::RenderBoats();
DefinedState();
CWaterLevel::RenderWater();
CRenderer::RenderFadingInEntities();
#ifndef SQUEEZE_PERFORMANCE
CRenderer::RenderVehiclesButNotBoats();
#endif
CWeather::RenderRainStreaks();
}
2019-07-24 18:55:43 +02:00
void
RenderDebugShit(void)
{
CTheScripts::RenderTheScriptDebugLines();
2020-04-10 18:36:39 +02:00
#ifndef FINAL
if(gbShowCollisionLines)
CRenderer::RenderCollisionLines();
2020-04-10 18:36:39 +02:00
ThePaths.DisplayPathData();
CDebug::DrawLines();
2020-04-25 00:40:14 +02:00
DefinedState();
2020-04-10 18:36:39 +02:00
#endif
2019-05-15 16:52:37 +02:00
}
void
RenderEffects(void)
{
CGlass::Render();
CWaterCannons::Render();
CSpecialFX::Render();
CShadows::RenderStaticShadows();
CShadows::RenderStoredShadows();
CSkidmarks::Render();
CAntennas::Render();
CRubbish::Render();
CCoronas::Render();
CParticle::Render();
CPacManPickups::Render();
CWeaponEffects::Render();
CPointLights::RenderFogEffect();
CMovingThings::Render();
CRenderer::RenderFirstPersonVehicle();
}
2019-06-01 23:17:39 +02:00
void
Render2dStuff(void)
2019-06-01 23:17:39 +02:00
{
RwRenderStateSet(rwRENDERSTATEZTESTENABLE, (void*)FALSE);
RwRenderStateSet(rwRENDERSTATEZWRITEENABLE, (void*)FALSE);
RwRenderStateSet(rwRENDERSTATEVERTEXALPHAENABLE, (void*)TRUE);
RwRenderStateSet(rwRENDERSTATESRCBLEND, (void*)rwBLENDSRCALPHA);
RwRenderStateSet(rwRENDERSTATEDESTBLEND, (void*)rwBLENDINVSRCALPHA);
RwRenderStateSet(rwRENDERSTATECULLMODE, (void*)rwCULLMODECULLNONE);
2019-06-01 23:17:39 +02:00
CReplay::Display();
CPickups::RenderPickUpText();
2019-06-01 23:17:39 +02:00
if(TheCamera.m_WideScreenOn
#ifdef CUTSCENE_BORDERS_SWITCH
&& CMenuManager::m_PrefsCutsceneBorders
#endif
)
TheCamera.DrawBordersForWideScreen();
2019-06-01 23:17:39 +02:00
CPed *player = FindPlayerPed();
int weaponType = 0;
if(player)
weaponType = player->GetWeapon()->m_eWeaponType;
bool firstPersonWeapon = false;
int cammode = TheCamera.Cams[TheCamera.ActiveCam].Mode;
if(cammode == CCam::MODE_SNIPER ||
cammode == CCam::MODE_SNIPER_RUNABOUT ||
cammode == CCam::MODE_ROCKETLAUNCHER ||
cammode == CCam::MODE_ROCKETLAUNCHER_RUNABOUT)
firstPersonWeapon = true;
// Draw black border for sniper and rocket launcher
if((weaponType == WEAPONTYPE_SNIPERRIFLE || weaponType == WEAPONTYPE_ROCKETLAUNCHER) && firstPersonWeapon){
CRGBA black(0, 0, 0, 255);
// top and bottom strips
if (weaponType == WEAPONTYPE_ROCKETLAUNCHER) {
CSprite2d::DrawRect(CRect(0.0f, 0.0f, SCREEN_WIDTH, SCREEN_HEIGHT / 2 - SCREEN_SCALE_Y(180)), black);
CSprite2d::DrawRect(CRect(0.0f, SCREEN_HEIGHT / 2 + SCREEN_SCALE_Y(170), SCREEN_WIDTH, SCREEN_HEIGHT), black);
}
else {
CSprite2d::DrawRect(CRect(0.0f, 0.0f, SCREEN_WIDTH, SCREEN_HEIGHT / 2 - SCREEN_SCALE_Y(210)), black);
CSprite2d::DrawRect(CRect(0.0f, SCREEN_HEIGHT / 2 + SCREEN_SCALE_Y(210), SCREEN_WIDTH, SCREEN_HEIGHT), black);
}
CSprite2d::DrawRect(CRect(0.0f, 0.0f, SCREEN_WIDTH / 2 - SCREEN_SCALE_X(210), SCREEN_HEIGHT), black);
CSprite2d::DrawRect(CRect(SCREEN_WIDTH / 2 + SCREEN_SCALE_X(210), 0.0f, SCREEN_WIDTH, SCREEN_HEIGHT), black);
2019-06-01 23:17:39 +02:00
}
MusicManager.DisplayRadioStationName();
TheConsole.Display();
2020-12-02 00:34:51 +01:00
#ifdef GTA_SCENE_EDIT
if(CSceneEdit::m_bEditOn)
CSceneEdit::Draw();
else
2020-12-02 00:34:51 +01:00
#endif
CHud::Draw();
CUserDisplay::OnscnTimer.ProcessForDisplay();
CMessages::Display();
CDarkel::DrawMessages();
CGarages::PrintMessages();
CPad::PrintErrorMessage();
CFont::DrawFonts();
2020-05-09 15:06:13 +02:00
#ifdef DEBUGMENU
DebugMenuRender();
2020-05-09 15:06:13 +02:00
#endif
2019-06-01 23:17:39 +02:00
}
void
RenderMenus(void)
2019-06-01 23:17:39 +02:00
{
2020-06-27 23:01:51 +02:00
if (FrontEndMenuManager.m_bMenuActive)
{
2020-11-26 16:47:19 +01:00
PUSH_MEMID(MEMID_FRONTEND);
FrontEndMenuManager.DrawFrontEnd();
2020-11-26 16:47:19 +01:00
POP_MEMID();
2020-06-27 23:01:51 +02:00
}
2019-06-01 23:17:39 +02:00
}
2020-03-22 15:23:40 +01:00
void
Render2dStuffAfterFade(void)
2020-03-22 15:23:40 +01:00
{
#ifndef MASTER
DisplayGameDebugText();
#endif
CHud::DrawAfterFade();
CFont::DrawFonts();
2020-03-22 15:23:40 +01:00
}
2019-06-01 23:17:39 +02:00
void
Idle(void *arg)
2019-06-01 23:17:39 +02:00
{
#ifdef ASPECT_RATIO_SCALE
CDraw::SetAspectRatio(CDraw::FindAspectRatio());
2019-06-01 23:17:39 +02:00
#endif
CTimer::Update();
2019-06-01 23:17:39 +02:00
tbInit();
2019-06-01 23:17:39 +02:00
CSprite2d::InitPerFrame();
CFont::InitPerFrame();
// We're basically merging FrontendIdle and Idle (just like TheGame on PS2)
#ifdef PS2_SAVE_DIALOG
// Only exists on PC FrontendIdle, probably some PS2 bug fix
if (FrontEndMenuManager.m_bMenuActive)
2019-06-01 23:17:39 +02:00
CSprite2d::SetRecipNearClip();
if (FrontEndMenuManager.m_bGameNotLoaded) {
CPad::UpdatePads();
FrontEndMenuManager.Process();
} else {
2020-11-26 16:47:19 +01:00
PUSH_MEMID(MEMID_GAME_PROCESS);
CPointLights::InitPerFrame();
tbStartTimer(0, "CGame::Process");
CGame::Process();
tbEndTimer("CGame::Process");
2020-11-26 16:47:19 +01:00
POP_MEMID();
tbStartTimer(0, "DMAudio.Service");
DMAudio.Service();
tbEndTimer("DMAudio.Service");
}
2019-06-01 23:17:39 +02:00
if (RsGlobal.quit)
return;
#else
2020-11-26 16:47:19 +01:00
PUSH_MEMID(MEMID_GAME_PROCESS);
CPointLights::InitPerFrame();
2020-10-25 16:17:30 +01:00
tbStartTimer(0, "CGame::Process");
CGame::Process();
tbEndTimer("CGame::Process");
2020-11-26 16:47:19 +01:00
POP_MEMID();
2019-06-01 23:17:39 +02:00
2020-10-25 16:17:30 +01:00
tbStartTimer(0, "DMAudio.Service");
DMAudio.Service();
tbEndTimer("DMAudio.Service");
2019-06-01 23:17:39 +02:00
#endif
if(CGame::bDemoMode && CTimer::GetTimeInMilliseconds() > (3*60 + 30)*1000 && !CCutsceneMgr::IsCutsceneProcessing()){
2020-11-26 16:47:19 +01:00
WANT_TO_LOAD = false;
FrontEndMenuManager.m_bWantToRestart = true;
return;
2019-06-01 23:17:39 +02:00
}
2020-11-26 16:47:19 +01:00
if(FrontEndMenuManager.m_bWantToRestart || FOUND_GAME_TO_LOAD)
2020-06-27 23:01:51 +02:00
{
2019-06-28 22:23:55 +02:00
return;
2020-06-27 23:01:51 +02:00
}
SetLightsWithTimeOfDayColour(Scene.world);
2019-06-28 19:23:28 +02:00
if(arg == nil)
return;
2019-06-28 19:23:28 +02:00
2020-11-26 16:47:19 +01:00
PUSH_MEMID(MEMID_RENDER);
if((!FrontEndMenuManager.m_bMenuActive || FrontEndMenuManager.m_bRenderGameInMenu) &&
TheCamera.GetScreenFadeStatus() != FADE_2)
{
2020-11-16 13:28:10 +01:00
// This is from SA, but it's nice for windowed mode
#if defined(GTA_PC) && !defined(RW_GL3)
if (!FrontEndMenuManager.m_bRenderGameInMenu) {
RwV2d pos;
pos.x = SCREEN_WIDTH / 2.0f;
pos.y = SCREEN_HEIGHT / 2.0f;
RsMouseSetPos(&pos);
}
#endif
2020-11-26 16:47:19 +01:00
PUSH_MEMID(MEMID_RENDERLIST);
tbStartTimer(0, "CnstrRenderList");
CRenderer::ConstructRenderList();
tbEndTimer("CnstrRenderList");
2020-10-25 16:17:30 +01:00
tbStartTimer(0, "PreRender");
CRenderer::PreRender();
tbEndTimer("PreRender");
2020-11-26 16:47:19 +01:00
POP_MEMID();
2019-06-28 19:23:28 +02:00
2020-08-18 10:58:15 +02:00
#ifdef FIX_BUGS
2020-09-25 23:24:30 +02:00
RwRenderStateSet(rwRENDERSTATEZWRITEENABLE, (void *)FALSE); // TODO: temp? this fixes OpenGL render but there should be a better place for this
2020-08-18 10:58:15 +02:00
// This has to be done BEFORE RwCameraBeginUpdate
RwCameraSetFarClipPlane(Scene.camera, CTimeCycle::GetFarClip());
RwCameraSetFogDistance(Scene.camera, CTimeCycle::GetFogStart());
#endif
if(CWeather::LightningFlash && !CCullZones::CamNoRain()){
if(!DoRWStuffStartOfFrame_Horizon(255, 255, 255, 255, 255, 255, 255))
2020-11-26 16:47:19 +01:00
goto popret;
}else{
if(!DoRWStuffStartOfFrame_Horizon(CTimeCycle::GetSkyTopRed(), CTimeCycle::GetSkyTopGreen(), CTimeCycle::GetSkyTopBlue(),
CTimeCycle::GetSkyBottomRed(), CTimeCycle::GetSkyBottomGreen(), CTimeCycle::GetSkyBottomBlue(),
255))
2020-11-26 16:47:19 +01:00
goto popret;
}
2019-06-18 09:50:26 +02:00
DefinedState();
2019-06-18 09:50:26 +02:00
2020-08-18 10:58:15 +02:00
#ifndef FIX_BUGS
RwCameraSetFarClipPlane(Scene.camera, CTimeCycle::GetFarClip());
RwCameraSetFogDistance(Scene.camera, CTimeCycle::GetFogStart());
2020-08-18 10:58:15 +02:00
#endif
2019-05-31 19:02:26 +02:00
tbStartTimer(0, "RenderScene");
RenderScene();
tbEndTimer("RenderScene");
2020-08-18 10:58:15 +02:00
#ifdef EXTENDED_PIPELINES
CustomPipes::EnvMapRender();
#endif
RenderDebugShit();
RenderEffects();
2019-05-31 19:02:26 +02:00
2020-06-27 23:01:51 +02:00
if((TheCamera.m_BlurType == MOTION_BLUR_NONE || TheCamera.m_BlurType == MOTION_BLUR_LIGHT_SCENE) &&
TheCamera.m_ScreenReductionPercentage > 0.0f)
TheCamera.SetMotionBlurAlpha(150);
2020-11-19 16:23:52 +01:00
#ifdef SCREEN_DROPLETS
CPostFX::GetBackBuffer(Scene.camera);
ScreenDroplets::Process();
ScreenDroplets::Render();
#endif
tbStartTimer(0, "RenderMotionBlur");
TheCamera.RenderMotionBlur();
tbEndTimer("RenderMotionBlur");
2020-10-25 16:17:30 +01:00
tbStartTimer(0, "Render2dStuff");
Render2dStuff();
tbEndTimer("Render2dStuff");
}else{
#ifdef ASPECT_RATIO_SCALE
CameraSize(Scene.camera, nil, SCREEN_VIEWWINDOW, SCREEN_ASPECT_RATIO);
#else
CameraSize(Scene.camera, nil, SCREEN_VIEWWINDOW, DEFAULT_ASPECT_RATIO);
#endif
CVisibilityPlugins::SetRenderWareCamera(Scene.camera);
RwCameraClear(Scene.camera, &gColourTop, rwCAMERACLEARZ);
if(!RsCameraBeginUpdate(Scene.camera))
2020-11-26 16:47:19 +01:00
goto popret;
}
2019-05-31 19:02:26 +02:00
#ifdef PS2_SAVE_DIALOG
if (FrontEndMenuManager.m_bMenuActive)
DefinedState();
#endif
tbStartTimer(0, "RenderMenus");
RenderMenus();
tbEndTimer("RenderMenus");
2020-06-27 23:01:51 +02:00
#ifdef PS2_MENU
if ( TheMemoryCard.m_bWantToLoad )
2020-11-26 16:47:19 +01:00
goto popret;
2020-06-27 23:01:51 +02:00
#endif
2020-10-25 16:17:30 +01:00
tbStartTimer(0, "DoFade");
DoFade();
tbEndTimer("DoFade");
2020-10-25 16:17:30 +01:00
tbStartTimer(0, "Render2dStuff-Fade");
Render2dStuffAfterFade();
tbEndTimer("Render2dStuff-Fade");
2020-10-25 16:17:30 +01:00
CCredits::Render();
2020-05-29 12:03:32 +02:00
if (gbShowTimebars)
2020-06-01 13:21:19 +02:00
tbDisplay();
DoRWStuffEndOfFrame();
2020-11-26 16:47:19 +01:00
POP_MEMID(); // MEMID_RENDER
if(g_SlowMode)
ProcessSlowMode();
2020-11-26 16:47:19 +01:00
return;
popret: POP_MEMID(); // MEMID_RENDER
2019-05-31 19:02:26 +02:00
}
void
FrontendIdle(void)
2019-05-31 19:02:26 +02:00
{
#ifdef ASPECT_RATIO_SCALE
CDraw::SetAspectRatio(CDraw::FindAspectRatio());
#endif
2019-06-12 12:34:22 +02:00
CTimer::Update();
CSprite2d::SetRecipNearClip(); // this should be on InitialiseRenderWare according to PS2 asm. seems like a bug fix
CSprite2d::InitPerFrame();
CFont::InitPerFrame();
CPad::UpdatePads();
FrontEndMenuManager.Process();
if(RsGlobal.quit)
return;
2019-05-31 19:02:26 +02:00
#ifdef ASPECT_RATIO_SCALE
CameraSize(Scene.camera, nil, SCREEN_VIEWWINDOW, SCREEN_ASPECT_RATIO);
#else
CameraSize(Scene.camera, nil, SCREEN_VIEWWINDOW, DEFAULT_ASPECT_RATIO);
#endif
CVisibilityPlugins::SetRenderWareCamera(Scene.camera);
RwCameraClear(Scene.camera, &gColourTop, rwCAMERACLEARZ);
if(!RsCameraBeginUpdate(Scene.camera))
return;
2019-05-31 19:02:26 +02:00
DefinedState(); // seems redundant, but breaks resolution change.
RenderMenus();
DoFade();
Render2dStuffAfterFade();
// CFont::DrawFonts(); // redundant
DoRWStuffEndOfFrame();
}
2019-05-31 19:02:26 +02:00
void
InitialiseGame(void)
2019-05-31 19:02:26 +02:00
{
LoadingScreen(nil, nil, "loadsc0");
CGame::Initialise("DATA\\GTA3.DAT");
2019-05-31 19:02:26 +02:00
}
RsEventStatus
AppEventHandler(RsEvent event, void *param)
{
switch( event )
{
2020-05-23 11:34:40 +02:00
case rsINITIALIZE:
{
2019-05-31 19:02:26 +02:00
CGame::InitialiseOnceBeforeRW();
2020-05-23 11:34:40 +02:00
return RsInitialize() ? rsEVENTPROCESSED : rsEVENTERROR;
}
2019-05-31 19:02:26 +02:00
case rsCAMERASIZE:
{
2019-06-12 19:18:24 +02:00
CameraSize(Scene.camera, (RwRect *)param,
SCREEN_VIEWWINDOW, DEFAULT_ASPECT_RATIO);
return rsEVENTPROCESSED;
}
2019-05-31 19:02:26 +02:00
2020-05-23 11:34:40 +02:00
case rsRWINITIALIZE:
{
return Initialise3D(param) ? rsEVENTPROCESSED : rsEVENTERROR;
}
2019-05-31 19:02:26 +02:00
case rsRWTERMINATE:
{
Terminate3D();
2019-05-31 19:02:26 +02:00
return rsEVENTPROCESSED;
}
2019-05-31 19:02:26 +02:00
case rsTERMINATE:
{
CGame::FinalShutdown();
2019-05-31 19:02:26 +02:00
return rsEVENTPROCESSED;
}
2019-05-31 19:02:26 +02:00
case rsPLUGINATTACH:
{
return PluginAttach() ? rsEVENTPROCESSED : rsEVENTERROR;
}
2019-05-31 19:02:26 +02:00
case rsINPUTDEVICEATTACH:
{
AttachInputDevices();
2019-05-31 19:02:26 +02:00
return rsEVENTPROCESSED;
}
2019-05-31 19:02:26 +02:00
case rsIDLE:
{
Idle(param);
2019-05-31 19:02:26 +02:00
return rsEVENTPROCESSED;
}
2019-05-31 19:02:26 +02:00
case rsFRONTENDIDLE:
{
#ifdef PS2_SAVE_DIALOG
Idle((void*)1);
#else
FrontendIdle();
#endif
2019-05-31 19:02:26 +02:00
return rsEVENTPROCESSED;
}
2019-05-31 19:02:26 +02:00
case rsACTIVATE:
{
param ? DMAudio.ReacquireDigitalHandle() : DMAudio.ReleaseDigitalHandle();
2019-05-31 19:02:26 +02:00
return rsEVENTPROCESSED;
}
2019-05-31 19:02:26 +02:00
default:
{
return rsEVENTNOTPROCESSED;
}
}
2019-05-31 19:02:26 +02:00
}
#ifndef MASTER
void
TheModelViewer(void)
{
2020-04-09 05:20:44 +02:00
#if (defined(GTA_PS2) || defined(GTA_XBOX))
//TODO
#else
// This is III Mobile code. III Xbox code run it like main function, which is impossible to implement on PC's state machine implementation.
// Also we want 2D things initialized in here to print animation ids etc., our additions for that marked with X
#ifdef ASPECT_RATIO_SCALE
CDraw::SetAspectRatio(CDraw::FindAspectRatio()); // X
#endif
CAnimViewer::Update();
CTimer::Update();
SetLightsWithTimeOfDayColour(Scene.world);
CRenderer::ConstructRenderList();
DoRWStuffStartOfFrame(CTimeCycle::GetSkyTopRed(), CTimeCycle::GetSkyTopGreen(), CTimeCycle::GetSkyTopBlue(),
CTimeCycle::GetSkyBottomRed(), CTimeCycle::GetSkyBottomGreen(), CTimeCycle::GetSkyBottomBlue(),
255);
CSprite2d::InitPerFrame(); // X
CFont::InitPerFrame(); // X
DefinedState();
CVisibilityPlugins::InitAlphaEntityList();
CAnimViewer::Render();
Render2dStuff(); // X
DoRWStuffEndOfFrame();
#endif
}
#endif
2020-11-26 16:47:19 +01:00
#ifdef GTA_PS2
void TheGame(void)
2019-07-24 18:55:43 +02:00
{
printf("Into TheGame!!!\n");
2019-07-24 18:55:43 +02:00
2020-11-26 16:47:19 +01:00
PUSH_MEMID(MEMID_GAME); // NB: not popped
CTimer::Initialise();
2020-04-09 05:20:44 +02:00
#ifdef GTA_PS2
CGame::Initialise();
#else
CGame::Initialise("DATA\\GTA3.DAT");
#endif
2020-05-12 01:24:57 +02:00
Const char *splash = GetRandomSplashScreen(); // inlined here
LoadingScreen("Starting Game", NULL, splash);
2020-04-09 05:20:44 +02:00
#ifdef GTA_PS2
2020-06-27 23:01:51 +02:00
if ( TheMemoryCard.CheckCardInserted(CARD_ONE) == CMemoryCard::NO_ERR_SUCCESS
&& TheMemoryCard.ChangeDirectory(CARD_ONE, TheMemoryCard.Cards[CARD_ONE].dir)
&& TheMemoryCard.FindMostRecentFileName(CARD_ONE, TheMemoryCard.MostRecentFile) == true
&& TheMemoryCard.CheckDataNotCorrupt(TheMemoryCard.MostRecentFile))
2019-07-24 18:55:43 +02:00
{
2020-06-27 23:01:51 +02:00
strcpy(TheMemoryCard.LoadFileName, TheMemoryCard.MostRecentFile);
TheMemoryCard.b_FoundRecentSavedGameWantToLoad = true;
if (CMenuManager::m_PrefsLanguage != TheMemoryCard.GetLanguageToLoad())
2019-07-24 18:55:43 +02:00
{
CMenuManager::m_PrefsLanguage = TheMemoryCard.GetLanguageToLoad();
TheText.Unload();
TheText.Load();
}
CGame::currLevel = TheMemoryCard.GetLevelToLoad();
}
#else
//TODO
#endif
while (true)
{
2020-11-26 16:47:19 +01:00
if (WANT_TO_LOAD)
{
2020-05-12 01:24:57 +02:00
Const char *splash1 = GetLevelSplashScreen(CGame::currLevel);
LoadSplash(splash1);
}
2020-11-26 16:47:19 +01:00
WANT_TO_LOAD = false;
CTimer::Update();
2020-11-26 16:47:19 +01:00
while (!(FrontEndMenuManager.m_bWantToRestart || FOUND_GAME_TO_LOAD))
{
CSprite2d::InitPerFrame();
CFont::InitPerFrame();
2020-11-26 16:47:19 +01:00
PUSH_MEMID(MEMID_GAME_PROCESS)
CPointLights::InitPerFrame();
CGame::Process();
2020-11-26 16:47:19 +01:00
POP_MEMID();
DMAudio.Service();
if (CGame::bDemoMode && CTimer::GetTimeInMilliseconds() > (3*60 + 30)*1000 && !CCutsceneMgr::IsCutsceneProcessing())
{
2020-11-26 16:47:19 +01:00
WANT_TO_LOAD = false;
FrontEndMenuManager.m_bWantToRestart = true;
2019-07-24 18:55:43 +02:00
break;
}
2020-11-26 16:47:19 +01:00
if (FrontEndMenuManager.m_bWantToRestart || FOUND_GAME_TO_LOAD)
break;
SetLightsWithTimeOfDayColour(Scene.world);
2020-11-26 16:47:19 +01:00
PUSH_MEMID(MEMID_RENDER);
if (!FrontEndMenuManager.m_bMenuActive || FrontEndMenuManager.m_bRenderGameInMenu == true && TheCamera.GetScreenFadeStatus() != FADE_2 )
{
2020-11-26 16:47:19 +01:00
PUSH_MEMID(MEMID_RENDERLIST);
CRenderer::ConstructRenderList();
CRenderer::PreRender();
2020-11-26 16:47:19 +01:00
POP_MEMID();
if (CWeather::LightningFlash && !CCullZones::CamNoRain())
DoRWStuffStartOfFrame_Horizon(255, 255, 255, 255, 255, 255, 255);
else
DoRWStuffStartOfFrame_Horizon(CTimeCycle::GetSkyTopRed(), CTimeCycle::GetSkyTopGreen(), CTimeCycle::GetSkyTopBlue(), CTimeCycle::GetSkyBottomRed(), CTimeCycle::GetSkyBottomGreen(), CTimeCycle::GetSkyBottomBlue(), 255);
DefinedState();
RwCameraSetFarClipPlane(Scene.camera, CTimeCycle::GetFarClip());
RwCameraSetFogDistance(Scene.camera, CTimeCycle::GetFogStart());
RenderScene();
RenderDebugShit();
RenderEffects();
2020-06-27 23:01:51 +02:00
if ((TheCamera.m_BlurType == MOTION_BLUR_NONE || TheCamera.m_BlurType == MOTION_BLUR_LIGHT_SCENE) && TheCamera.m_ScreenReductionPercentage > 0.0f)
TheCamera.SetMotionBlurAlpha(150);
TheCamera.RenderMotionBlur();
Render2dStuff();
}
else
{
CameraSize(Scene.camera, NULL, SCREEN_VIEWWINDOW, SCREEN_ASPECT_RATIO);
CVisibilityPlugins::SetRenderWareCamera(Scene.camera);
RwCameraClear(Scene.camera, &gColourTop, rwCAMERACLEARZ);
if (!RsCameraBeginUpdate(Scene.camera))
break;
}
RenderMenus();
2020-11-26 16:47:19 +01:00
if (WANT_TO_LOAD)
{
2020-11-26 16:47:19 +01:00
POP_MEMID(); // MEMID_RENDER
break;
}
DoFade();
Render2dStuffAfterFade();
CCredits::Render();
DoRWStuffEndOfFrame();
while (frameCount < 2)
;
frameCount = 0;
CTimer::Update();
2020-11-26 16:47:19 +01:00
POP_MEMID(): // MEMID_RENDER
if (g_SlowMode)
ProcessSlowMode();
2019-07-24 18:55:43 +02:00
}
CPad::ResetCheats();
CPad::StopPadsShaking();
DMAudio.ChangeMusicMode(MUSICMODE_DISABLE);
CGame::ShutDownForRestart();
CTimer::Stop();
2020-11-26 16:47:19 +01:00
if (FrontEndMenuManager.m_bWantToRestart || FOUND_GAME_TO_LOAD)
2019-07-24 18:55:43 +02:00
{
2020-11-26 16:47:19 +01:00
if (FOUND_GAME_TO_LOAD)
{
FrontEndMenuManager.m_bWantToRestart = true;
2020-11-26 16:47:19 +01:00
WANT_TO_LOAD = true;
}
CGame::InitialiseWhenRestarting();
DMAudio.ChangeMusicMode(MUSICMODE_GAME);
FrontEndMenuManager.m_bWantToRestart = false;
continue;
2019-07-24 18:55:43 +02:00
}
break;
2019-07-24 18:55:43 +02:00
}
DMAudio.Terminate();
}
void SystemInit()
{
#ifdef __MWERKS__
mwInit();
#endif
2019-07-24 18:55:43 +02:00
2020-11-25 22:49:50 +01:00
#ifdef USE_CUSTOM_ALLOCATOR
InitMemoryMgr();
#endif
2020-04-09 05:20:44 +02:00
#ifdef GTA_PS2
CFileMgr::InitCdSystem();
char path[256];
sprintf(path, "cdrom0:\\%s%s;1", "SYSTEM\\", "IOPRP23.IMG");
sceSifInitRpc(0);
while ( !sceSifRebootIop(path) )
2019-07-24 18:55:43 +02:00
;
while( !sceSifSyncIop() )
;
sceSifInitRpc(0);
CFileMgr::InitCdSystem();
sceFsReset();
#endif
CFileMgr::Initialise();
2020-04-09 05:20:44 +02:00
#ifdef GTA_PS2
CFileMgr::InitCd();
2020-12-04 01:12:58 +01:00
char modulepath[256];
strcpy(modulepath, "cdrom0:\\");
strcat(modulepath, "SYSTEM\\");
strcat(modulepath, "SIO2MAN.IRX");
LoadModule(modulepath);
strcpy(modulepath, "cdrom0:\\");
strcat(modulepath, "SYSTEM\\");
strcat(modulepath, "PADMAN.IRX");
LoadModule(modulepath);
strcpy(modulepath, "cdrom0:\\");
strcat(modulepath, "SYSTEM\\");
strcat(modulepath, "LIBSD.IRX");
LoadModule(modulepath);
strcpy(modulepath, "cdrom0:\\");
strcat(modulepath, "SYSTEM\\");
strcat(modulepath, "SDRDRV.IRX");
LoadModule(modulepath);
strcpy(modulepath, "cdrom0:\\");
strcat(modulepath, "SYSTEM\\");
strcat(modulepath, "MCMAN.IRX");
LoadModule(modulepath);
strcpy(modulepath, "cdrom0:\\");
strcat(modulepath, "SYSTEM\\");
strcat(modulepath, "MCSERV.IRX");
LoadModule(modulepath);
#endif
2020-04-09 05:20:44 +02:00
#ifdef GTA_PS2
ThreadParam param;
param.entry = &IdleThread;
param.stack = idleThreadStack;
param.stackSize = 2048;
param.initPriority = 127;
param.gpReg = &_gp;
int thread = CreateThread(&param);
StartThread(thread, NULL);
#else
//
#endif
2020-04-15 07:03:53 +02:00
#ifdef GTA_PS2_STUFF
CPad::Initialise();
2020-04-15 07:03:53 +02:00
#endif
CPad::GetPad(0)->Mode = 0;
CGame::frenchGame = false;
CGame::germanGame = false;
CGame::nastyGame = true;
CMenuManager::m_PrefsAllowNastyGame = true;
2020-04-09 05:20:44 +02:00
#ifdef GTA_PS2
int32 lang = sceScfGetLanguage();
if ( lang == SCE_ITALIAN_LANGUAGE )
CMenuManager::m_PrefsLanguage = LANGUAGE_ITALIAN;
else if ( lang == SCE_SPANISH_LANGUAGE )
CMenuManager::m_PrefsLanguage = LANGUAGE_SPANISH;
else if ( lang == SCE_GERMAN_LANGUAGE )
{
CGame::germanGame = true;
CGame::nastyGame = false;
CMenuManager::m_PrefsAllowNastyGame = false;
CMenuManager::m_PrefsLanguage = LANGUAGE_GERMAN;
}
else if ( lang == SCE_FRENCH_LANGUAGE )
{
CGame::frenchGame = true;
CGame::nastyGame = false;
CMenuManager::m_PrefsAllowNastyGame = false;
CMenuManager::m_PrefsLanguage = LANGUAGE_FRENCH;
}
else
CMenuManager::m_PrefsLanguage = LANGUAGE_AMERICAN;
FrontEndMenuManager.InitialiseMenuContentsAfterLoadingGame();
#else
//
#endif
2020-11-26 16:47:19 +01:00
#ifdef GTA_PS2
TheMemoryCard.Init();
#endif
}
void GameInit()
{
if ( !gameAlreadyInitialised )
{
2020-04-09 05:20:44 +02:00
#ifdef GTA_PS2
char path[256];
strcpy(path, "cdrom0:\\");
strcat(path, "SYSTEM\\");
strcat(path, "CDSTREAM.IRX");
LoadModule(path);
strcpy(path, "cdrom0:\\");
strcat(path, "SYSTEM\\");
strcat(path, "SAMPMAN.IRX");
LoadModule(path);
strcpy(path, "cdrom0:\\");
strcat(path, "SYSTEM\\");
strcat(path, "MUSICSTR.IRX");
LoadModule(path);
#endif
CdStreamInit(MAX_CDCHANNELS);
2020-11-26 16:47:19 +01:00
#ifdef GTA_PS2
Initialise3D(); //no params
#else
//TODO
#endif
2020-04-09 05:20:44 +02:00
#ifdef GTA_PS2
char *files[] =
{
"\\ANIM\\CUTS.IMG;1",
"\\ANIM\\CUTS.DIR;1",
"\\ANIM\\PED.IFP;1",
"\\MODELS\\FRONTEND.TXD;1",
"\\MODELS\\FONTS.TXD;1",
"\\MODELS\\HUD.TXD;1",
"\\MODELS\\PARTICLE.TXD;1",
"\\MODELS\\MISC.TXD;1",
"\\MODELS\\GENERIC.TXD;1",
"\\MODELS\\GTA3.DIR;1",
"\\TEXT\\ENGLISH.GXT;1",
"\\TEXT\\FRENCH.GXT;1",
"\\TEXT\\GERMAN.GXT;1",
"\\TEXT\\ITALIAN.GXT;1",
"\\TEXT\\SPANISH.GXT;1",
"\\TXD\\LOADSC0.TXD;1",
"\\TXD\\LOADSC1.TXD;1",
"\\TXD\\LOADSC2.TXD;1",
"\\TXD\\LOADSC3.TXD;1",
"\\TXD\\LOADSC4.TXD;1",
"\\TXD\\LOADSC5.TXD;1",
"\\TXD\\LOADSC6.TXD;1",
"\\TXD\\LOADSC7.TXD;1",
"\\TXD\\LOADSC8.TXD;1",
"\\TXD\\LOADSC9.TXD;1",
"\\TXD\\LOADSC10.TXD;1",
"\\TXD\\LOADSC11.TXD;1",
"\\TXD\\LOADSC12.TXD;1",
"\\TXD\\LOADSC13.TXD;1",
"\\TXD\\LOADSC14.TXD;1",
"\\TXD\\LOADSC15.TXD;1",
"\\TXD\\LOADSC16.TXD;1",
"\\TXD\\LOADSC17.TXD;1",
"\\TXD\\LOADSC18.TXD;1",
"\\TXD\\LOADSC19.TXD;1",
"\\TXD\\LOADSC20.TXD;1",
"\\TXD\\LOADSC21.TXD;1",
"\\TXD\\LOADSC22.TXD;1",
"\\TXD\\LOADSC23.TXD;1",
"\\TXD\\LOADSC24.TXD;1",
"\\TXD\\LOADSC25.TXD;1",
"\\TXD\\NEWS.TXD;1",
"\\MODELS\\COLL\\GENERIC.COL;1",
"\\MODELS\\COLL\\INDUST.COL;1",
"\\MODELS\\COLL\\COMMER.COL;1",
"\\MODELS\\COLL\\SUBURB.COL;1",
"\\MODELS\\COLL\\WEAPONS.COL;1",
"\\MODELS\\COLL\\VEHICLES.COL;1",
"\\MODELS\\COLL\\PEDS.COL;1",
"\\MODELS\\GENERIC\\AIR_VLO.DFF;1",
"\\MODELS\\GENERIC\\WEAPONS.DFF;1",
"\\MODELS\\GENERIC\\WHEELS.DFF;1",
"\\MODELS\\GENERIC\\LOPLYGUY.DFF;1",
"\\MODELS\\GENERIC\\ARROW.DFF;1",
"\\MODELS\\GENERIC\\ZONECYLB.DFF;1",
"\\DATA\\MAPS\\COMNTOP.IPL;1",
"\\DATA\\MAPS\\COMNBTM.IPL;1",
"\\DATA\\MAPS\\COMSE.IPL;1",
"\\DATA\\MAPS\\COMSW.IPL;1",
"\\DATA\\MAPS\\CULL.IPL;1",
"\\DATA\\MAPS\\INDUSTNE.IPL;1",
"\\DATA\\MAPS\\INDUSTNW.IPL;1",
"\\DATA\\MAPS\\INDUSTSE.IPL;1",
"\\DATA\\MAPS\\INDUSTSW.IPL;1",
"\\DATA\\MAPS\\SUBURBNE.IPL;1",
"\\DATA\\MAPS\\SUBURBSW.IPL;1",
"\\DATA\\MAPS\\OVERVIEW.IPL;1",
"\\DATA\\MAPS\\PROPS.IPL;1",
"\\DATA\\MAPS\\GTA3.IDE;1",
"\\DATA\\PATHS\\FLIGHT.DAT;1",
"\\DATA\\PATHS\\FLIGHT2.DAT;1",
"\\DATA\\PATHS\\FLIGHT3.DAT;1",
"\\DATA\\PATHS\\FLIGHT4.DAT;1",
"\\DATA\\PATHS\\TRACKS.DAT;1",
"\\DATA\\PATHS\\TRACKS2.DAT;1",
"\\DATA\\PATHS\\CHASE0.DAT;1",
"\\DATA\\PATHS\\CHASE1.DAT;1",
"\\DATA\\PATHS\\CHASE2.DAT;1",
"\\DATA\\PATHS\\CHASE3.DAT;1",
"\\DATA\\PATHS\\CHASE4.DAT;1",
"\\DATA\\PATHS\\CHASE5.DAT;1",
"\\DATA\\PATHS\\CHASE6.DAT;1",
"\\DATA\\PATHS\\CHASE7.DAT;1",
"\\DATA\\PATHS\\CHASE10.DAT;1",
"\\DATA\\PATHS\\CHASE11.DAT;1",
"\\DATA\\PATHS\\CHASE14.DAT;1",
"\\DATA\\PATHS\\CHASE16.DAT;1",
"\\DATA\\PATHS\\CHASE18.DAT;1",
"\\DATA\\PATHS\\CHASE19.DAT;1"
};
for ( int32 i = 0; i < ARRAY_SIZE(files); i++ )
SkyRegisterFileOnCd([i]);
#endif
CreateDebugFont();
2020-04-09 05:20:44 +02:00
#ifdef GTA_PS2
2020-12-04 01:12:58 +01:00
AddIntcHandler(INTC_VBLANK_S, VBlankCounter, 0);
#endif
CameraSize(Scene.camera, NULL, DEFAULT_VIEWWINDOW, DEFAULT_ASPECT_RATIO);
CSprite2d::SetRecipNearClip();
CTxdStore::Initialise();
2020-11-26 16:47:19 +01:00
PUSH_MEMID(MEMID_TEXTURES);
CFont::Initialise();
CHud::Initialise();
2020-11-26 16:47:19 +01:00
POP_MEMID();
ValidateVersion();
2020-04-09 05:20:44 +02:00
#ifdef GTA_PS2
sceCdCLOCK rtc;
sceCdReadClock(&rtc);
uint32 seed = rtc.minute + rtc.day;
uint32 seed2 = (seed << 4)-seed;
uint32 seed3 = (seed2 << 4)-seed2;
srand ((seed3<<4)+rtc.second);
#else
//TODO: mysrand();
#endif
gameAlreadyInitialised = true;
}
}
int
main(int argc, char *argv[])
{
#ifdef __MWERKS__
mwInit(); // metrowerks initialisation
#endif
SystemInit();
2020-11-26 16:47:19 +01:00
#ifdef GTA_PS2
2020-06-27 23:01:51 +02:00
int32 r = TheMemoryCard.CheckCardStateAtGameStartUp(CARD_ONE);
2020-12-04 01:12:58 +01:00
if ( r == CMemoryCard::ERR_DIRNOENTRY || r == CMemoryCard::ERR_NOFORMAT )
{
GameInit();
TheText.Unload();
TheText.Load();
CFont::Initialise();
FrontEndMenuManager.DrawMemoryCardStartUpMenus();
2020-12-04 01:12:58 +01:00
}else if(r == CMemoryCard::ERR_OPENNOENTRY || r == CMemoryCard::ERR_NONE){
// eh?
}
#endif
2020-04-09 05:20:44 +02:00
#ifdef GTA_PS2
{
if (gameAlreadyInitialised)
RpSkySuspend();
InitMPEGPlayer();
2020-12-04 01:12:58 +01:00
#ifdef GTA_PAL
PlayMPEG("cdrom0:\\MOVIES\\DMAPAL.PSS;1", false);
if (CGame::frenchGame || CGame::germanGame)
PlayMPEG("cdrom0:\\MOVIES\\INTROPAF.PSS;1", true);
else
PlayMPEG("cdrom0:\\MOVIES\\INTROPAL.PSS;1", true);
2020-12-04 01:12:58 +01:00
#else
PlayMPEG("cdrom0:\\MOVIES\\DMANTSC.PSS;1", false);
PlayMPEG("cdrom0:\\MOVIES\\INTRNTSC.PSS;1", true);
#endif
ShutdownMPEGPlayer();
if ( gameAlreadyInitialised )
RpSkyResume();
2019-07-24 18:55:43 +02:00
}
#else
//TODO
#endif
GameInit();
if ( CGame::frenchGame || CGame::germanGame )
LoadingScreen(NULL, version_name, "loadsc24");
else
LoadingScreen(NULL, version_name, "loadsc0");
DMAudio.Initialise();
TheGame();
CGame::ShutDown();
RwEngineStop();
RwEngineClose();
RwEngineTerm();
#ifdef __MWERKS__
mwExit(); // metrowerks shutdown
#endif
return 0;
2019-07-24 18:55:43 +02:00
}
2020-05-11 04:55:57 +02:00
#endif