Synced weather and time for QB-Core Framework 🌅
- Syncs the weather for all players
- Download the script and put it in the
[qr]
directory. - Add the following code to your server.cfg/resouces.cfg
ensure qr-core
ensure qr-weathersync
You can adjust available weather and defaults in config.lua
to adjust weather patterns you need to modify nextWeatherStage() in server/server.lua
/freezetime
- Toggle time progression
/freezeweather
- Toggle dynamic weather
/weather [type]
- Set weather
/blackout
- Toggle blackout
/morning
- Set time to 9am
/noon
- Set time to 12pm
/evening
- Set time to 6pm
/night
- Set time to 11pm
/time [hour] (minute)
- Set time to whatever you want
Triggers event to switch weather to next stage
-- LUA EXAMPLE
local success = exports["qr-weathersync"]:nextWeatherStage();
// JAVASCRIPT EXAMPLE
const success = global.exports["qr-weathersync"].nextWeatherStage();
Switch to a specified weather type from Config.AvailableWeatherTypes
-- LUA EXAMPLE
local success = exports["qr-weathersync"]:setWeather("snow");
// JAVASCRIPT EXAMPLE
const success = global.exports["qr-weathersync"].setWeather("snow");
Sets sun position based on time to specified
-- LUA EXAMPLE
local success = exports["qr-weathersync"]:setTime(8, 10); -- 8:10 AM
// JAVASCRIPT EXAMPLE
const success = global.exports["qb-weathersync"].setTime(15, 30); // 3:30PM
Sets or toggles blackout state and returns the state
-- LUA EXAMPLE
local newStatus = exports["qr-weathersync"]:setBlackout(); -- Toggle
// JAVASCRIPT EXAMPLE
const newStatus = global.exports["qr-weathersync"].setBlackout(true); // Enable
Sets or toggles time freeze state and returns the state
-- LUA EXAMPLE
local newStatus = exports["qr-weathersync"]:setTimeFreeze(); -- Toggle
// JAVASCRIPT EXAMPLE
const newStatus = global.exports["qr-weathersync"].setTimeFreeze(true); // Enable
Sets or toggles dynamic weather state and returns the state
-- LUA EXAMPLE
local newStatus = exports["qr-weathersync"]:setDynamicWeather(); -- Toggle
// JAVASCRIPT EXAMPLE
const newStatus = global.exports["qb-weathersync"].setDynamicWeather(true); // Enable
Returns if blackout is enabled or disabled
-- LUA EXAMPLE
local state = exports["qr-weathersync"]:getBlackoutState();
// JAVASCRIPT EXAMPLE
const state = global.exports["qr-weathersync"].getBlackoutState();
Returns if time progression is enabled or disabled
-- LUA EXAMPLE
local state = exports["qr-weathersync"]:getTimeFreezeState();
// JAVASCRIPT EXAMPLE
const state = global.exports["qr-weathersync"].getTimeFreezeState();
Returns the current weather type
-- LUA EXAMPLE
local currentWeather = exports["qr-weathersync"]:getWeatherState();
// JAVASCRIPT EXAMPLE
const currentWeather = global.exports["qr-weathersync"].getWeatherState();
Returns if time progression is enabled or disabled
-- LUA EXAMPLE
local state = exports["qr-weathersync"]:getDynamicWeather();
// JAVASCRIPT EXAMPLE
const state = global.exports["qr-weathersync"].getDynamicWeather();
qr-weathersync:server:RequestStateSync
- Sync time and weather for everyone
qr-weathersync:server:setWeather
[type] - Set Weather type (List in Config)
qr-weathersync:server:setTime
[hour] (minute) - Set simulated time
qr-weathersync:server:toggleBlackout
(true|false) - Enable, disable or toggle blackout
qr-weathersync:server:toggleFreezeTime
(true|false) (minute) - Enable, disable or toggle time progression
qr-weathersync:server:toggleDynamicWeather
(true|false) - Enable, disable or toggle dynamic weather