mirror of
https://github.com/acemod/ACE3.git
synced 2024-08-30 18:23:18 +00:00
90 lines
3.5 KiB
Plaintext
90 lines
3.5 KiB
Plaintext
// by CAA-Picard
|
|
|
|
if !(hasInterface) exitWith {};
|
|
|
|
// Kestrel Stuff
|
|
AGM_isKestrel = false;
|
|
AGM_isKestrelWheel = false;
|
|
|
|
0 spawn {
|
|
waitUntil {preloadTitleRsc ["AGM_Kestrel", "PLAIN"]};
|
|
waitUntil {preloadTitleRsc ["AGM_KestrelWheel", "PLAIN"]};
|
|
waitUntil {preloadTitleRsc ["AGM_KestrelWheel_Preload", "PLAIN"]};
|
|
};
|
|
|
|
// Air temperature and air density
|
|
if (isNumber (configFile >> "CfgWorlds" >> worldName >> "AGM_TempMeanJan")) then {
|
|
AGM_TempMeanJan = getNumber (configFile >> "CfgWorlds" >> worldName >> "AGM_TempMeanJan");
|
|
AGM_TempMeanJul = getNumber (configFile >> "CfgWorlds" >> worldName >> "AGM_TempMeanJul");
|
|
AGM_TempAmplitudeJan = getNumber (configFile >> "CfgWorlds" >> worldName >> "AGM_TempAmplitudeJan");
|
|
AGM_TempAmplitudeJul = getNumber (configFile >> "CfgWorlds" >> worldName >> "AGM_TempAmplitudeJul");
|
|
} else {
|
|
_lat = - getNumber (configFile >> "CfgWorlds" >> worldName >> "latitude");
|
|
if (_lat == 0) then {_lat = 0.1;};
|
|
_yearlyTempMean = 28 min (28 - (abs(_lat) - 23.5) * (3.14159/180) * 6371 / 145);
|
|
AGM_TempMeanJan = _yearlyTempMean - _lat / abs(_lat) * ((abs(_lat) max 25) - 25) * 30 / 65;
|
|
AGM_TempMeanJul = _yearlyTempMean + _lat / abs(_lat) * ((abs(_lat) max 25) - 25) * 30 / 65;
|
|
AGM_TempAmplitudeJan = 10;
|
|
AGM_TempAmplitudeJul = 10;
|
|
};
|
|
|
|
0 spawn {
|
|
while {true} do {
|
|
_annualCoef = 0.5 - 0.5 * cos(360 * dateToNumber date);
|
|
_dailyTempMean = AGM_TempMeanJan * (1 - _annualCoef) + AGM_TempMeanJul * _annualCoef;
|
|
_dailyTempAmplitude = AGM_TempAmplitudeJan * (1 - _annualCoef) + AGM_TempAmplitudeJul * _annualCoef;
|
|
|
|
_hourlyCoef = -0.5 * sin(360 * ((3 + (date select 3))/24 + (date select 4)/1440));
|
|
AGM_Wind_currentTemperature = _dailyTempMean + _hourlyCoef * _dailyTempAmplitude - 2 * humidity - 4 * overcast;
|
|
AGM_Wind_currentRelativeDensity = (273.15 + 20) / (273.15 + AGM_Wind_currentTemperature);
|
|
sleep 60;
|
|
};
|
|
};
|
|
|
|
// Wind & Temperature Readings
|
|
0 spawn {
|
|
while {true} do {
|
|
waitUntil {(inputAction "Compass" > 0 or inputAction "CompassToggle" > 0) and (vehicle player == player)};
|
|
|
|
_windStrength = sqrt((wind select 0) ^ 2 + (wind select 1) ^ 2);
|
|
|
|
_arrowRscString = "";
|
|
switch true do {
|
|
case (_windStrength <= 0.5) : {};
|
|
case (_windStrength <= 3) : {_arrowRscString = "VeryLight";};
|
|
case (_windStrength <= 5) : {_arrowRscString = "Light";};
|
|
case (_windStrength <= 7) : {_arrowRscString = "Moderate";};
|
|
default {_arrowRscString = "Strong";};
|
|
};
|
|
|
|
_approxTemp = (round (AGM_Wind_currentTemperature / 5)) * 5; // in steps of 5
|
|
hintSilent format ["%1: %2 °C", localize "STR_AGM_Wind_ApproximateTemp", _approxTemp];
|
|
|
|
// Draw arrow indicator
|
|
186186 cutRsc ["AGM_Wind_Arrow", "PLAIN"];
|
|
|
|
// Calculate relative direction between player
|
|
#define numSectors 16
|
|
_relAngle = windDir - (getdir (player));
|
|
_sector = round(_relAngle / (360/numSectors)) + 1;
|
|
if (_sector < 1) then {
|
|
_sector = _sector + numSectors;
|
|
};
|
|
if (_sector > numSectors) then {
|
|
_sector = _sector - numSectors;
|
|
};
|
|
|
|
// Update arrow indicator texture
|
|
_textureName = if (_arrowRscString == "") then {
|
|
"\AGM_Wind\ui\AGM_noWind.paa"
|
|
} else {
|
|
format["\AGM_Wind\ui\AGM_Wind%1-%2.paa", _arrowRscString, if (_sector < 10) then {"0"+str(_sector)} else {str(_sector)}]
|
|
};
|
|
((uiNamespace getVariable "AGM_Wind_Arrow") displayCtrl 185185) ctrlSetText _textureName;
|
|
|
|
sleep 0.1;
|
|
//186186 cutText ["", "PLAIN"];
|
|
hint "";
|
|
};
|
|
};
|