1
0
mirror of https://github.com/citizenfx/cfx-server-data.git synced 2025-01-24 18:23:21 +08:00

spawnmanager: fix spawning when faded out, add skipFade option, add timeout for collision loading

This commit is contained in:
iridium 2019-06-05 15:11:20 +02:00
parent 23a840f780
commit 64a26ad1de

View File

@ -208,12 +208,6 @@ function spawnPlayer(spawnIdx, cb)
spawnLock = true spawnLock = true
Citizen.CreateThread(function() Citizen.CreateThread(function()
DoScreenFadeOut(500)
while IsScreenFadingOut() do
Citizen.Wait(0)
end
-- if the spawn isn't set, select a random one -- if the spawn isn't set, select a random one
if not spawnIdx then if not spawnIdx then
spawnIdx = GetRandomIntInRange(1, #spawnPoints + 1) spawnIdx = GetRandomIntInRange(1, #spawnPoints + 1)
@ -228,6 +222,14 @@ function spawnPlayer(spawnIdx, cb)
spawn = spawnPoints[spawnIdx] spawn = spawnPoints[spawnIdx]
end end
if not spawn.skipFade then
DoScreenFadeOut(500)
while not IsScreenFadedOut() do
Citizen.Wait(0)
end
end
-- validate the index -- validate the index
if not spawn then if not spawn then
Citizen.Trace("tried to spawn at an invalid spawn index\n") Citizen.Trace("tried to spawn at an invalid spawn index\n")
@ -288,16 +290,20 @@ function spawnPlayer(spawnIdx, cb)
--loadScene(spawn.x, spawn.y, spawn.z) --loadScene(spawn.x, spawn.y, spawn.z)
--ForceLoadingScreen(false) --ForceLoadingScreen(false)
while not HasCollisionLoadedAroundEntity(ped) do local time = GetGameTimer()
while (not HasCollisionLoadedAroundEntity(ped) and (GetGameTimer() - time) < 5000) do
Citizen.Wait(0) Citizen.Wait(0)
end end
ShutdownLoadingScreen() ShutdownLoadingScreen()
DoScreenFadeIn(500) if IsScreenFadedOut() then
DoScreenFadeIn(500)
while IsScreenFadingIn() do while not IsScreenFadedIn() do
Citizen.Wait(0) Citizen.Wait(0)
end
end end
-- and unfreeze the player -- and unfreeze the player