mirror of
https://github.com/GTAmodding/re3.git
synced 2025-01-18 01:56:36 +00:00
Script4.cpp
This commit is contained in:
parent
e6aa9f9d4e
commit
510ad223f0
2 changed files with 68 additions and 61 deletions
|
@ -443,6 +443,7 @@ public:
|
||||||
|
|
||||||
static int GetSaveVarIndex(int);
|
static int GetSaveVarIndex(int);
|
||||||
static void Shutdown(void);
|
static void Shutdown(void);
|
||||||
|
static void SwapNearestBuildingModel(float, float, float, float, int, int);
|
||||||
|
|
||||||
#ifdef GTA_SCRIPT_COLLECTIVE
|
#ifdef GTA_SCRIPT_COLLECTIVE
|
||||||
static void AdvanceCollectiveIndex()
|
static void AdvanceCollectiveIndex()
|
||||||
|
|
|
@ -248,13 +248,13 @@ int8 CRunningScript::ProcessCommands800To899(int32 command)
|
||||||
pPed->SetObjective(OBJECTIVE_CATCH_TRAIN);
|
pPed->SetObjective(OBJECTIVE_CATCH_TRAIN);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
*/
|
|
||||||
#ifdef GTA_SCRIPT_COLLECTIVE
|
#ifdef GTA_SCRIPT_COLLECTIVE
|
||||||
case COMMAND_SET_COLL_OBJ_CATCH_TRAIN:
|
case COMMAND_SET_COLL_OBJ_CATCH_TRAIN:
|
||||||
CollectParameters(&m_nIp, 1);
|
CollectParameters(&m_nIp, 1);
|
||||||
CTheScripts::SetObjectiveForAllPedsInCollective(GET_INTEGER_PARAM(0), OBJECTIVE_CATCH_TRAIN);
|
CTheScripts::SetObjectiveForAllPedsInCollective(GET_INTEGER_PARAM(0), OBJECTIVE_CATCH_TRAIN);
|
||||||
return 0;
|
return 0;
|
||||||
#endif
|
#endif
|
||||||
|
*/
|
||||||
case COMMAND_SET_PLAYER_NEVER_GETS_TIRED:
|
case COMMAND_SET_PLAYER_NEVER_GETS_TIRED:
|
||||||
{
|
{
|
||||||
CollectParameters(&m_nIp, 2);
|
CollectParameters(&m_nIp, 2);
|
||||||
|
@ -285,7 +285,7 @@ int8 CRunningScript::ProcessCommands800To899(int32 command)
|
||||||
script_assert(pVehicle);
|
script_assert(pVehicle);
|
||||||
// no action
|
// no action
|
||||||
return 0;
|
return 0;
|
||||||
}
|
*/
|
||||||
case COMMAND_SET_CAR_BIG_WHEELS:
|
case COMMAND_SET_CAR_BIG_WHEELS:
|
||||||
{
|
{
|
||||||
CollectParameters(&m_nIp, 2);
|
CollectParameters(&m_nIp, 2);
|
||||||
|
@ -296,7 +296,6 @@ int8 CRunningScript::ProcessCommands800To899(int32 command)
|
||||||
pCar->bBigWheels = (GET_INTEGER_PARAM(1) != 0);
|
pCar->bBigWheels = (GET_INTEGER_PARAM(1) != 0);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
*/
|
|
||||||
case COMMAND_SET_FREE_RESPRAYS:
|
case COMMAND_SET_FREE_RESPRAYS:
|
||||||
CollectParameters(&m_nIp, 1);
|
CollectParameters(&m_nIp, 1);
|
||||||
CGarages::SetFreeResprays(GET_INTEGER_PARAM(0) != 0);
|
CGarages::SetFreeResprays(GET_INTEGER_PARAM(0) != 0);
|
||||||
|
@ -317,7 +316,6 @@ int8 CRunningScript::ProcessCommands800To899(int32 command)
|
||||||
pPed->bIsVisible = (GET_INTEGER_PARAM(1) != 0);
|
pPed->bIsVisible = (GET_INTEGER_PARAM(1) != 0);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
/*
|
|
||||||
case COMMAND_SET_CAR_VISIBLE:
|
case COMMAND_SET_CAR_VISIBLE:
|
||||||
{
|
{
|
||||||
CollectParameters(&m_nIp, 2);
|
CollectParameters(&m_nIp, 2);
|
||||||
|
@ -326,7 +324,6 @@ int8 CRunningScript::ProcessCommands800To899(int32 command)
|
||||||
pVehicle->bIsVisible = (GET_INTEGER_PARAM(1) != 0);
|
pVehicle->bIsVisible = (GET_INTEGER_PARAM(1) != 0);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
*/
|
|
||||||
case COMMAND_IS_AREA_OCCUPIED:
|
case COMMAND_IS_AREA_OCCUPIED:
|
||||||
{
|
{
|
||||||
CollectParameters(&m_nIp, 11);
|
CollectParameters(&m_nIp, 11);
|
||||||
|
@ -457,25 +454,28 @@ int8 CRunningScript::ProcessCommands800To899(int32 command)
|
||||||
CTheScripts::IntroTextLines[CTheScripts::NumberOfIntroTextLinesThisFrame].m_nFont = GET_INTEGER_PARAM(0);
|
CTheScripts::IntroTextLines[CTheScripts::NumberOfIntroTextLinesThisFrame].m_nFont = GET_INTEGER_PARAM(0);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
*/
|
||||||
case COMMAND_INDUSTRIAL_PASSED:
|
case COMMAND_INDUSTRIAL_PASSED:
|
||||||
CStats::IndustrialPassed = true;
|
CollectParameters(&m_nIp, 1);
|
||||||
DMAudio.PlayRadioAnnouncement(STREAMED_SOUND_ANNOUNCE_COMMERCIAL_OPEN);
|
CStats::IndustrialPassed = GET_INTEGER_PARAM(0);
|
||||||
return 0;
|
return 0;
|
||||||
case COMMAND_COMMERCIAL_PASSED:
|
case COMMAND_COMMERCIAL_PASSED:
|
||||||
CStats::CommercialPassed = true;
|
CollectParameters(&m_nIp, 1);
|
||||||
DMAudio.PlayRadioAnnouncement(STREAMED_SOUND_ANNOUNCE_SUBURBAN_OPEN);
|
CStats::CommercialPassed = GET_INTEGER_PARAM(0);
|
||||||
return 0;
|
return 0;
|
||||||
case COMMAND_SUBURBAN_PASSED:
|
case COMMAND_SUBURBAN_PASSED:
|
||||||
CStats::SuburbanPassed = true;
|
CollectParameters(&m_nIp, 1);
|
||||||
|
CStats::SuburbanPassed = GET_INTEGER_PARAM(0);
|
||||||
return 0;
|
return 0;
|
||||||
*/
|
|
||||||
case COMMAND_ROTATE_OBJECT:
|
case COMMAND_ROTATE_OBJECT:
|
||||||
{
|
{
|
||||||
CollectParameters(&m_nIp, 4);
|
CollectParameters(&m_nIp, 4);
|
||||||
CObject* pObject = CPools::GetObjectPool()->GetAt(GET_INTEGER_PARAM(0));
|
CObject* pObject = CPools::GetObjectPool()->GetAt(GET_INTEGER_PARAM(0));
|
||||||
script_assert(pObject);
|
script_assert(pObject);
|
||||||
|
float fx = pObject->GetForward().x;
|
||||||
|
float fy = pObject->GetForward().y;
|
||||||
float heading = LimitAngleOnCircle(
|
float heading = LimitAngleOnCircle(
|
||||||
RADTODEG(Atan2(-pObject->GetForward().x, pObject->GetForward().y)));
|
RADTODEG(CGeneral::GetATanOfXY(pObject->GetForward().x, pObject->GetForward().y)));
|
||||||
float headingTarget = GET_FLOAT_PARAM(1);
|
float headingTarget = GET_FLOAT_PARAM(1);
|
||||||
#ifdef FIX_BUGS
|
#ifdef FIX_BUGS
|
||||||
float rotateBy = GET_FLOAT_PARAM(2) * CTimer::GetTimeStepFix();
|
float rotateBy = GET_FLOAT_PARAM(2) * CTimer::GetTimeStepFix();
|
||||||
|
@ -651,6 +651,7 @@ int8 CRunningScript::ProcessCommands800To899(int32 command)
|
||||||
case COMMAND_STOP_CHASE_SCENE:
|
case COMMAND_STOP_CHASE_SCENE:
|
||||||
CRecordDataForChase::CleanUpChaseScene();
|
CRecordDataForChase::CleanUpChaseScene();
|
||||||
return 0;
|
return 0;
|
||||||
|
*/
|
||||||
case COMMAND_IS_EXPLOSION_IN_AREA:
|
case COMMAND_IS_EXPLOSION_IN_AREA:
|
||||||
{
|
{
|
||||||
CollectParameters(&m_nIp, 7);
|
CollectParameters(&m_nIp, 7);
|
||||||
|
@ -676,6 +677,7 @@ int8 CRunningScript::ProcessCommands800To899(int32 command)
|
||||||
infX, supX, infY, supY, infZ, supZ));
|
infX, supX, infY, supY, infZ, supZ));
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
/*
|
||||||
case COMMAND_IS_EXPLOSION_IN_ZONE:
|
case COMMAND_IS_EXPLOSION_IN_ZONE:
|
||||||
{
|
{
|
||||||
CollectParameters(&m_nIp, 1);
|
CollectParameters(&m_nIp, 1);
|
||||||
|
@ -865,7 +867,6 @@ int8 CRunningScript::ProcessCommands800To899(int32 command)
|
||||||
}
|
}
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
/*
|
|
||||||
case COMMAND_HAS_CHAR_SPOTTED_CHAR:
|
case COMMAND_HAS_CHAR_SPOTTED_CHAR:
|
||||||
{
|
{
|
||||||
CollectParameters(&m_nIp, 2);
|
CollectParameters(&m_nIp, 2);
|
||||||
|
@ -876,7 +877,6 @@ int8 CRunningScript::ProcessCommands800To899(int32 command)
|
||||||
UpdateCompareFlag(pPed->OurPedCanSeeThisOne(pTarget));
|
UpdateCompareFlag(pPed->OurPedCanSeeThisOne(pTarget));
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
*/
|
|
||||||
case COMMAND_SET_CHAR_OBJ_HAIL_TAXI:
|
case COMMAND_SET_CHAR_OBJ_HAIL_TAXI:
|
||||||
{
|
{
|
||||||
CollectParameters(&m_nIp, 1);
|
CollectParameters(&m_nIp, 1);
|
||||||
|
@ -894,7 +894,6 @@ int8 CRunningScript::ProcessCommands800To899(int32 command)
|
||||||
UpdateCompareFlag(pObject->bRenderDamaged || !pObject->bIsVisible);
|
UpdateCompareFlag(pObject->bRenderDamaged || !pObject->bIsVisible);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
/*
|
|
||||||
case COMMAND_START_KILL_FRENZY_HEADSHOT:
|
case COMMAND_START_KILL_FRENZY_HEADSHOT:
|
||||||
{
|
{
|
||||||
wchar* text = CTheScripts::GetTextByKeyFromScript(&m_nIp);
|
wchar* text = CTheScripts::GetTextByKeyFromScript(&m_nIp);
|
||||||
|
@ -925,7 +924,6 @@ int8 CRunningScript::ProcessCommands800To899(int32 command)
|
||||||
GET_FLOAT_PARAM(0), GET_FLOAT_PARAM(1));
|
GET_FLOAT_PARAM(0), GET_FLOAT_PARAM(1));
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
*/
|
|
||||||
case COMMAND_WARP_PLAYER_INTO_CAR:
|
case COMMAND_WARP_PLAYER_INTO_CAR:
|
||||||
{
|
{
|
||||||
CollectParameters(&m_nIp, 2);
|
CollectParameters(&m_nIp, 2);
|
||||||
|
@ -946,6 +944,7 @@ int8 CRunningScript::ProcessCommands800To899(int32 command)
|
||||||
script_assert(pVehicle);
|
script_assert(pVehicle);
|
||||||
pPed->SetObjective(OBJECTIVE_ENTER_CAR_AS_DRIVER, pVehicle);
|
pPed->SetObjective(OBJECTIVE_ENTER_CAR_AS_DRIVER, pVehicle);
|
||||||
pPed->WarpPedIntoCar(pVehicle);
|
pPed->WarpPedIntoCar(pVehicle);
|
||||||
|
pPed->RestorePreviousObjective();
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
case COMMAND_SWITCH_CAR_RADIO:
|
case COMMAND_SWITCH_CAR_RADIO:
|
||||||
|
@ -960,7 +959,6 @@ int8 CRunningScript::ProcessCommands800To899(int32 command)
|
||||||
CMessages::AddBigMessageWithNumber(text, GET_INTEGER_PARAM(2), GET_INTEGER_PARAM(3) - 1, GET_INTEGER_PARAM(0), GET_INTEGER_PARAM(1), -1, -1, -1, -1);
|
CMessages::AddBigMessageWithNumber(text, GET_INTEGER_PARAM(2), GET_INTEGER_PARAM(3) - 1, GET_INTEGER_PARAM(0), GET_INTEGER_PARAM(1), -1, -1, -1, -1);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
/*
|
|
||||||
case COMMAND_PRINT_WITH_3_NUMBERS_BIG:
|
case COMMAND_PRINT_WITH_3_NUMBERS_BIG:
|
||||||
{
|
{
|
||||||
wchar* text = CTheScripts::GetTextByKeyFromScript(&m_nIp);
|
wchar* text = CTheScripts::GetTextByKeyFromScript(&m_nIp);
|
||||||
|
@ -968,6 +966,7 @@ int8 CRunningScript::ProcessCommands800To899(int32 command)
|
||||||
CMessages::AddBigMessageWithNumber(text, GET_INTEGER_PARAM(3), GET_INTEGER_PARAM(4) - 1, GET_INTEGER_PARAM(0), GET_INTEGER_PARAM(1), GET_INTEGER_PARAM(2), -1, -1, -1);
|
CMessages::AddBigMessageWithNumber(text, GET_INTEGER_PARAM(3), GET_INTEGER_PARAM(4) - 1, GET_INTEGER_PARAM(0), GET_INTEGER_PARAM(1), GET_INTEGER_PARAM(2), -1, -1, -1);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
/*
|
||||||
case COMMAND_PRINT_WITH_4_NUMBERS_BIG:
|
case COMMAND_PRINT_WITH_4_NUMBERS_BIG:
|
||||||
{
|
{
|
||||||
wchar* text = CTheScripts::GetTextByKeyFromScript(&m_nIp);
|
wchar* text = CTheScripts::GetTextByKeyFromScript(&m_nIp);
|
||||||
|
@ -1149,13 +1148,13 @@ int8 CRunningScript::ProcessCommands800To899(int32 command)
|
||||||
case COMMAND_GIVE_PLAYER_DETONATOR:
|
case COMMAND_GIVE_PLAYER_DETONATOR:
|
||||||
CGarages::GivePlayerDetonator();
|
CGarages::GivePlayerDetonator();
|
||||||
return 0;
|
return 0;
|
||||||
*/
|
|
||||||
#ifdef GTA_SCRIPT_COLLECTIVE
|
#ifdef GTA_SCRIPT_COLLECTIVE
|
||||||
case COMMAND_SET_COLL_OBJ_STEAL_ANY_CAR:
|
case COMMAND_SET_COLL_OBJ_STEAL_ANY_CAR:
|
||||||
CollectParameters(&m_nIp, 1);
|
CollectParameters(&m_nIp, 1);
|
||||||
CTheScripts::SetObjectiveForAllPedsInCollective(GET_INTEGER_PARAM(0), OBJECTIVE_STEAL_ANY_CAR);
|
CTheScripts::SetObjectiveForAllPedsInCollective(GET_INTEGER_PARAM(0), OBJECTIVE_STEAL_ANY_CAR);
|
||||||
return 0;
|
return 0;
|
||||||
#endif
|
#endif
|
||||||
|
*/
|
||||||
case COMMAND_SET_OBJECT_VELOCITY:
|
case COMMAND_SET_OBJECT_VELOCITY:
|
||||||
{
|
{
|
||||||
CollectParameters(&m_nIp, 4);
|
CollectParameters(&m_nIp, 4);
|
||||||
|
@ -1302,6 +1301,7 @@ int8 CRunningScript::ProcessCommands900To999(int32 command)
|
||||||
pObject->AddToMoveSpeed(GET_VECTOR_PARAM(1) * METERS_PER_SECOND_TO_GAME_SPEED);
|
pObject->AddToMoveSpeed(GET_VECTOR_PARAM(1) * METERS_PER_SECOND_TO_GAME_SPEED);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
/*
|
||||||
case COMMAND_DRAW_SPRITE:
|
case COMMAND_DRAW_SPRITE:
|
||||||
{
|
{
|
||||||
CollectParameters(&m_nIp, 9);
|
CollectParameters(&m_nIp, 9);
|
||||||
|
@ -1351,7 +1351,6 @@ int8 CRunningScript::ProcessCommands900To999(int32 command)
|
||||||
CTxdStore::AddRef(slot);
|
CTxdStore::AddRef(slot);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
/*
|
|
||||||
case COMMAND_REMOVE_TEXTURE_DICTIONARY:
|
case COMMAND_REMOVE_TEXTURE_DICTIONARY:
|
||||||
{
|
{
|
||||||
CTheScripts::RemoveScriptTextureDictionary();
|
CTheScripts::RemoveScriptTextureDictionary();
|
||||||
|
@ -1394,6 +1393,7 @@ int8 CRunningScript::ProcessCommands900To999(int32 command)
|
||||||
CollectParameters(&m_nIp, 1);
|
CollectParameters(&m_nIp, 1);
|
||||||
DMAudio.ChangeMusicMode(MUSICMODE_FRONTEND);
|
DMAudio.ChangeMusicMode(MUSICMODE_FRONTEND);
|
||||||
DMAudio.PlayFrontEndTrack(GET_INTEGER_PARAM(0) + STREAMED_SOUND_MISSION_COMPLETED - 1, 0);
|
DMAudio.PlayFrontEndTrack(GET_INTEGER_PARAM(0) + STREAMED_SOUND_MISSION_COMPLETED - 1, 0);
|
||||||
|
//DMAudio.SaveAnnouncementsWhenMissionPassedPlayed(); // TODO!
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
case COMMAND_CLEAR_AREA:
|
case COMMAND_CLEAR_AREA:
|
||||||
|
@ -1417,6 +1417,7 @@ int8 CRunningScript::ProcessCommands900To999(int32 command)
|
||||||
pVehicle->m_bSirenOrAlarm = GET_INTEGER_PARAM(1) != 0;
|
pVehicle->m_bSirenOrAlarm = GET_INTEGER_PARAM(1) != 0;
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
/*
|
||||||
case COMMAND_SWITCH_PED_ROADS_ON_ANGLED:
|
case COMMAND_SWITCH_PED_ROADS_ON_ANGLED:
|
||||||
{
|
{
|
||||||
CollectParameters(&m_nIp, 7);
|
CollectParameters(&m_nIp, 7);
|
||||||
|
@ -1424,11 +1425,13 @@ int8 CRunningScript::ProcessCommands900To999(int32 command)
|
||||||
GET_FLOAT_PARAM(3), GET_FLOAT_PARAM(4), GET_FLOAT_PARAM(5), GET_FLOAT_PARAM(6), 0, 1);
|
GET_FLOAT_PARAM(3), GET_FLOAT_PARAM(4), GET_FLOAT_PARAM(5), GET_FLOAT_PARAM(6), 0, 1);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
*/
|
||||||
case COMMAND_SWITCH_PED_ROADS_OFF_ANGLED:
|
case COMMAND_SWITCH_PED_ROADS_OFF_ANGLED:
|
||||||
CollectParameters(&m_nIp, 7);
|
CollectParameters(&m_nIp, 7);
|
||||||
ThePaths.SwitchRoadsInAngledArea(GET_FLOAT_PARAM(0), GET_FLOAT_PARAM(1), GET_FLOAT_PARAM(2),
|
ThePaths.SwitchRoadsInAngledArea(GET_FLOAT_PARAM(0), GET_FLOAT_PARAM(1), GET_FLOAT_PARAM(2),
|
||||||
GET_FLOAT_PARAM(3), GET_FLOAT_PARAM(4), GET_FLOAT_PARAM(5), GET_FLOAT_PARAM(6), 0, 0);
|
GET_FLOAT_PARAM(3), GET_FLOAT_PARAM(4), GET_FLOAT_PARAM(5), GET_FLOAT_PARAM(6), 0, 0);
|
||||||
return 0;
|
return 0;
|
||||||
|
/*
|
||||||
case COMMAND_SWITCH_ROADS_ON_ANGLED:
|
case COMMAND_SWITCH_ROADS_ON_ANGLED:
|
||||||
CollectParameters(&m_nIp, 7);
|
CollectParameters(&m_nIp, 7);
|
||||||
ThePaths.SwitchRoadsInAngledArea(GET_FLOAT_PARAM(0), GET_FLOAT_PARAM(1), GET_FLOAT_PARAM(2),
|
ThePaths.SwitchRoadsInAngledArea(GET_FLOAT_PARAM(0), GET_FLOAT_PARAM(1), GET_FLOAT_PARAM(2),
|
||||||
|
@ -1439,6 +1442,7 @@ int8 CRunningScript::ProcessCommands900To999(int32 command)
|
||||||
ThePaths.SwitchRoadsInAngledArea(GET_FLOAT_PARAM(0), GET_FLOAT_PARAM(1), GET_FLOAT_PARAM(2),
|
ThePaths.SwitchRoadsInAngledArea(GET_FLOAT_PARAM(0), GET_FLOAT_PARAM(1), GET_FLOAT_PARAM(2),
|
||||||
GET_FLOAT_PARAM(3), GET_FLOAT_PARAM(4), GET_FLOAT_PARAM(5), GET_FLOAT_PARAM(6), 1, 0);
|
GET_FLOAT_PARAM(3), GET_FLOAT_PARAM(4), GET_FLOAT_PARAM(5), GET_FLOAT_PARAM(6), 1, 0);
|
||||||
return 0;
|
return 0;
|
||||||
|
*/
|
||||||
case COMMAND_SET_CAR_WATERTIGHT:
|
case COMMAND_SET_CAR_WATERTIGHT:
|
||||||
{
|
{
|
||||||
CollectParameters(&m_nIp, 2);
|
CollectParameters(&m_nIp, 2);
|
||||||
|
@ -1463,7 +1467,7 @@ int8 CRunningScript::ProcessCommands900To999(int32 command)
|
||||||
float size = Max(0.0f, GET_FLOAT_PARAM(7));
|
float size = Max(0.0f, GET_FLOAT_PARAM(7));
|
||||||
eParticleObjectType type = (eParticleObjectType)GET_INTEGER_PARAM(0);
|
eParticleObjectType type = (eParticleObjectType)GET_INTEGER_PARAM(0);
|
||||||
RwRGBA color;
|
RwRGBA color;
|
||||||
if (type == POBJECT_SMOKE_TRAIL){
|
if (type == POBJECT_SMOKE_TRAIL){ // 17 in LCS -- assuming enum is the same
|
||||||
color.alpha = -1;
|
color.alpha = -1;
|
||||||
color.red = GET_INTEGER_PARAM(8);
|
color.red = GET_INTEGER_PARAM(8);
|
||||||
color.green = GET_INTEGER_PARAM(9);
|
color.green = GET_INTEGER_PARAM(9);
|
||||||
|
@ -1495,7 +1499,6 @@ int8 CRunningScript::ProcessCommands900To999(int32 command)
|
||||||
pVehicle->SetHeading(heading);
|
pVehicle->SetHeading(heading);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
/*
|
|
||||||
case COMMAND_IS_CRANE_LIFTING_CAR:
|
case COMMAND_IS_CRANE_LIFTING_CAR:
|
||||||
{
|
{
|
||||||
CollectParameters(&m_nIp, 3);
|
CollectParameters(&m_nIp, 3);
|
||||||
|
@ -1503,7 +1506,6 @@ int8 CRunningScript::ProcessCommands900To999(int32 command)
|
||||||
UpdateCompareFlag(CCranes::IsThisCarPickedUp(GET_FLOAT_PARAM(0), GET_FLOAT_PARAM(1), pVehicle));
|
UpdateCompareFlag(CCranes::IsThisCarPickedUp(GET_FLOAT_PARAM(0), GET_FLOAT_PARAM(1), pVehicle));
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
*/
|
|
||||||
case COMMAND_DRAW_SPHERE:
|
case COMMAND_DRAW_SPHERE:
|
||||||
{
|
{
|
||||||
CollectParameters(&m_nIp, 4);
|
CollectParameters(&m_nIp, 4);
|
||||||
|
@ -1635,35 +1637,7 @@ int8 CRunningScript::ProcessCommands900To999(int32 command)
|
||||||
case COMMAND_SWAP_NEAREST_BUILDING_MODEL:
|
case COMMAND_SWAP_NEAREST_BUILDING_MODEL:
|
||||||
{
|
{
|
||||||
CollectParameters(&m_nIp, 6);
|
CollectParameters(&m_nIp, 6);
|
||||||
CVector pos = GET_VECTOR_PARAM(0);
|
CTheScripts::SwapNearestBuildingModel(GET_FLOAT_PARAM(0), GET_FLOAT_PARAM(1), GET_FLOAT_PARAM(2), GET_FLOAT_PARAM(3), GET_INTEGER_PARAM(4), GET_INTEGER_PARAM(5));
|
||||||
if (pos.z <= MAP_Z_LOW_LIMIT)
|
|
||||||
pos.z = CWorld::FindGroundZForCoord(pos.x, pos.y);
|
|
||||||
float radius = GET_FLOAT_PARAM(3);
|
|
||||||
int mi1 = GET_INTEGER_PARAM(4) >= 0 ? GET_INTEGER_PARAM(4) : CTheScripts::UsedObjectArray[-GET_INTEGER_PARAM(4)].index;
|
|
||||||
int mi2 = GET_INTEGER_PARAM(5) >= 0 ? GET_INTEGER_PARAM(5) : CTheScripts::UsedObjectArray[-GET_INTEGER_PARAM(5)].index;
|
|
||||||
int16 total;
|
|
||||||
CEntity* apEntities[16];
|
|
||||||
CWorld::FindObjectsOfTypeInRange(mi1, pos, radius, true, &total, 16, apEntities, true, false, false, false, false);
|
|
||||||
if (total == 0)
|
|
||||||
CWorld::FindObjectsOfTypeInRangeSectorList(mi1, CWorld::GetBigBuildingList(LEVEL_GENERIC), pos, radius, true, &total, 16, apEntities);
|
|
||||||
if (total == 0)
|
|
||||||
CWorld::FindObjectsOfTypeInRangeSectorList(mi1, CWorld::GetBigBuildingList(CTheZones::GetLevelFromPosition(&pos)), pos, radius, true, &total, 16, apEntities);
|
|
||||||
CEntity* pClosestEntity = nil;
|
|
||||||
float min_dist = 2.0f * radius;
|
|
||||||
for (int i = 0; i < total; i++) {
|
|
||||||
float dist = (apEntities[i]->GetPosition() - pos).Magnitude();
|
|
||||||
if (dist < min_dist) {
|
|
||||||
min_dist = dist;
|
|
||||||
pClosestEntity = apEntities[i];
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if (!pClosestEntity) {
|
|
||||||
printf("Failed to find building\n");
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
CBuilding* pReplacedBuilding = ((CBuilding*)pClosestEntity);
|
|
||||||
pReplacedBuilding->ReplaceWithNewModel(mi2);
|
|
||||||
CTheScripts::AddToBuildingSwapArray(pReplacedBuilding, mi1, mi2);
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
case COMMAND_SWITCH_WORLD_PROCESSING:
|
case COMMAND_SWITCH_WORLD_PROCESSING:
|
||||||
|
@ -1778,8 +1752,7 @@ int8 CRunningScript::ProcessCommands900To999(int32 command)
|
||||||
*/
|
*/
|
||||||
case COMMAND_DISPLAY_ONSCREEN_TIMER_WITH_STRING:
|
case COMMAND_DISPLAY_ONSCREEN_TIMER_WITH_STRING:
|
||||||
{
|
{
|
||||||
//script_assert(CTheScripts::ScriptSpace[m_nIp++] == ARGUMENT_GLOBALVAR);
|
uint16 var = GetPointerToScriptVariable(&m_nIp, VAR_GLOBAL) - (int32*)CTheScripts::ScriptSpace;
|
||||||
uint16 var = CTheScripts::Read2BytesFromScript(&m_nIp);
|
|
||||||
CollectParameters(&m_nIp, 1);
|
CollectParameters(&m_nIp, 1);
|
||||||
wchar* text = TheText.Get((char*)&CTheScripts::ScriptSpace[m_nIp]); // ???
|
wchar* text = TheText.Get((char*)&CTheScripts::ScriptSpace[m_nIp]); // ???
|
||||||
strncpy(onscreen_str, (char*)&CTheScripts::ScriptSpace[m_nIp], KEY_LENGTH_IN_SCRIPT);
|
strncpy(onscreen_str, (char*)&CTheScripts::ScriptSpace[m_nIp], KEY_LENGTH_IN_SCRIPT);
|
||||||
|
@ -1789,8 +1762,7 @@ int8 CRunningScript::ProcessCommands900To999(int32 command)
|
||||||
}
|
}
|
||||||
case COMMAND_DISPLAY_ONSCREEN_COUNTER_WITH_STRING:
|
case COMMAND_DISPLAY_ONSCREEN_COUNTER_WITH_STRING:
|
||||||
{
|
{
|
||||||
//script_assert(CTheScripts::ScriptSpace[m_nIp++] == ARGUMENT_GLOBALVAR);
|
uint16 var = GetPointerToScriptVariable(&m_nIp, VAR_GLOBAL) - (int32*)CTheScripts::ScriptSpace;
|
||||||
uint16 var = CTheScripts::Read2BytesFromScript(&m_nIp);
|
|
||||||
CollectParameters(&m_nIp, 1);
|
CollectParameters(&m_nIp, 1);
|
||||||
wchar* text = TheText.Get((char*)&CTheScripts::ScriptSpace[m_nIp]); // ???
|
wchar* text = TheText.Get((char*)&CTheScripts::ScriptSpace[m_nIp]); // ???
|
||||||
strncpy(onscreen_str, (char*)&CTheScripts::ScriptSpace[m_nIp], KEY_LENGTH_IN_SCRIPT);
|
strncpy(onscreen_str, (char*)&CTheScripts::ScriptSpace[m_nIp], KEY_LENGTH_IN_SCRIPT);
|
||||||
|
@ -1805,8 +1777,8 @@ int8 CRunningScript::ProcessCommands900To999(int32 command)
|
||||||
return 0;
|
return 0;
|
||||||
int attempts;
|
int attempts;
|
||||||
int model = -1;
|
int model = -1;
|
||||||
int index = CGeneral::GetRandomNumberInRange(0, 50);
|
int index = CGeneral::GetRandomNumberInRange(0, MAXVEHICLESLOADED);
|
||||||
for (attempts = 0; attempts < 50; attempts++) {
|
for (attempts = 0; attempts < MAXVEHICLESLOADED; attempts++) {
|
||||||
if (model != -1)
|
if (model != -1)
|
||||||
break;
|
break;
|
||||||
model = CStreaming::ms_vehiclesLoaded[index];
|
model = CStreaming::ms_vehiclesLoaded[index];
|
||||||
|
@ -1815,6 +1787,7 @@ int8 CRunningScript::ProcessCommands900To999(int32 command)
|
||||||
if (CModelInfo::IsCarModel(model) || CModelInfo::IsBikeModel(model)) {
|
if (CModelInfo::IsCarModel(model) || CModelInfo::IsBikeModel(model)) {
|
||||||
switch (model) {
|
switch (model) {
|
||||||
// TODO(LCS): do it right
|
// TODO(LCS): do it right
|
||||||
|
// apparently leeds didn't :lmao:
|
||||||
case MI_LANDSTAL:
|
case MI_LANDSTAL:
|
||||||
case MI_LINERUN:
|
case MI_LINERUN:
|
||||||
case MI_RIO:
|
case MI_RIO:
|
||||||
|
@ -1910,7 +1883,7 @@ int8 CRunningScript::ProcessCommands900To999(int32 command)
|
||||||
//case MI_WASHING:
|
//case MI_WASHING:
|
||||||
case MI_BOBCAT:
|
case MI_BOBCAT:
|
||||||
case MI_BANSHEE:
|
case MI_BANSHEE:
|
||||||
case MI_CABBIE:
|
//case MI_CABBIE:
|
||||||
case MI_STALLION:
|
case MI_STALLION:
|
||||||
case MI_RUMPO:
|
case MI_RUMPO:
|
||||||
//case MI_ADMIRAL:
|
//case MI_ADMIRAL:
|
||||||
|
@ -1966,7 +1939,7 @@ int8 CRunningScript::ProcessCommands900To999(int32 command)
|
||||||
}
|
}
|
||||||
case COMMAND_IS_COLLISION_IN_MEMORY:
|
case COMMAND_IS_COLLISION_IN_MEMORY:
|
||||||
CollectParameters(&m_nIp, 1);
|
CollectParameters(&m_nIp, 1);
|
||||||
UpdateCompareFlag(CCollision::ms_collisionInMemory == GET_INTEGER_PARAM(0));
|
UpdateCompareFlag(CGame::currLevel == GET_INTEGER_PARAM(0));
|
||||||
return 0;
|
return 0;
|
||||||
case COMMAND_SET_WANTED_MULTIPLIER:
|
case COMMAND_SET_WANTED_MULTIPLIER:
|
||||||
CollectParameters(&m_nIp, 1);
|
CollectParameters(&m_nIp, 1);
|
||||||
|
@ -1975,7 +1948,6 @@ int8 CRunningScript::ProcessCommands900To999(int32 command)
|
||||||
case COMMAND_SET_CAMERA_IN_FRONT_OF_PLAYER:
|
case COMMAND_SET_CAMERA_IN_FRONT_OF_PLAYER:
|
||||||
TheCamera.SetCameraDirectlyInFrontForFollowPed_CamOnAString();
|
TheCamera.SetCameraDirectlyInFrontForFollowPed_CamOnAString();
|
||||||
return 0;
|
return 0;
|
||||||
/*
|
|
||||||
case COMMAND_IS_CAR_VISIBLY_DAMAGED:
|
case COMMAND_IS_CAR_VISIBLY_DAMAGED:
|
||||||
{
|
{
|
||||||
CollectParameters(&m_nIp, 1);
|
CollectParameters(&m_nIp, 1);
|
||||||
|
@ -1984,7 +1956,6 @@ int8 CRunningScript::ProcessCommands900To999(int32 command)
|
||||||
UpdateCompareFlag(pVehicle->bIsDamaged);
|
UpdateCompareFlag(pVehicle->bIsDamaged);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
*/
|
|
||||||
case COMMAND_DOES_OBJECT_EXIST:
|
case COMMAND_DOES_OBJECT_EXIST:
|
||||||
CollectParameters(&m_nIp, 1);
|
CollectParameters(&m_nIp, 1);
|
||||||
UpdateCompareFlag(CPools::GetObjectPool()->GetAt(GET_INTEGER_PARAM(0)));
|
UpdateCompareFlag(CPools::GetObjectPool()->GetAt(GET_INTEGER_PARAM(0)));
|
||||||
|
@ -2166,16 +2137,19 @@ int8 CRunningScript::ProcessCommands900To999(int32 command)
|
||||||
pPed->SetObjective(OBJECTIVE_LEAVE_CAR, pPed->m_pMyVehicle);
|
pPed->SetObjective(OBJECTIVE_LEAVE_CAR, pPed->m_pMyVehicle);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
/*
|
||||||
case COMMAND_SET_SPRITES_DRAW_BEFORE_FADE:
|
case COMMAND_SET_SPRITES_DRAW_BEFORE_FADE:
|
||||||
CollectParameters(&m_nIp, 1);
|
CollectParameters(&m_nIp, 1);
|
||||||
CTheScripts::IntroRectangles[CTheScripts::NumberOfIntroRectanglesThisFrame].m_bBeforeFade = GET_INTEGER_PARAM(0) != 0;
|
CTheScripts::IntroRectangles[CTheScripts::NumberOfIntroRectanglesThisFrame].m_bBeforeFade = GET_INTEGER_PARAM(0) != 0;
|
||||||
return 0;
|
return 0;
|
||||||
|
*/
|
||||||
case COMMAND_SET_TEXT_RIGHT_JUSTIFY:
|
case COMMAND_SET_TEXT_RIGHT_JUSTIFY:
|
||||||
CollectParameters(&m_nIp, 1);
|
CollectParameters(&m_nIp, 1);
|
||||||
CTheScripts::IntroTextLines[CTheScripts::NumberOfIntroTextLinesThisFrame].m_bRightJustify = GET_INTEGER_PARAM(0) != 0;
|
CTheScripts::IntroTextLines[CTheScripts::NumberOfIntroTextLinesThisFrame].m_bRightJustify = GET_INTEGER_PARAM(0) != 0;
|
||||||
return 0;
|
return 0;
|
||||||
case COMMAND_PRINT_HELP:
|
case COMMAND_PRINT_HELP:
|
||||||
{
|
{
|
||||||
|
/* maybe will be useful? TODO
|
||||||
if (CCamera::m_bUseMouse3rdPerson && (
|
if (CCamera::m_bUseMouse3rdPerson && (
|
||||||
strcmp((char*)&CTheScripts::ScriptSpace[m_nIp], "HELP15") == 0 ||
|
strcmp((char*)&CTheScripts::ScriptSpace[m_nIp], "HELP15") == 0 ||
|
||||||
strcmp((char*)&CTheScripts::ScriptSpace[m_nIp], "GUN_2A") == 0 ||
|
strcmp((char*)&CTheScripts::ScriptSpace[m_nIp], "GUN_2A") == 0 ||
|
||||||
|
@ -2184,11 +2158,13 @@ int8 CRunningScript::ProcessCommands900To999(int32 command)
|
||||||
m_nIp += KEY_LENGTH_IN_SCRIPT;
|
m_nIp += KEY_LENGTH_IN_SCRIPT;
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
*/
|
||||||
wchar* text = CTheScripts::GetTextByKeyFromScript(&m_nIp);
|
wchar* text = CTheScripts::GetTextByKeyFromScript(&m_nIp);
|
||||||
CHud::SetHelpMessage(text, false);
|
CHud::SetHelpMessage(text, false);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
case COMMAND_CLEAR_HELP:
|
case COMMAND_CLEAR_HELP:
|
||||||
|
//CHud::gLastPrintForeverString = false; TODO
|
||||||
CHud::SetHelpMessage(nil, false);
|
CHud::SetHelpMessage(nil, false);
|
||||||
return 0;
|
return 0;
|
||||||
case COMMAND_FLASH_HUD_OBJECT:
|
case COMMAND_FLASH_HUD_OBJECT:
|
||||||
|
@ -2258,6 +2234,36 @@ void CTheScripts::RemoveScriptSphere(int32 index)
|
||||||
ScriptSphereArray[index].m_Id = 0;
|
ScriptSphereArray[index].m_Id = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void CTheScripts::SwapNearestBuildingModel(float x, float y, float z, float radius, int mi1, int mi2)
|
||||||
|
{
|
||||||
|
CVector pos(x, y, z);
|
||||||
|
if (pos.z <= MAP_Z_LOW_LIMIT)
|
||||||
|
pos.z = CWorld::FindGroundZForCoord(pos.x, pos.y);
|
||||||
|
if (mi1 < 0)
|
||||||
|
mi1 = CTheScripts::UsedObjectArray[-mi1].index;
|
||||||
|
if (mi2 < 0)
|
||||||
|
mi2 = CTheScripts::UsedObjectArray[-mi2].index;
|
||||||
|
int16 total;
|
||||||
|
CEntity* apEntities[16];
|
||||||
|
CWorld::FindObjectsOfTypeInRange(mi1, pos, radius, true, &total, 16, apEntities, true, false, false, false, false);
|
||||||
|
if (total == 0)
|
||||||
|
CWorld::FindObjectsOfTypeInRangeSectorList(mi1, CWorld::GetBigBuildingList(LEVEL_GENERIC), pos, radius, true, &total, 16, apEntities);
|
||||||
|
if (total == 0)
|
||||||
|
CWorld::FindObjectsOfTypeInRangeSectorList(mi1, CWorld::GetBigBuildingList(CTheZones::GetLevelFromPosition(&pos)), pos, radius, true, &total, 16, apEntities);
|
||||||
|
CEntity* pClosestEntity = nil;
|
||||||
|
float min_dist = 2.0f * radius;
|
||||||
|
for (int i = 0; i < total; i++) {
|
||||||
|
float dist = (apEntities[i]->GetPosition() - pos).Magnitude();
|
||||||
|
if (dist < min_dist) {
|
||||||
|
min_dist = dist;
|
||||||
|
pClosestEntity = apEntities[i];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
CBuilding* pReplacedBuilding = ((CBuilding*)pClosestEntity);
|
||||||
|
pReplacedBuilding->ReplaceWithNewModel(mi2);
|
||||||
|
AddToBuildingSwapArray(pReplacedBuilding, mi1, mi2);
|
||||||
|
}
|
||||||
|
|
||||||
void CTheScripts::AddToBuildingSwapArray(CBuilding* pBuilding, int32 old_model, int32 new_model)
|
void CTheScripts::AddToBuildingSwapArray(CBuilding* pBuilding, int32 old_model, int32 new_model)
|
||||||
{
|
{
|
||||||
int i = 0;
|
int i = 0;
|
||||||
|
|
Loading…
Reference in a new issue