mirror of
				https://github.com/halpz/re3.git
				synced 2025-11-04 15:04:59 +00:00 
			
		
		
		
	Merge branch 'master' into miami
# Conflicts: # src/control/CarAI.cpp # src/control/Phones.cpp # src/control/Phones.h # src/control/Record.cpp # src/control/Restart.cpp # src/control/Script.cpp # src/core/Collision.cpp # src/core/Frontend.cpp # src/core/Frontend.h # src/core/Game.h # src/core/Streaming.cpp # src/core/TempColModels.cpp # src/core/Wanted.cpp # src/core/Zones.cpp # src/core/config.h # src/core/main.cpp # src/core/re3.cpp # src/entities/Entity.cpp # src/entities/Physical.cpp # src/extras/frontendoption.cpp # src/modelinfo/ModelInfo.cpp # src/modelinfo/PedModelInfo.cpp # src/peds/CivilianPed.cpp # src/peds/CopPed.cpp # src/peds/EmergencyPed.cpp # src/peds/Ped.cpp # src/peds/Ped.h # src/peds/Population.cpp # src/render/Renderer.cpp # src/save/GenericGameStorage.cpp # src/skel/win/win.cpp # src/vehicles/Automobile.cpp # src/vehicles/Boat.cpp # src/vehicles/Boat.h # src/vehicles/Vehicle.cpp
This commit is contained in:
		
						commit
						d0f5464200
					
				| 
						 | 
					@ -155,8 +155,8 @@ CGameLogic::Update()
 | 
				
			||||||
			CCarCtrl::ClearInterestingVehicleList();
 | 
								CCarCtrl::ClearInterestingVehicleList();
 | 
				
			||||||
			CWorld::ClearExcitingStuffFromArea(pPlayerInfo.GetPos(), 4000.0f, 1);
 | 
								CWorld::ClearExcitingStuffFromArea(pPlayerInfo.GetPos(), 4000.0f, 1);
 | 
				
			||||||
			CRestart::FindClosestHospitalRestartPoint(pPlayerInfo.GetPos(), &vecRestartPos, &fRestartFloat);
 | 
								CRestart::FindClosestHospitalRestartPoint(pPlayerInfo.GetPos(), &vecRestartPos, &fRestartFloat);
 | 
				
			||||||
			CRestart::OverrideHospitalLevel = LEVEL_NONE;
 | 
								CRestart::OverrideHospitalLevel = LEVEL_GENERIC;
 | 
				
			||||||
			CRestart::OverridePoliceStationLevel = LEVEL_NONE;
 | 
								CRestart::OverridePoliceStationLevel = LEVEL_GENERIC;
 | 
				
			||||||
			PassTime(720);
 | 
								PassTime(720);
 | 
				
			||||||
			RestorePlayerStuffDuringResurrection(pPlayerInfo.m_pPed, vecRestartPos, fRestartFloat);
 | 
								RestorePlayerStuffDuringResurrection(pPlayerInfo.m_pPed, vecRestartPos, fRestartFloat);
 | 
				
			||||||
			AfterDeathArrestSetUpShortCutTaxi();
 | 
								AfterDeathArrestSetUpShortCutTaxi();
 | 
				
			||||||
| 
						 | 
					@ -261,8 +261,8 @@ CGameLogic::Update()
 | 
				
			||||||
			CCarCtrl::ClearInterestingVehicleList();
 | 
								CCarCtrl::ClearInterestingVehicleList();
 | 
				
			||||||
			CWorld::ClearExcitingStuffFromArea(pPlayerInfo.GetPos(), 4000.0f, 1);
 | 
								CWorld::ClearExcitingStuffFromArea(pPlayerInfo.GetPos(), 4000.0f, 1);
 | 
				
			||||||
			CRestart::FindClosestPoliceRestartPoint(pPlayerInfo.GetPos(), &vecRestartPos, &fRestartFloat);
 | 
								CRestart::FindClosestPoliceRestartPoint(pPlayerInfo.GetPos(), &vecRestartPos, &fRestartFloat);
 | 
				
			||||||
			CRestart::OverrideHospitalLevel = LEVEL_NONE;
 | 
								CRestart::OverrideHospitalLevel = LEVEL_GENERIC;
 | 
				
			||||||
			CRestart::OverridePoliceStationLevel = LEVEL_NONE;
 | 
								CRestart::OverridePoliceStationLevel = LEVEL_GENERIC;
 | 
				
			||||||
			PassTime(720);
 | 
								PassTime(720);
 | 
				
			||||||
			RestorePlayerStuffDuringResurrection(pPlayerInfo.m_pPed, vecRestartPos, fRestartFloat);
 | 
								RestorePlayerStuffDuringResurrection(pPlayerInfo.m_pPed, vecRestartPos, fRestartFloat);
 | 
				
			||||||
			AfterDeathArrestSetUpShortCutTaxi();
 | 
								AfterDeathArrestSetUpShortCutTaxi();
 | 
				
			||||||
| 
						 | 
					@ -313,8 +313,8 @@ CGameLogic::Update()
 | 
				
			||||||
			CCarCtrl::ClearInterestingVehicleList();
 | 
								CCarCtrl::ClearInterestingVehicleList();
 | 
				
			||||||
			CWorld::ClearExcitingStuffFromArea(pPlayerInfo.GetPos(), 4000.0f, 1);
 | 
								CWorld::ClearExcitingStuffFromArea(pPlayerInfo.GetPos(), 4000.0f, 1);
 | 
				
			||||||
			CRestart::FindClosestPoliceRestartPoint(pPlayerInfo.GetPos(), &vecRestartPos, &fRestartFloat);
 | 
								CRestart::FindClosestPoliceRestartPoint(pPlayerInfo.GetPos(), &vecRestartPos, &fRestartFloat);
 | 
				
			||||||
			CRestart::OverridePoliceStationLevel = LEVEL_NONE;
 | 
								CRestart::OverridePoliceStationLevel = LEVEL_GENERIC;
 | 
				
			||||||
			CRestart::OverrideHospitalLevel = LEVEL_NONE;
 | 
								CRestart::OverrideHospitalLevel = LEVEL_GENERIC;
 | 
				
			||||||
			RestorePlayerStuffDuringResurrection(pPlayerInfo.m_pPed, vecRestartPos, fRestartFloat);
 | 
								RestorePlayerStuffDuringResurrection(pPlayerInfo.m_pPed, vecRestartPos, fRestartFloat);
 | 
				
			||||||
			SortOutStreamingAndMemory(pPlayerInfo.GetPos());
 | 
								SortOutStreamingAndMemory(pPlayerInfo.GetPos());
 | 
				
			||||||
			TheCamera.m_fCamShakeForce = 0.0f;
 | 
								TheCamera.m_fCamShakeForce = 0.0f;
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -284,6 +284,7 @@ CPhoneInfo::Initialise(void)
 | 
				
			||||||
		CBuilding *building = pool->GetSlot(i);
 | 
							CBuilding *building = pool->GetSlot(i);
 | 
				
			||||||
		if (building) {
 | 
							if (building) {
 | 
				
			||||||
			if (building->GetModelIndex() == MI_PHONEBOOTH1) {
 | 
								if (building->GetModelIndex() == MI_PHONEBOOTH1) {
 | 
				
			||||||
 | 
									assert(m_nMax < ARRAY_SIZE(m_aPhones) && "NUMPHONES should be increased");
 | 
				
			||||||
				CPhone *maxPhone = &m_aPhones[m_nMax];
 | 
									CPhone *maxPhone = &m_aPhones[m_nMax];
 | 
				
			||||||
				maxPhone->m_nState = PHONE_STATE_FREE;
 | 
									maxPhone->m_nState = PHONE_STATE_FREE;
 | 
				
			||||||
				maxPhone->m_vecPos = building->GetPosition();
 | 
									maxPhone->m_vecPos = building->GetPosition();
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -170,7 +170,7 @@ static void ApplyPanelDamageToCar(uint32 panels, CAutomobile* vehicle, bool flyi
 | 
				
			||||||
 | 
					
 | 
				
			||||||
void PrintElementsInPtrList(void) 
 | 
					void PrintElementsInPtrList(void) 
 | 
				
			||||||
{
 | 
					{
 | 
				
			||||||
	for (CPtrNode* node = CWorld::GetBigBuildingList(LEVEL_NONE).first; node; node = node->next) {
 | 
						for (CPtrNode* node = CWorld::GetBigBuildingList(LEVEL_GENERIC).first; node; node = node->next) {
 | 
				
			||||||
		/* Most likely debug print was present here */
 | 
							/* Most likely debug print was present here */
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
| 
						 | 
					@ -1143,7 +1143,7 @@ void CReplay::StoreStuffInMem(void)
 | 
				
			||||||
	pWorld1 = new uint8[sizeof(CSector) * NUMSECTORS_X * NUMSECTORS_Y];
 | 
						pWorld1 = new uint8[sizeof(CSector) * NUMSECTORS_X * NUMSECTORS_Y];
 | 
				
			||||||
	memcpy(pWorld1, CWorld::GetSector(0, 0), NUMSECTORS_X * NUMSECTORS_Y * sizeof(CSector));
 | 
						memcpy(pWorld1, CWorld::GetSector(0, 0), NUMSECTORS_X * NUMSECTORS_Y * sizeof(CSector));
 | 
				
			||||||
	WorldPtrList = CWorld::GetMovingEntityList().first; // why
 | 
						WorldPtrList = CWorld::GetMovingEntityList().first; // why
 | 
				
			||||||
	BigBuildingPtrList = CWorld::GetBigBuildingList(LEVEL_NONE).first;
 | 
						BigBuildingPtrList = CWorld::GetBigBuildingList(LEVEL_GENERIC).first;
 | 
				
			||||||
	pPickups = new uint8[sizeof(CPickup) * NUMPICKUPS];
 | 
						pPickups = new uint8[sizeof(CPickup) * NUMPICKUPS];
 | 
				
			||||||
	memcpy(pPickups, CPickups::aPickUps, NUMPICKUPS * sizeof(CPickup));
 | 
						memcpy(pPickups, CPickups::aPickUps, NUMPICKUPS * sizeof(CPickup));
 | 
				
			||||||
	pReferences = new uint8[(sizeof(CReference) * NUMREFERENCES)];
 | 
						pReferences = new uint8[(sizeof(CReference) * NUMREFERENCES)];
 | 
				
			||||||
| 
						 | 
					@ -1189,7 +1189,7 @@ void CReplay::RestoreStuffFromMem(void)
 | 
				
			||||||
	delete[] pWorld1;
 | 
						delete[] pWorld1;
 | 
				
			||||||
	pWorld1 = nil;
 | 
						pWorld1 = nil;
 | 
				
			||||||
	CWorld::GetMovingEntityList().first = WorldPtrList;
 | 
						CWorld::GetMovingEntityList().first = WorldPtrList;
 | 
				
			||||||
	CWorld::GetBigBuildingList(LEVEL_NONE).first = BigBuildingPtrList;
 | 
						CWorld::GetBigBuildingList(LEVEL_GENERIC).first = BigBuildingPtrList;
 | 
				
			||||||
	memcpy(CPickups::aPickUps, pPickups, sizeof(CPickup) * NUMPICKUPS);
 | 
						memcpy(CPickups::aPickUps, pPickups, sizeof(CPickup) * NUMPICKUPS);
 | 
				
			||||||
	delete[] pPickups;
 | 
						delete[] pPickups;
 | 
				
			||||||
	pPickups = nil;
 | 
						pPickups = nil;
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -24,8 +24,8 @@ uint16 CRestart::NumberOfPoliceRestarts;
 | 
				
			||||||
void
 | 
					void
 | 
				
			||||||
CRestart::Initialise()
 | 
					CRestart::Initialise()
 | 
				
			||||||
{
 | 
					{
 | 
				
			||||||
	OverridePoliceStationLevel = LEVEL_NONE;
 | 
						OverridePoliceStationLevel = LEVEL_GENERIC;
 | 
				
			||||||
	OverrideHospitalLevel = LEVEL_NONE;
 | 
						OverrideHospitalLevel = LEVEL_GENERIC;
 | 
				
			||||||
	bFadeInAfterNextArrest = true;
 | 
						bFadeInAfterNextArrest = true;
 | 
				
			||||||
	bFadeInAfterNextDeath = true;
 | 
						bFadeInAfterNextDeath = true;
 | 
				
			||||||
	OverrideHeading = 0.0f;
 | 
						OverrideHeading = 0.0f;
 | 
				
			||||||
| 
						 | 
					@ -86,7 +86,7 @@ CRestart::FindClosestHospitalRestartPoint(const CVector &pos, CVector *outPos, f
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	// find closest point on this level
 | 
						// find closest point on this level
 | 
				
			||||||
	for (int i = 0; i < NumberOfHospitalRestarts; i++) {
 | 
						for (int i = 0; i < NumberOfHospitalRestarts; i++) {
 | 
				
			||||||
		if (CTheZones::GetLevelFromPosition(&HospitalRestartPoints[i]) == (OverrideHospitalLevel != LEVEL_NONE ? OverrideHospitalLevel : curlevel)) {
 | 
							if (CTheZones::GetLevelFromPosition(&HospitalRestartPoints[i]) == (OverrideHospitalLevel != LEVEL_GENERIC ? OverrideHospitalLevel : curlevel)) {
 | 
				
			||||||
			float dist = (pos - HospitalRestartPoints[i]).MagnitudeSqr();
 | 
								float dist = (pos - HospitalRestartPoints[i]).MagnitudeSqr();
 | 
				
			||||||
			if (fMinDist >= dist) {
 | 
								if (fMinDist >= dist) {
 | 
				
			||||||
				fMinDist = dist;
 | 
									fMinDist = dist;
 | 
				
			||||||
| 
						 | 
					@ -133,7 +133,7 @@ CRestart::FindClosestPoliceRestartPoint(const CVector &pos, CVector *outPos, flo
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	// find closest point on this level
 | 
						// find closest point on this level
 | 
				
			||||||
	for (int i = 0; i < NumberOfPoliceRestarts; i++) {
 | 
						for (int i = 0; i < NumberOfPoliceRestarts; i++) {
 | 
				
			||||||
		if (CTheZones::GetLevelFromPosition(&PoliceRestartPoints[i]) == (OverridePoliceStationLevel != LEVEL_NONE ? OverridePoliceStationLevel : curlevel)) {
 | 
							if (CTheZones::GetLevelFromPosition(&PoliceRestartPoints[i]) == (OverridePoliceStationLevel != LEVEL_GENERIC ? OverridePoliceStationLevel : curlevel)) {
 | 
				
			||||||
			float dist = (pos - PoliceRestartPoints[i]).MagnitudeSqr();
 | 
								float dist = (pos - PoliceRestartPoints[i]).MagnitudeSqr();
 | 
				
			||||||
			if (fMinDist >= dist) {
 | 
								if (fMinDist >= dist) {
 | 
				
			||||||
				fMinDist = dist;
 | 
									fMinDist = dist;
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -9143,7 +9143,7 @@ int8 CRunningScript::ProcessCommands800To899(int32 command)
 | 
				
			||||||
		CEntity* apEntities[16];
 | 
							CEntity* apEntities[16];
 | 
				
			||||||
		CWorld::FindObjectsOfTypeInRange(mi, pos, range, true, &total, 16, apEntities, true, false, false, true, true);
 | 
							CWorld::FindObjectsOfTypeInRange(mi, pos, range, true, &total, 16, apEntities, true, false, false, true, true);
 | 
				
			||||||
		if (total == 0)
 | 
							if (total == 0)
 | 
				
			||||||
			CWorld::FindObjectsOfTypeInRangeSectorList(mi, CWorld::GetBigBuildingList(LEVEL_NONE), pos, range, true, &total, 16, apEntities);
 | 
								CWorld::FindObjectsOfTypeInRangeSectorList(mi, CWorld::GetBigBuildingList(LEVEL_GENERIC), pos, range, true, &total, 16, apEntities);
 | 
				
			||||||
		if (total == 0)
 | 
							if (total == 0)
 | 
				
			||||||
			CWorld::FindObjectsOfTypeInRangeSectorList(mi, CWorld::GetBigBuildingList(CTheZones::GetLevelFromPosition(&pos)), pos, range, true, &total, 16, apEntities);
 | 
								CWorld::FindObjectsOfTypeInRangeSectorList(mi, CWorld::GetBigBuildingList(CTheZones::GetLevelFromPosition(&pos)), pos, range, true, &total, 16, apEntities);
 | 
				
			||||||
		CEntity* pClosestEntity = nil;
 | 
							CEntity* pClosestEntity = nil;
 | 
				
			||||||
| 
						 | 
					@ -9933,7 +9933,7 @@ int8 CRunningScript::ProcessCommands900To999(int32 command)
 | 
				
			||||||
		CEntity* apEntities[16];
 | 
							CEntity* apEntities[16];
 | 
				
			||||||
		CWorld::FindObjectsOfTypeInRange(mi1, pos, radius, true, &total, 16, apEntities, true, false, false, false, false);
 | 
							CWorld::FindObjectsOfTypeInRange(mi1, pos, radius, true, &total, 16, apEntities, true, false, false, false, false);
 | 
				
			||||||
		if (total == 0)
 | 
							if (total == 0)
 | 
				
			||||||
			CWorld::FindObjectsOfTypeInRangeSectorList(mi1, CWorld::GetBigBuildingList(LEVEL_NONE), pos, radius, true, &total, 16, apEntities);
 | 
								CWorld::FindObjectsOfTypeInRangeSectorList(mi1, CWorld::GetBigBuildingList(LEVEL_GENERIC), pos, radius, true, &total, 16, apEntities);
 | 
				
			||||||
		if (total == 0)
 | 
							if (total == 0)
 | 
				
			||||||
			CWorld::FindObjectsOfTypeInRangeSectorList(mi1, CWorld::GetBigBuildingList(CTheZones::GetLevelFromPosition(&pos)), pos, radius, true, &total, 16, apEntities);
 | 
								CWorld::FindObjectsOfTypeInRangeSectorList(mi1, CWorld::GetBigBuildingList(CTheZones::GetLevelFromPosition(&pos)), pos, radius, true, &total, 16, apEntities);
 | 
				
			||||||
		CEntity* pClosestEntity = nil;
 | 
							CEntity* pClosestEntity = nil;
 | 
				
			||||||
| 
						 | 
					@ -10593,11 +10593,15 @@ int8 CRunningScript::ProcessCommands1000To1099(int32 command)
 | 
				
			||||||
		CollectParameters(&m_nIp, 1);
 | 
							CollectParameters(&m_nIp, 1);
 | 
				
			||||||
		CTimer::Stop();
 | 
							CTimer::Stop();
 | 
				
			||||||
		CGame::currLevel = (eLevelName)ScriptParams[0];
 | 
							CGame::currLevel = (eLevelName)ScriptParams[0];
 | 
				
			||||||
 | 
					#ifndef NO_ISLAND_LOADING
 | 
				
			||||||
		CStreaming::RemoveUnusedBigBuildings(CGame::currLevel);
 | 
							CStreaming::RemoveUnusedBigBuildings(CGame::currLevel);
 | 
				
			||||||
		CStreaming::RemoveUnusedBuildings(CGame::currLevel);
 | 
							CStreaming::RemoveUnusedBuildings(CGame::currLevel);
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
		CCollision::SortOutCollisionAfterLoad();
 | 
							CCollision::SortOutCollisionAfterLoad();
 | 
				
			||||||
 | 
					#ifndef NO_ISLAND_LOADING
 | 
				
			||||||
		CStreaming::RequestIslands(CGame::currLevel);
 | 
							CStreaming::RequestIslands(CGame::currLevel);
 | 
				
			||||||
		CStreaming::LoadAllRequestedModels(true);
 | 
							CStreaming::LoadAllRequestedModels(true);
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
		CTimer::Update();
 | 
							CTimer::Update();
 | 
				
			||||||
		return 0;
 | 
							return 0;
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
| 
						 | 
					@ -10626,7 +10630,7 @@ int8 CRunningScript::ProcessCommands1000To1099(int32 command)
 | 
				
			||||||
		if (ScriptParams[1])
 | 
							if (ScriptParams[1])
 | 
				
			||||||
			pVehicle->m_nZoneLevel = CTheZones::GetLevelFromPosition(&pVehicle->GetPosition());
 | 
								pVehicle->m_nZoneLevel = CTheZones::GetLevelFromPosition(&pVehicle->GetPosition());
 | 
				
			||||||
		else
 | 
							else
 | 
				
			||||||
			pVehicle->m_nZoneLevel = LEVEL_NONE;
 | 
								pVehicle->m_nZoneLevel = LEVEL_GENERIC;
 | 
				
			||||||
		return 0;
 | 
							return 0;
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
	case COMMAND_SET_CHAR_STAYS_IN_CURRENT_LEVEL:
 | 
						case COMMAND_SET_CHAR_STAYS_IN_CURRENT_LEVEL:
 | 
				
			||||||
| 
						 | 
					@ -10637,7 +10641,7 @@ int8 CRunningScript::ProcessCommands1000To1099(int32 command)
 | 
				
			||||||
		if (ScriptParams[1])
 | 
							if (ScriptParams[1])
 | 
				
			||||||
			pPed->m_nZoneLevel = CTheZones::GetLevelFromPosition(&pPed->GetPosition());
 | 
								pPed->m_nZoneLevel = CTheZones::GetLevelFromPosition(&pPed->GetPosition());
 | 
				
			||||||
		else
 | 
							else
 | 
				
			||||||
			pPed->m_nZoneLevel = LEVEL_NONE;
 | 
								pPed->m_nZoneLevel = LEVEL_GENERIC;
 | 
				
			||||||
		return 0;
 | 
							return 0;
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
	*/
 | 
						*/
 | 
				
			||||||
| 
						 | 
					@ -11275,18 +11279,24 @@ int8 CRunningScript::ProcessCommands1100To1199(int32 command)
 | 
				
			||||||
		CTimer::Stop();
 | 
							CTimer::Stop();
 | 
				
			||||||
		CGame::currLevel = (eLevelName)ScriptParams[0];
 | 
							CGame::currLevel = (eLevelName)ScriptParams[0];
 | 
				
			||||||
		if (CGame::currLevel != CCollision::ms_collisionInMemory) {
 | 
							if (CGame::currLevel != CCollision::ms_collisionInMemory) {
 | 
				
			||||||
 | 
					#ifndef NO_ISLAND_LOADING
 | 
				
			||||||
			DMAudio.SetEffectsFadeVol(0);
 | 
								DMAudio.SetEffectsFadeVol(0);
 | 
				
			||||||
			CPad::StopPadsShaking();
 | 
								CPad::StopPadsShaking();
 | 
				
			||||||
			CCollision::LoadCollisionScreen(CGame::currLevel);
 | 
								CCollision::LoadCollisionScreen(CGame::currLevel);
 | 
				
			||||||
			DMAudio.Service();
 | 
								DMAudio.Service();
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
			CPopulation::DealWithZoneChange(CCollision::ms_collisionInMemory, CGame::currLevel, false);
 | 
								CPopulation::DealWithZoneChange(CCollision::ms_collisionInMemory, CGame::currLevel, false);
 | 
				
			||||||
 | 
					#ifndef NO_ISLAND_LOADING
 | 
				
			||||||
			CStreaming::RemoveUnusedBigBuildings(CGame::currLevel);
 | 
								CStreaming::RemoveUnusedBigBuildings(CGame::currLevel);
 | 
				
			||||||
			CStreaming::RemoveUnusedBuildings(CGame::currLevel);
 | 
								CStreaming::RemoveUnusedBuildings(CGame::currLevel);
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
			CCollision::SortOutCollisionAfterLoad();
 | 
								CCollision::SortOutCollisionAfterLoad();
 | 
				
			||||||
 | 
					#ifndef NO_ISLAND_LOADING
 | 
				
			||||||
			CStreaming::RequestIslands(CGame::currLevel);
 | 
								CStreaming::RequestIslands(CGame::currLevel);
 | 
				
			||||||
			CStreaming::RequestBigBuildings(CGame::currLevel);
 | 
								CStreaming::RequestBigBuildings(CGame::currLevel);
 | 
				
			||||||
			CStreaming::LoadAllRequestedModels(true);
 | 
								CStreaming::LoadAllRequestedModels(true);
 | 
				
			||||||
			DMAudio.SetEffectsFadeVol(127);
 | 
								DMAudio.SetEffectsFadeVol(127);
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
		CTimer::Update();
 | 
							CTimer::Update();
 | 
				
			||||||
		return 0;
 | 
							return 0;
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -41,7 +41,7 @@ void
 | 
				
			||||||
CCollision::Init(void)
 | 
					CCollision::Init(void)
 | 
				
			||||||
{
 | 
					{
 | 
				
			||||||
	ms_colModelCache.Init(NUMCOLCACHELINKS);
 | 
						ms_colModelCache.Init(NUMCOLCACHELINKS);
 | 
				
			||||||
	ms_collisionInMemory = LEVEL_NONE;
 | 
						ms_collisionInMemory = LEVEL_GENERIC;
 | 
				
			||||||
	CColStore::Initialise();
 | 
						CColStore::Initialise();
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
| 
						 | 
					@ -70,10 +70,10 @@ GetCollisionInSectorList(CPtrList &list)
 | 
				
			||||||
	for(node = list.first; node; node = node->next){
 | 
						for(node = list.first; node; node = node->next){
 | 
				
			||||||
		e = (CEntity*)node->item;
 | 
							e = (CEntity*)node->item;
 | 
				
			||||||
		level = CModelInfo::GetModelInfo(e->GetModelIndex())->GetColModel()->level;
 | 
							level = CModelInfo::GetModelInfo(e->GetModelIndex())->GetColModel()->level;
 | 
				
			||||||
		if(level != LEVEL_NONE)
 | 
							if(level != LEVEL_GENERIC)
 | 
				
			||||||
			return (eLevelName)level;
 | 
								return (eLevelName)level;
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
	return LEVEL_NONE;
 | 
						return LEVEL_GENERIC;
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
//--MIAMI: unused
 | 
					//--MIAMI: unused
 | 
				
			||||||
| 
						 | 
					@ -84,15 +84,15 @@ GetCollisionInSector(CSector §)
 | 
				
			||||||
	int level;
 | 
						int level;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	level = GetCollisionInSectorList(sect.m_lists[ENTITYLIST_BUILDINGS]);
 | 
						level = GetCollisionInSectorList(sect.m_lists[ENTITYLIST_BUILDINGS]);
 | 
				
			||||||
	if(level == LEVEL_NONE)
 | 
						if(level == LEVEL_GENERIC)
 | 
				
			||||||
		level = GetCollisionInSectorList(sect.m_lists[ENTITYLIST_BUILDINGS_OVERLAP]);
 | 
							level = GetCollisionInSectorList(sect.m_lists[ENTITYLIST_BUILDINGS_OVERLAP]);
 | 
				
			||||||
	if(level == LEVEL_NONE)
 | 
						if(level == LEVEL_GENERIC)
 | 
				
			||||||
		level = GetCollisionInSectorList(sect.m_lists[ENTITYLIST_OBJECTS]);
 | 
							level = GetCollisionInSectorList(sect.m_lists[ENTITYLIST_OBJECTS]);
 | 
				
			||||||
	if(level == LEVEL_NONE)
 | 
						if(level == LEVEL_GENERIC)
 | 
				
			||||||
		level = GetCollisionInSectorList(sect.m_lists[ENTITYLIST_OBJECTS_OVERLAP]);
 | 
							level = GetCollisionInSectorList(sect.m_lists[ENTITYLIST_OBJECTS_OVERLAP]);
 | 
				
			||||||
	if(level == LEVEL_NONE)
 | 
						if(level == LEVEL_GENERIC)
 | 
				
			||||||
		level = GetCollisionInSectorList(sect.m_lists[ENTITYLIST_DUMMIES]);
 | 
							level = GetCollisionInSectorList(sect.m_lists[ENTITYLIST_DUMMIES]);
 | 
				
			||||||
	if(level == LEVEL_NONE)
 | 
						if(level == LEVEL_GENERIC)
 | 
				
			||||||
		level = GetCollisionInSectorList(sect.m_lists[ENTITYLIST_DUMMIES_OVERLAP]);
 | 
							level = GetCollisionInSectorList(sect.m_lists[ENTITYLIST_DUMMIES_OVERLAP]);
 | 
				
			||||||
	return (eLevelName)level;
 | 
						return (eLevelName)level;
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -91,6 +91,10 @@ int curBottomBarOption = -1;
 | 
				
			||||||
int hoveredBottomBarOption = -1;
 | 
					int hoveredBottomBarOption = -1;
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#ifdef CUTSCENE_BORDERS_SWITCH
 | 
				
			||||||
 | 
					bool CMenuManager::m_PrefsCutsceneBorders = true;
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
// Originally that was PS2 option color, they forget it here and used in PrintBriefs once(but didn't use the output anyway)
 | 
					// Originally that was PS2 option color, they forget it here and used in PrintBriefs once(but didn't use the output anyway)
 | 
				
			||||||
#ifdef PS2_LIKE_MENU
 | 
					#ifdef PS2_LIKE_MENU
 | 
				
			||||||
const CRGBA TEXT_COLOR = CRGBA(150, 110, 30, 255);
 | 
					const CRGBA TEXT_COLOR = CRGBA(150, 110, 30, 255);
 | 
				
			||||||
| 
						 | 
					@ -3166,6 +3170,9 @@ CMenuManager::LoadSettings()
 | 
				
			||||||
			CFileMgr::Read(fileHandle, (char*)&m_PrefsShowHud, 1);
 | 
								CFileMgr::Read(fileHandle, (char*)&m_PrefsShowHud, 1);
 | 
				
			||||||
			CFileMgr::Read(fileHandle, (char*)&m_PrefsRadarMode, 1);
 | 
								CFileMgr::Read(fileHandle, (char*)&m_PrefsRadarMode, 1);
 | 
				
			||||||
			CFileMgr::Read(fileHandle, (char*)&m_PrefsShowLegends, 1);
 | 
								CFileMgr::Read(fileHandle, (char*)&m_PrefsShowLegends, 1);
 | 
				
			||||||
 | 
					#ifdef CUTSCENE_BORDERS_SWITCH
 | 
				
			||||||
 | 
								CFileMgr::Read(fileHandle, (char *)&CMenuManager::m_PrefsCutsceneBorders, 1);
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
| 
						 | 
					@ -3275,6 +3282,9 @@ CMenuManager::SaveSettings()
 | 
				
			||||||
		CFileMgr::Write(fileHandle, (char*)&m_PrefsShowHud, 1);
 | 
							CFileMgr::Write(fileHandle, (char*)&m_PrefsShowHud, 1);
 | 
				
			||||||
		CFileMgr::Write(fileHandle, (char*)&m_PrefsRadarMode, 1);
 | 
							CFileMgr::Write(fileHandle, (char*)&m_PrefsRadarMode, 1);
 | 
				
			||||||
		CFileMgr::Write(fileHandle, (char*)&m_PrefsShowLegends, 1);
 | 
							CFileMgr::Write(fileHandle, (char*)&m_PrefsShowLegends, 1);
 | 
				
			||||||
 | 
					#ifdef CUTSCENE_BORDERS_SWITCH
 | 
				
			||||||
 | 
							CFileMgr::Write(fileHandle, (char *)&CMenuManager::m_PrefsCutsceneBorders, 1);
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
	m_lastWorking3DAudioProvider = m_nPrefsAudio3DProviderIndex;
 | 
						m_lastWorking3DAudioProvider = m_nPrefsAudio3DProviderIndex;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -598,6 +598,10 @@ public:
 | 
				
			||||||
	};
 | 
						};
 | 
				
			||||||
	bool GetIsMenuActive() {return !!m_bMenuActive;}
 | 
						bool GetIsMenuActive() {return !!m_bMenuActive;}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#ifdef CUTSCENE_BORDERS_SWITCH
 | 
				
			||||||
 | 
						static bool m_PrefsCutsceneBorders;
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#ifndef MASTER
 | 
					#ifndef MASTER
 | 
				
			||||||
	static bool m_PrefsMarketing;
 | 
						static bool m_PrefsMarketing;
 | 
				
			||||||
	static bool m_PrefsDisableTutorials;
 | 
						static bool m_PrefsDisableTutorials;
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -354,7 +354,7 @@ bool CGame::Initialise(const char* datFile)
 | 
				
			||||||
	LoadingScreen("Loading the Game", "Setup streaming", nil);
 | 
						LoadingScreen("Loading the Game", "Setup streaming", nil);
 | 
				
			||||||
	CStreaming::LoadInitialVehicles();
 | 
						CStreaming::LoadInitialVehicles();
 | 
				
			||||||
	CStreaming::LoadInitialPeds();
 | 
						CStreaming::LoadInitialPeds();
 | 
				
			||||||
	CStreaming::RequestBigBuildings(LEVEL_NONE);
 | 
						CStreaming::RequestBigBuildings(LEVEL_GENERIC);
 | 
				
			||||||
	CStreaming::LoadAllRequestedModels(false);
 | 
						CStreaming::LoadAllRequestedModels(false);
 | 
				
			||||||
	printf("Streaming uses %dK of its memory", CStreaming::ms_memoryUsed / 1024);
 | 
						printf("Streaming uses %dK of its memory", CStreaming::ms_memoryUsed / 1024);
 | 
				
			||||||
	LoadingScreen("Loading the Game", "Load animations", GetRandomSplashScreen());
 | 
						LoadingScreen("Loading the Game", "Load animations", GetRandomSplashScreen());
 | 
				
			||||||
| 
						 | 
					@ -505,7 +505,7 @@ void CGame::ReInitGameObjectVariables(void)
 | 
				
			||||||
	CTimeCycle::Initialise();
 | 
						CTimeCycle::Initialise();
 | 
				
			||||||
	CDraw::SetFOV(120.0f);
 | 
						CDraw::SetFOV(120.0f);
 | 
				
			||||||
	CDraw::ms_fLODDistance = 500.0f;
 | 
						CDraw::ms_fLODDistance = 500.0f;
 | 
				
			||||||
	CStreaming::RequestBigBuildings(LEVEL_NONE);
 | 
						CStreaming::RequestBigBuildings(LEVEL_GENERIC);
 | 
				
			||||||
	CStreaming::LoadAllRequestedModels(false);
 | 
						CStreaming::LoadAllRequestedModels(false);
 | 
				
			||||||
	CPed::Initialise();
 | 
						CPed::Initialise();
 | 
				
			||||||
	CEventList::Initialise();
 | 
						CEventList::Initialise();
 | 
				
			||||||
| 
						 | 
					@ -643,7 +643,7 @@ void CGame::InitialiseWhenRestarting(void)
 | 
				
			||||||
			CTimer::Initialise();
 | 
								CTimer::Initialise();
 | 
				
			||||||
			FrontEndMenuManager.m_bWantToLoad = false;
 | 
								FrontEndMenuManager.m_bWantToLoad = false;
 | 
				
			||||||
			ReInitGameObjectVariables();
 | 
								ReInitGameObjectVariables();
 | 
				
			||||||
			currLevel = LEVEL_NONE;
 | 
								currLevel = LEVEL_GENERIC;
 | 
				
			||||||
			CCollision::SortOutCollisionAfterLoad();
 | 
								CCollision::SortOutCollisionAfterLoad();
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -2,7 +2,7 @@
 | 
				
			||||||
 | 
					
 | 
				
			||||||
enum eLevelName {
 | 
					enum eLevelName {
 | 
				
			||||||
	LEVEL_IGNORE = -1, // beware, this is only used in CPhysical's m_nZoneLevel
 | 
						LEVEL_IGNORE = -1, // beware, this is only used in CPhysical's m_nZoneLevel
 | 
				
			||||||
	LEVEL_NONE = 0,
 | 
						LEVEL_GENERIC = 0,
 | 
				
			||||||
	LEVEL_BEACH,
 | 
						LEVEL_BEACH,
 | 
				
			||||||
	LEVEL_MAINLAND
 | 
						LEVEL_MAINLAND
 | 
				
			||||||
};
 | 
					};
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -560,7 +560,7 @@ CPlayerInfo::Process(void)
 | 
				
			||||||
		veh->m_nZoneLevel = LEVEL_IGNORE;
 | 
							veh->m_nZoneLevel = LEVEL_IGNORE;
 | 
				
			||||||
		for (int i = 0; i < ARRAY_SIZE(veh->pPassengers); i++) {
 | 
							for (int i = 0; i < ARRAY_SIZE(veh->pPassengers); i++) {
 | 
				
			||||||
			if (veh->pPassengers[i])
 | 
								if (veh->pPassengers[i])
 | 
				
			||||||
				veh->pPassengers[i]->m_nZoneLevel = LEVEL_NONE;
 | 
									veh->pPassengers[i]->m_nZoneLevel = LEVEL_GENERIC;
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
		CStats::DistanceTravelledInVehicle += veh->m_fDistanceTravelled;
 | 
							CStats::DistanceTravelledInVehicle += veh->m_fDistanceTravelled;
 | 
				
			||||||
	} else {
 | 
						} else {
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -21,8 +21,8 @@ int32 CStats::PedsKilledOfThisType[NUM_PEDTYPES];
 | 
				
			||||||
int32 CStats::TimesDied;
 | 
					int32 CStats::TimesDied;
 | 
				
			||||||
int32 CStats::TimesArrested;
 | 
					int32 CStats::TimesArrested;
 | 
				
			||||||
int32 CStats::KillsSinceLastCheckpoint;
 | 
					int32 CStats::KillsSinceLastCheckpoint;
 | 
				
			||||||
int32 CStats::DistanceTravelledInVehicle;
 | 
					float CStats::DistanceTravelledInVehicle;
 | 
				
			||||||
int32 CStats::DistanceTravelledOnFoot;
 | 
					float CStats::DistanceTravelledOnFoot;
 | 
				
			||||||
int32 CStats::ProgressMade;
 | 
					int32 CStats::ProgressMade;
 | 
				
			||||||
int32 CStats::TotalProgressInGame;
 | 
					int32 CStats::TotalProgressInGame;
 | 
				
			||||||
int32 CStats::CarsExploded;
 | 
					int32 CStats::CarsExploded;
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -25,8 +25,8 @@ public:
 | 
				
			||||||
	static int32 TimesDied;
 | 
						static int32 TimesDied;
 | 
				
			||||||
	static int32 TimesArrested;
 | 
						static int32 TimesArrested;
 | 
				
			||||||
	static int32 KillsSinceLastCheckpoint;
 | 
						static int32 KillsSinceLastCheckpoint;
 | 
				
			||||||
	static int32 DistanceTravelledInVehicle;
 | 
						static float DistanceTravelledInVehicle;
 | 
				
			||||||
	static int32 DistanceTravelledOnFoot;
 | 
						static float DistanceTravelledOnFoot;
 | 
				
			||||||
	static int32 CarsExploded;
 | 
						static int32 CarsExploded;
 | 
				
			||||||
	static int32 PeopleKilledByPlayer;
 | 
						static int32 PeopleKilledByPlayer;
 | 
				
			||||||
	static int32 ProgressMade;
 | 
						static int32 ProgressMade;
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -723,7 +723,11 @@ CStreaming::RequestBigBuildings(eLevelName level, const CVector &pos)
 | 
				
			||||||
	n = CPools::GetBuildingPool()->GetSize()-1;
 | 
						n = CPools::GetBuildingPool()->GetSize()-1;
 | 
				
			||||||
	for(i = n; i >= 0; i--){
 | 
						for(i = n; i >= 0; i--){
 | 
				
			||||||
		b = CPools::GetBuildingPool()->GetSlot(i);
 | 
							b = CPools::GetBuildingPool()->GetSlot(i);
 | 
				
			||||||
		if(b && b->bIsBIGBuilding && b->m_level == level)
 | 
							if(b && b->bIsBIGBuilding
 | 
				
			||||||
 | 
					#ifndef NO_ISLAND_LOADING
 | 
				
			||||||
 | 
							    && b->m_level == level
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
							)
 | 
				
			||||||
			if(b->bStreamBIGBuilding){
 | 
								if(b->bStreamBIGBuilding){
 | 
				
			||||||
				if(CRenderer::ShouldModelBeStreamed(b, pos))
 | 
									if(CRenderer::ShouldModelBeStreamed(b, pos))
 | 
				
			||||||
					RequestModel(b->GetModelIndex(), 0);
 | 
										RequestModel(b->GetModelIndex(), 0);
 | 
				
			||||||
| 
						 | 
					@ -795,6 +799,7 @@ CStreaming::InstanceLoadedModels(const CVector &pos)
 | 
				
			||||||
void
 | 
					void
 | 
				
			||||||
CStreaming::RequestIslands(eLevelName level)
 | 
					CStreaming::RequestIslands(eLevelName level)
 | 
				
			||||||
{
 | 
					{
 | 
				
			||||||
 | 
					#ifndef NO_ISLAND_LOADING
 | 
				
			||||||
	switch(level){
 | 
						switch(level){
 | 
				
			||||||
	case LEVEL_MAINLAND:
 | 
						case LEVEL_MAINLAND:
 | 
				
			||||||
		if(islandLODbeach != -1)
 | 
							if(islandLODbeach != -1)
 | 
				
			||||||
| 
						 | 
					@ -806,6 +811,7 @@ CStreaming::RequestIslands(eLevelName level)
 | 
				
			||||||
		break;
 | 
							break;
 | 
				
			||||||
	default: break;
 | 
						default: break;
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
//--MIAMI: TODO
 | 
					//--MIAMI: TODO
 | 
				
			||||||
| 
						 | 
					@ -1010,10 +1016,12 @@ CStreaming::RemoveBuildings(eLevelName level)
 | 
				
			||||||
void
 | 
					void
 | 
				
			||||||
CStreaming::RemoveUnusedBigBuildings(eLevelName level)
 | 
					CStreaming::RemoveUnusedBigBuildings(eLevelName level)
 | 
				
			||||||
{
 | 
					{
 | 
				
			||||||
 | 
					#ifndef NO_ISLAND_LOADING
 | 
				
			||||||
	if(level != LEVEL_BEACH)
 | 
						if(level != LEVEL_BEACH)
 | 
				
			||||||
		RemoveBigBuildings(LEVEL_BEACH);
 | 
							RemoveBigBuildings(LEVEL_BEACH);
 | 
				
			||||||
	if(level != LEVEL_MAINLAND)
 | 
						if(level != LEVEL_MAINLAND)
 | 
				
			||||||
		RemoveBigBuildings(LEVEL_MAINLAND);
 | 
							RemoveBigBuildings(LEVEL_MAINLAND);
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
	RemoveIslandsNotUsed(level);
 | 
						RemoveIslandsNotUsed(level);
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
| 
						 | 
					@ -1035,6 +1043,7 @@ DeleteIsland(CEntity *island)
 | 
				
			||||||
void
 | 
					void
 | 
				
			||||||
CStreaming::RemoveIslandsNotUsed(eLevelName level)
 | 
					CStreaming::RemoveIslandsNotUsed(eLevelName level)
 | 
				
			||||||
{
 | 
					{
 | 
				
			||||||
 | 
					#ifndef NO_ISLAND_LOADING
 | 
				
			||||||
	int i;
 | 
						int i;
 | 
				
			||||||
	if(pIslandLODmainlandEntity == nil)
 | 
						if(pIslandLODmainlandEntity == nil)
 | 
				
			||||||
	for(i = CPools::GetBuildingPool()->GetSize()-1; i >= 0; i--){
 | 
						for(i = CPools::GetBuildingPool()->GetSize()-1; i >= 0; i--){
 | 
				
			||||||
| 
						 | 
					@ -1053,8 +1062,10 @@ CStreaming::RemoveIslandsNotUsed(eLevelName level)
 | 
				
			||||||
		break;
 | 
							break;
 | 
				
			||||||
	case LEVEL_BEACH:
 | 
						case LEVEL_BEACH:
 | 
				
			||||||
		DeleteIsland(pIslandLODbeachEntity);
 | 
							DeleteIsland(pIslandLODbeachEntity);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
		break;
 | 
							break;
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 | 
					#endif // !NO_ISLAND_LOADING
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
//--MIAMI: done
 | 
					//--MIAMI: done
 | 
				
			||||||
| 
						 | 
					@ -1594,7 +1605,7 @@ CStreaming::LoadBigBuildingsWhenNeeded(void)
 | 
				
			||||||
	if(CCutsceneMgr::IsCutsceneProcessing())
 | 
						if(CCutsceneMgr::IsCutsceneProcessing())
 | 
				
			||||||
		return;
 | 
							return;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	if(CTheZones::m_CurrLevel == LEVEL_NONE || 
 | 
						if(CTheZones::m_CurrLevel == LEVEL_GENERIC || 
 | 
				
			||||||
	   CTheZones::m_CurrLevel == CGame::currLevel)
 | 
						   CTheZones::m_CurrLevel == CGame::currLevel)
 | 
				
			||||||
		return;
 | 
							return;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
| 
						 | 
					@ -1612,7 +1623,7 @@ CStreaming::LoadBigBuildingsWhenNeeded(void)
 | 
				
			||||||
	CGame::TidyUpMemory(true, true);
 | 
						CGame::TidyUpMemory(true, true);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	CReplay::EmptyReplayBuffer();
 | 
						CReplay::EmptyReplayBuffer();
 | 
				
			||||||
	if(CGame::currLevel != LEVEL_NONE)
 | 
						if(CGame::currLevel != LEVEL_GENERIC)
 | 
				
			||||||
		LoadSplash(GetLevelSplashScreen(CGame::currLevel));
 | 
							LoadSplash(GetLevelSplashScreen(CGame::currLevel));
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	CStreaming::RequestBigBuildings(CGame::currLevel, TheCamera.GetPosition());
 | 
						CStreaming::RequestBigBuildings(CGame::currLevel, TheCamera.GetPosition());
 | 
				
			||||||
| 
						 | 
					@ -2620,16 +2631,16 @@ CStreaming::LoadScene(const CVector &pos)
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
	CRenderer::m_loadingPriority = false;
 | 
						CRenderer::m_loadingPriority = false;
 | 
				
			||||||
	DeleteAllRwObjects();
 | 
						DeleteAllRwObjects();
 | 
				
			||||||
	if(level == LEVEL_NONE)
 | 
						if(level == LEVEL_GENERIC)
 | 
				
			||||||
		level = CGame::currLevel;
 | 
							level = CGame::currLevel;
 | 
				
			||||||
	CGame::currLevel = level;
 | 
						CGame::currLevel = level;
 | 
				
			||||||
	RemoveUnusedBigBuildings(level);
 | 
						RemoveUnusedBigBuildings(level);
 | 
				
			||||||
	RequestBigBuildings(level, pos);
 | 
						RequestBigBuildings(level, pos);
 | 
				
			||||||
	RequestBigBuildings(LEVEL_NONE, pos);
 | 
						RequestBigBuildings(LEVEL_GENERIC, pos);
 | 
				
			||||||
	RemoveIslandsNotUsed(level);
 | 
						RemoveIslandsNotUsed(level);
 | 
				
			||||||
	LoadAllRequestedModels(false);
 | 
						LoadAllRequestedModels(false);
 | 
				
			||||||
	InstanceBigBuildings(level, pos);
 | 
						InstanceBigBuildings(level, pos);
 | 
				
			||||||
	InstanceBigBuildings(LEVEL_NONE, pos);
 | 
						InstanceBigBuildings(LEVEL_GENERIC, pos);
 | 
				
			||||||
	AddModelsToRequestList(pos);
 | 
						AddModelsToRequestList(pos);
 | 
				
			||||||
	CRadar::StreamRadarSections(pos);
 | 
						CRadar::StreamRadarSections(pos);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -37,19 +37,19 @@ CTempColModels::Initialise(void)
 | 
				
			||||||
#define SET_COLMODEL_SPHERES(colmodel, sphrs)\
 | 
					#define SET_COLMODEL_SPHERES(colmodel, sphrs)\
 | 
				
			||||||
	colmodel.numSpheres = ARRAY_SIZE(sphrs);\
 | 
						colmodel.numSpheres = ARRAY_SIZE(sphrs);\
 | 
				
			||||||
	colmodel.spheres = sphrs;\
 | 
						colmodel.spheres = sphrs;\
 | 
				
			||||||
	colmodel.level = LEVEL_NONE;\
 | 
						colmodel.level = LEVEL_GENERIC;\
 | 
				
			||||||
	colmodel.ownsCollisionVolumes = false;\
 | 
						colmodel.ownsCollisionVolumes = false;\
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	int i;
 | 
						int i;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	ms_colModelBBox.boundingSphere.Set(2.0f, CVector(0.0f, 0.0f, 0.0f));
 | 
						ms_colModelBBox.boundingSphere.Set(2.0f, CVector(0.0f, 0.0f, 0.0f));
 | 
				
			||||||
	ms_colModelBBox.boundingBox.Set(CVector(-2.0f, -2.0f, -2.0f), CVector(2.0f, 2.0f, 2.0f));
 | 
						ms_colModelBBox.boundingBox.Set(CVector(-2.0f, -2.0f, -2.0f), CVector(2.0f, 2.0f, 2.0f));
 | 
				
			||||||
	ms_colModelBBox.level = LEVEL_NONE;
 | 
						ms_colModelBBox.level = LEVEL_GENERIC;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	for (i = 0; i < ARRAY_SIZE(ms_colModelCutObj); i++) {
 | 
						for (i = 0; i < ARRAY_SIZE(ms_colModelCutObj); i++) {
 | 
				
			||||||
		ms_colModelCutObj[i].boundingSphere.Set(2.0f, CVector(0.0f, 0.0f, 0.0f));
 | 
							ms_colModelCutObj[i].boundingSphere.Set(2.0f, CVector(0.0f, 0.0f, 0.0f));
 | 
				
			||||||
		ms_colModelCutObj[i].boundingBox.Set(CVector(-2.0f, -2.0f, -2.0f), CVector(2.0f, 2.0f, 2.0f));
 | 
							ms_colModelCutObj[i].boundingBox.Set(CVector(-2.0f, -2.0f, -2.0f), CVector(2.0f, 2.0f, 2.0f));
 | 
				
			||||||
		ms_colModelCutObj[i].level = LEVEL_NONE;
 | 
							ms_colModelCutObj[i].level = LEVEL_GENERIC;
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	// Ped Spheres
 | 
						// Ped Spheres
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -1785,7 +1785,7 @@ CWorld::ClearForRestart(void)
 | 
				
			||||||
			CWorld::Remove(pEntity);
 | 
								CWorld::Remove(pEntity);
 | 
				
			||||||
			delete pEntity;
 | 
								delete pEntity;
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
		for(CPtrNode *pNode = GetBigBuildingList(LEVEL_NONE).first; pNode; pNode = pNode->next) {
 | 
							for(CPtrNode *pNode = GetBigBuildingList(LEVEL_GENERIC).first; pNode; pNode = pNode->next) {
 | 
				
			||||||
			CVehicle *pVehicle = (CVehicle *)pNode->item;
 | 
								CVehicle *pVehicle = (CVehicle *)pNode->item;
 | 
				
			||||||
			if(pVehicle && pVehicle->IsVehicle() && pVehicle->IsPlane()) {
 | 
								if(pVehicle && pVehicle->IsVehicle() && pVehicle->IsPlane()) {
 | 
				
			||||||
				CWorld::Remove(pVehicle);
 | 
									CWorld::Remove(pVehicle);
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -93,7 +93,7 @@ CTheZones::Init(void)
 | 
				
			||||||
	InfoZoneArray[0].maxx =  1600.0f;
 | 
						InfoZoneArray[0].maxx =  1600.0f;
 | 
				
			||||||
	InfoZoneArray[0].maxy =  2000.0f;
 | 
						InfoZoneArray[0].maxy =  2000.0f;
 | 
				
			||||||
	InfoZoneArray[0].maxz =  500.0f;
 | 
						InfoZoneArray[0].maxz =  500.0f;
 | 
				
			||||||
	InfoZoneArray[0].level = LEVEL_NONE;
 | 
						InfoZoneArray[0].level = LEVEL_GENERIC;
 | 
				
			||||||
	InfoZoneArray[0].type = ZONE_INFO;
 | 
						InfoZoneArray[0].type = ZONE_INFO;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	strcpy(NavigationZoneArray[0].name, "VICE_C");
 | 
						strcpy(NavigationZoneArray[0].name, "VICE_C");
 | 
				
			||||||
| 
						 | 
					@ -103,10 +103,10 @@ CTheZones::Init(void)
 | 
				
			||||||
	NavigationZoneArray[0].maxx =  1600.0f;
 | 
						NavigationZoneArray[0].maxx =  1600.0f;
 | 
				
			||||||
	NavigationZoneArray[0].maxy =  2000.0f;
 | 
						NavigationZoneArray[0].maxy =  2000.0f;
 | 
				
			||||||
	NavigationZoneArray[0].maxz =  500.0f;
 | 
						NavigationZoneArray[0].maxz =  500.0f;
 | 
				
			||||||
	NavigationZoneArray[0].level = LEVEL_NONE;
 | 
						NavigationZoneArray[0].level = LEVEL_GENERIC;
 | 
				
			||||||
	NavigationZoneArray[0].type = ZONE_NAVIG;
 | 
						NavigationZoneArray[0].type = ZONE_NAVIG;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	m_CurrLevel = LEVEL_NONE;
 | 
						m_CurrLevel = LEVEL_GENERIC;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	for(i = 0; i < NUMMAPZONES; i++){
 | 
						for(i = 0; i < NUMMAPZONES; i++){
 | 
				
			||||||
		memset(&MapZoneArray[i], 0, sizeof(CZone));
 | 
							memset(&MapZoneArray[i], 0, sizeof(CZone));
 | 
				
			||||||
| 
						 | 
					@ -120,7 +120,7 @@ CTheZones::Init(void)
 | 
				
			||||||
	MapZoneArray[0].maxx =  1600.0f;
 | 
						MapZoneArray[0].maxx =  1600.0f;
 | 
				
			||||||
	MapZoneArray[0].maxy =  2000.0f;
 | 
						MapZoneArray[0].maxy =  2000.0f;
 | 
				
			||||||
	MapZoneArray[0].maxz =  500.0f;
 | 
						MapZoneArray[0].maxz =  500.0f;
 | 
				
			||||||
	MapZoneArray[0].level = LEVEL_NONE;
 | 
						MapZoneArray[0].level = LEVEL_GENERIC;
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
//--MIAMI: done
 | 
					//--MIAMI: done
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -213,7 +213,10 @@ enum Config {
 | 
				
			||||||
#define DEFAULT_NATIVE_RESOLUTION	// Set default video mode to your native resolution (fixes Windows 10 launch)
 | 
					#define DEFAULT_NATIVE_RESOLUTION	// Set default video mode to your native resolution (fixes Windows 10 launch)
 | 
				
			||||||
#define USE_TXD_CDIMAGE		// generate and load textures from txd.img
 | 
					#define USE_TXD_CDIMAGE		// generate and load textures from txd.img
 | 
				
			||||||
#define IMPROVED_VIDEOMODE	// save and load videomode parameters instead of a magic number
 | 
					#define IMPROVED_VIDEOMODE	// save and load videomode parameters instead of a magic number
 | 
				
			||||||
 | 
					//#define DISABLE_LOADING_SCREEN // disable the loading screen which vastly improves the loading time
 | 
				
			||||||
 | 
					//#define NO_ISLAND_LOADING  // disable loadscreen between islands via loading all island data at once, consumes more memory and CPU
 | 
				
			||||||
//#define USE_TEXTURE_POOL
 | 
					//#define USE_TEXTURE_POOL
 | 
				
			||||||
 | 
					#define CUTSCENE_BORDERS_SWITCH
 | 
				
			||||||
 | 
					
 | 
				
			||||||
// Water & Particle
 | 
					// Water & Particle
 | 
				
			||||||
#define PC_PARTICLE
 | 
					#define PC_PARTICLE
 | 
				
			||||||
| 
						 | 
					@ -281,6 +284,7 @@ enum Config {
 | 
				
			||||||
#define VC_PED_PORTS			// various ports from VC's CPed, mostly subtle
 | 
					#define VC_PED_PORTS			// various ports from VC's CPed, mostly subtle
 | 
				
			||||||
// #define NEW_WALK_AROUND_ALGORITHM	// to make walking around vehicles/objects less awkward
 | 
					// #define NEW_WALK_AROUND_ALGORITHM	// to make walking around vehicles/objects less awkward
 | 
				
			||||||
#define CANCELLABLE_CAR_ENTER
 | 
					#define CANCELLABLE_CAR_ENTER
 | 
				
			||||||
 | 
					//#define PEDS_REPORT_CRIMES_ON_PHONE
 | 
				
			||||||
 | 
					
 | 
				
			||||||
// Camera
 | 
					// Camera
 | 
				
			||||||
#define IMPROVED_CAMERA		// Better Debug cam, and maybe more in the future
 | 
					#define IMPROVED_CAMERA		// Better Debug cam, and maybe more in the future
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -249,7 +249,11 @@ DoFade(void)
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
		// This is CCamera::GetScreenRect in VC
 | 
							// This is CCamera::GetScreenRect in VC
 | 
				
			||||||
		if(TheCamera.m_WideScreenOn){
 | 
							if(TheCamera.m_WideScreenOn
 | 
				
			||||||
 | 
					#ifdef CUTSCENE_BORDERS_SWITCH
 | 
				
			||||||
 | 
								&& CMenuManager::m_PrefsCutsceneBorders
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
								){
 | 
				
			||||||
			float y = SCREEN_HEIGHT/2 * TheCamera.m_ScreenReductionPercentage/100.0f;
 | 
								float y = SCREEN_HEIGHT/2 * TheCamera.m_ScreenReductionPercentage/100.0f;
 | 
				
			||||||
			rect.left = 0.0f;
 | 
								rect.left = 0.0f;
 | 
				
			||||||
			rect.right = SCREEN_WIDTH;
 | 
								rect.right = SCREEN_WIDTH;
 | 
				
			||||||
| 
						 | 
					@ -464,6 +468,11 @@ LoadingScreen(const char *str1, const char *str2, const char *splashscreen)
 | 
				
			||||||
{
 | 
					{
 | 
				
			||||||
	CSprite2d *splash;
 | 
						CSprite2d *splash;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#ifdef DISABLE_LOADING_SCREEN
 | 
				
			||||||
 | 
						if (str1 && str2)
 | 
				
			||||||
 | 
							return;
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#ifndef RANDOMSPLASH
 | 
					#ifndef RANDOMSPLASH
 | 
				
			||||||
	splashscreen = "LOADSC0";
 | 
						splashscreen = "LOADSC0";
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
| 
						 | 
					@ -885,7 +894,11 @@ Render2dStuff(void)
 | 
				
			||||||
	CReplay::Display();
 | 
						CReplay::Display();
 | 
				
			||||||
	CPickups::RenderPickUpText();
 | 
						CPickups::RenderPickUpText();
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	if(TheCamera.m_WideScreenOn)
 | 
						if(TheCamera.m_WideScreenOn
 | 
				
			||||||
 | 
					#ifdef CUTSCENE_BORDERS_SWITCH
 | 
				
			||||||
 | 
							&& CMenuManager::m_PrefsCutsceneBorders
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
							)
 | 
				
			||||||
		TheCamera.DrawBordersForWideScreen();
 | 
							TheCamera.DrawBordersForWideScreen();
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	CPed *player = FindPlayerPed();
 | 
						CPed *player = FindPlayerPed();
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -134,6 +134,14 @@ void ToggleFreeCam(int8 action)
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#ifdef CUTSCENE_BORDERS_SWITCH
 | 
				
			||||||
 | 
					void BorderModeChange(int8 displayedValue)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
						CMenuManager::m_PrefsCutsceneBorders = !!displayedValue;
 | 
				
			||||||
 | 
						FrontEndMenuManager.SaveSettings();
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
// Reloaded on language change, so you can use hardcoded wchar* and TheText.Get with peace of mind
 | 
					// Reloaded on language change, so you can use hardcoded wchar* and TheText.Get with peace of mind
 | 
				
			||||||
void
 | 
					void
 | 
				
			||||||
CustomFrontendOptionsPopulate(void)
 | 
					CustomFrontendOptionsPopulate(void)
 | 
				
			||||||
| 
						 | 
					@ -158,6 +166,12 @@ CustomFrontendOptionsPopulate(void)
 | 
				
			||||||
	FrontendOptionSetPosition(MENUPAGE_CONTROLLER_PC, 1);
 | 
						FrontendOptionSetPosition(MENUPAGE_CONTROLLER_PC, 1);
 | 
				
			||||||
	FrontendOptionAddDynamic(text, nil, ToggleFreeCam, nil);
 | 
						FrontendOptionAddDynamic(text, nil, ToggleFreeCam, nil);
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#ifdef CUTSCENE_BORDERS_SWITCH
 | 
				
			||||||
 | 
						static const wchar *off_on[] = { TheText.Get("FEM_OFF"), TheText.Get("FEM_ON") };
 | 
				
			||||||
 | 
						FrontendOptionSetPosition(MENUPAGE_GRAPHICS_SETTINGS, 9);
 | 
				
			||||||
 | 
						FrontendOptionAddSelect((const wchar *)L"CUTSCENE BORDERS", off_on, 2, (int8 *)&CMenuManager::m_PrefsCutsceneBorders, false, BorderModeChange, nil);
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -17,7 +17,7 @@ CBuilding::ReplaceWithNewModel(int32 id)
 | 
				
			||||||
	m_modelIndex = id;
 | 
						m_modelIndex = id;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	if(bIsBIGBuilding)
 | 
						if(bIsBIGBuilding)
 | 
				
			||||||
		if(m_level == LEVEL_NONE || m_level == CGame::currLevel)
 | 
							if(m_level == LEVEL_GENERIC || m_level == CGame::currLevel)
 | 
				
			||||||
			CStreaming::RequestModel(id, STREAMFLAGS_DONT_REMOVE);
 | 
								CStreaming::RequestModel(id, STREAMFLAGS_DONT_REMOVE);
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -359,8 +359,8 @@ CEntity::SetupBigBuilding(void)
 | 
				
			||||||
	if(mi->m_lodDistances[0] <= 2000.0f)
 | 
						if(mi->m_lodDistances[0] <= 2000.0f)
 | 
				
			||||||
		bStreamBIGBuilding = true;
 | 
							bStreamBIGBuilding = true;
 | 
				
			||||||
	if(mi->m_lodDistances[0] > 2500.0f || mi->m_ignoreDrawDist)
 | 
						if(mi->m_lodDistances[0] > 2500.0f || mi->m_ignoreDrawDist)
 | 
				
			||||||
		m_level = LEVEL_NONE;
 | 
							m_level = LEVEL_GENERIC;
 | 
				
			||||||
	else if(m_level == LEVEL_NONE)
 | 
						else if(m_level == LEVEL_GENERIC)
 | 
				
			||||||
		printf("%s isn't in a level\n", mi->GetName());
 | 
							printf("%s isn't in a level\n", mi->GetName());
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -75,7 +75,7 @@ CPhysical::CPhysical(void)
 | 
				
			||||||
#ifdef FIX_BUGS
 | 
					#ifdef FIX_BUGS
 | 
				
			||||||
	m_nSurfaceTouched = SURFACE_DEFAULT;
 | 
						m_nSurfaceTouched = SURFACE_DEFAULT;
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
	m_nZoneLevel = LEVEL_NONE;
 | 
						m_nZoneLevel = LEVEL_GENERIC;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	bIsFrozen = false;
 | 
						bIsFrozen = false;
 | 
				
			||||||
	bDontLoadCollision = false;
 | 
						bDontLoadCollision = false;
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -110,7 +110,7 @@ CPedModelInfo::CreateHitColModelSkinned(RpClump *clump)
 | 
				
			||||||
	max.x = max.y = 0.5f;
 | 
						max.x = max.y = 0.5f;
 | 
				
			||||||
	max.z = 1.2f;
 | 
						max.z = 1.2f;
 | 
				
			||||||
	colmodel->boundingBox.Set(min, max);
 | 
						colmodel->boundingBox.Set(min, max);
 | 
				
			||||||
	colmodel->level = LEVEL_NONE;
 | 
						colmodel->level = LEVEL_GENERIC;
 | 
				
			||||||
	m_hitColModel = colmodel;
 | 
						m_hitColModel = colmodel;
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -353,7 +353,7 @@ CPopulation::FindCollisionZoneForCoors(CVector *coors, int *safeZoneOut, eLevelN
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
	// Then it's transition area
 | 
						// Then it's transition area
 | 
				
			||||||
	if (*safeZoneOut >= 0)
 | 
						if (*safeZoneOut >= 0)
 | 
				
			||||||
		*levelOut = LEVEL_NONE;
 | 
							*levelOut = LEVEL_GENERIC;
 | 
				
			||||||
	else
 | 
						else
 | 
				
			||||||
		*levelOut = CTheZones::GetLevelFromPosition(coors);
 | 
							*levelOut = CTheZones::GetLevelFromPosition(coors);
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -3,6 +3,7 @@
 | 
				
			||||||
#include "Draw.h"
 | 
					#include "Draw.h"
 | 
				
			||||||
#include "Frontend.h"
 | 
					#include "Frontend.h"
 | 
				
			||||||
#include "Camera.h"
 | 
					#include "Camera.h"
 | 
				
			||||||
 | 
					#include "CutsceneMgr.h"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#ifdef ASPECT_RATIO_SCALE
 | 
					#ifdef ASPECT_RATIO_SCALE
 | 
				
			||||||
float CDraw::ms_fAspectRatio = DEFAULT_ASPECT_RATIO;
 | 
					float CDraw::ms_fAspectRatio = DEFAULT_ASPECT_RATIO;
 | 
				
			||||||
| 
						 | 
					@ -61,7 +62,10 @@ void
 | 
				
			||||||
CDraw::SetFOV(float fov)
 | 
					CDraw::SetFOV(float fov)
 | 
				
			||||||
{
 | 
					{
 | 
				
			||||||
#ifdef ASPECT_RATIO_SCALE
 | 
					#ifdef ASPECT_RATIO_SCALE
 | 
				
			||||||
 | 
						if (!CCutsceneMgr::IsRunning())
 | 
				
			||||||
		ms_fScaledFOV = ConvertFOV(fov);
 | 
							ms_fScaledFOV = ConvertFOV(fov);
 | 
				
			||||||
 | 
						else
 | 
				
			||||||
 | 
							ms_fScaledFOV = fov;
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
	ms_fFOV = fov;
 | 
						ms_fFOV = fov;
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -779,7 +779,7 @@ CRenderer::ScanWorld(void)
 | 
				
			||||||
			ScanSectorPoly(poly, 3, ScanSectorList);
 | 
								ScanSectorPoly(poly, 3, ScanSectorList);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
			ScanBigBuildingList(CWorld::GetBigBuildingList(CGame::currLevel));
 | 
								ScanBigBuildingList(CWorld::GetBigBuildingList(CGame::currLevel));
 | 
				
			||||||
			ScanBigBuildingList(CWorld::GetBigBuildingList(LEVEL_NONE));
 | 
								ScanBigBuildingList(CWorld::GetBigBuildingList(LEVEL_GENERIC));
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -497,7 +497,7 @@ CheckDataNotCorrupt(int32 slot, char *name)
 | 
				
			||||||
	char filename[100];
 | 
						char filename[100];
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	int32 blocknum = 0;
 | 
						int32 blocknum = 0;
 | 
				
			||||||
	eLevelName level = LEVEL_NONE;
 | 
						eLevelName level = LEVEL_GENERIC;
 | 
				
			||||||
	CheckSum = 0;
 | 
						CheckSum = 0;
 | 
				
			||||||
	uint32 bytes_processed = 0;
 | 
						uint32 bytes_processed = 0;
 | 
				
			||||||
	sprintf(filename, "%s%i%s", DefaultPCSaveFileName, slot + 1, ".b");
 | 
						sprintf(filename, "%s%i%s", DefaultPCSaveFileName, slot + 1, ".b");
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -1370,6 +1370,15 @@ WinMain(HINSTANCE instance,
 | 
				
			||||||
	RwInt32 argc;
 | 
						RwInt32 argc;
 | 
				
			||||||
	RwChar** argv;
 | 
						RwChar** argv;
 | 
				
			||||||
	SystemParametersInfo(SPI_SETFOREGROUNDLOCKTIMEOUT, 0, nil, SPIF_SENDCHANGE);
 | 
						SystemParametersInfo(SPI_SETFOREGROUNDLOCKTIMEOUT, 0, nil, SPIF_SENDCHANGE);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#if 0
 | 
				
			||||||
 | 
						// TODO: make this an option somewhere
 | 
				
			||||||
 | 
						AllocConsole();
 | 
				
			||||||
 | 
						freopen("CONIN$", "r", stdin);
 | 
				
			||||||
 | 
						freopen("CONOUT$", "w", stdout);
 | 
				
			||||||
 | 
						freopen("CONOUT$", "w", stderr);
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#else
 | 
					#else
 | 
				
			||||||
int
 | 
					int
 | 
				
			||||||
main(int argc, char *argv[])
 | 
					main(int argc, char *argv[])
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -83,7 +83,7 @@ CPlane::CPlane(int32 id, uint8 CreatedBy)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	SetStatus(STATUS_PLANE);
 | 
						SetStatus(STATUS_PLANE);
 | 
				
			||||||
	bIsBIGBuilding = true;
 | 
						bIsBIGBuilding = true;
 | 
				
			||||||
	m_level = LEVEL_NONE;
 | 
						m_level = LEVEL_GENERIC;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#ifdef FIX_BUGS
 | 
					#ifdef FIX_BUGS
 | 
				
			||||||
	m_isFarAway = true;
 | 
						m_isFarAway = true;
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
		Loading…
	
		Reference in a new issue