date: Difference between revisions

From Bohemia Interactive Community
Jump to navigation Jump to search
m (Text replacement - "\| *((\[\[[a-zA-Z0-9_ |()]+\]\],? ?)+) * \}\}" to "|seealso= $1 }}")
m (Some wiki formatting)
 
(28 intermediate revisions by 2 users not shown)
Line 1: Line 1:
{{RV|type=command
{{RV|type=command


| arma1
|game1= arma1
|version1= 1.00


|1.00
|game2= arma2
|version2= 1.00
 
|game3= arma2oa
|version3= 1.50
 
|game4= tkoh
|version4= 1.00
 
|game5= arma3
|version5= 0.50


|gr1= Environment
|gr1= Environment
Line 9: Line 20:
|eff= local
|eff= local


| Return the actual in-mission date and time.
|descr= Return the actual in-mission date and time.
{{Feature|arma3 | Clients' local date is [[Multiplayer Scripting#Join In Progress|automatically and periodically synchronised]] with the server date.}}


|mp= Returns the current <u>local</u> in-game date.
|mp= Returns the current '''local''' (MP client) in-game date.
{{Feature|arma3|Clients' local date is [[Multiplayer Scripting#JIP Synchronisation|automatically and periodically synchronised]] with the server date.}}


| [[date]]
|s1= [[date]]


| [[Date]] - format [year, month, day, hour, minute]
|r1= [[Array]] - [[Date]] format


|x1=<code>_now = [[date]]; {{cc|[2014,10,30,2,30] ''(Oct. 30th, 2:30am)''}}
|x1= <sqf>
_hour = _now [[select]] 3;
// in {{arma3}}
_min  = _now [[select]] 4;</code>
date params ["_year", "_month", "_day", "_hours", "_minutes"];


|x2=<code>[[if]] ([[date]] [[select]] 3 >= 19) [[then]] { {{cc|7pm}}
// pre {{arma3}}
[[hintSilent]] "ah, Arma sunset"; {{|...cue bad guys}}
private ["_now", "_year", "_month", "_day", "_hours", "_minutes"];
};</code>
_now = date; // [2014,10,30,2,30] a.k.a Oct. 30th, 2:30am
_year = _now select 0;
_month = _now select 1;
_day = _now select 2;
_hours = _now select 3;
_minutes = _now select 4;
</sqf>


|seealso= [[setDate]], [[dateToNumber]], [[numberToDate]], [[time]], [[missionStart]], [[systemTime]], [[systemTimeUTC]]
|x2= <sqf>
if (date select 3 >= 19) then // 7pm
{
hintSilent "ah, Arma sunset"; // ...cue bad guys
};
</sqf>
 
|seealso= [[setDate]] [[dateToNumber]] [[numberToDate]] [[time]] [[missionStart]] [[systemTime]] [[systemTimeUTC]]
}}
}}


<dl class="command_description">
{{Note
<!-- Note Section BEGIN -->
|user= Lou Montana
 
|timestamp= 20180123233500
<dd class="notedate">Posted on January 23, 2018 - 23:35 (UTC)</dd>
|text= a useful script to format the date:
<dt class="note">[[User:Lou Montana|Lou Montana]]</dt>
<sqf>
<dd class="note">
_curDate = date;
a useful script to format the date:
private _ddMMyyyy = format ["%3/%2/%1",
<code>_curDate = date;
_curDate select 0,
[[private]] _ddMMyyyy = [[format]] ["%3/%2/%1",
(if (_curDate select 1 < 10) then { "0" } else { "" }) + str (_curDate select 1),
_curDate [[select]] 0,
(if (_curDate select 2 < 10) then { "0" } else { "" }) + str (_curDate select 2)
([[if]] (_curDate [[select]] 1 < 10) [[then]] { "0" } [[else]] { "" }) + [[str]] (_curDate [[select]] 1),
];
([[if]] (_curDate [[select]] 2 < 10) [[then]] { "0" } [[else]] { "" }) + [[str]] (_curDate [[select]] 2)
</sqf>
];</code>


it can be shortened to: (no intermediary variable but more request to [[date]])
it can be shortened to: (no intermediary variable but more request to [[date]])
<code>[[private]] _ddMMyyyy = [[format]] ["%3/%2/%1",
<sqf>
[[date]] [[select]] 0,
private _ddMMyyyy = format ["%3/%2/%1",
([[if]] ([[date]] [[select]] 1 < 10) [[then]] { "0" } [[else]] { "" }) + [[str]] ([[date]] [[select]] 1),
date select 0,
([[if]] ([[date]] [[select]] 2 < 10) [[then]] { "0" } [[else]] { "" }) + [[str]] ([[date]] [[select]] 2)
(if (date select 1 < 10) then { "0" } else { "" }) + str (date select 1),
];</code>
(if (date select 2 < 10) then { "0" } else { "" }) + str (date select 2)
];
</sqf>


'''EDIT:''' or to
'''EDIT:''' or to
<code>[[private]] _ddMMyyyy = [[format]] ["%4%5/%2%3/%1",
<sqf>
[[date]] [[select]] 0,
private _ddMMyyyy = format ["%4%5/%2%3/%1",
["", "0"] [[select]] ([[date]] [[select]] 1 < 10),
date select 0,
[[date]] [[select]] 1,
["", "0"] select (date select 1 < 10),
["", "0"] [[select]] ([[date]] [[select]] 2 < 10),
date select 1,
[[date]] [[select]] 2
["", "0"] select (date select 2 < 10),
];</code>
date select 2
</dd>
];
 
</sqf>
<!-- Note Section END -->
}}
</dl>
 
 
{{GameCategory|arma2|Scripting Commands}}
{{GameCategory|arma3|Scripting Commands}}
{{GameCategory|tkoh|Scripting Commands}}

Latest revision as of 20:08, 8 March 2024

Hover & click on the images for description

Description

Description:
Return the actual in-mission date and time.
Multiplayer:
Returns the current local (MP client) in-game date.
Arma 3
Clients' local date is automatically and periodically synchronised with the server date.
Groups:
Environment

Syntax

Syntax:
date
Return Value:
Array - Date format

Examples

Example 1:
// in Arma 3 date params ["_year", "_month", "_day", "_hours", "_minutes"]; // pre Arma 3 private ["_now", "_year", "_month", "_day", "_hours", "_minutes"]; _now = date; // [2014,10,30,2,30] a.k.a Oct. 30th, 2:30am _year = _now select 0; _month = _now select 1; _day = _now select 2; _hours = _now select 3; _minutes = _now select 4;
Example 2:
if (date select 3 >= 19) then // 7pm { hintSilent "ah, Arma sunset"; // ...cue bad guys };

Additional Information

See also:
setDate dateToNumber numberToDate time missionStart systemTime systemTimeUTC

Notes

Report bugs on the Feedback Tracker and/or discuss them on the Arma Discord or on the Forums.
Only post proven facts here! Add Note
Lou Montana - c
Posted on Jan 23, 2018 - 23:35 (UTC)
a useful script to format the date:
_curDate = date; private _ddMMyyyy = format ["%3/%2/%1", _curDate select 0, (if (_curDate select 1 < 10) then { "0" } else { "" }) + str (_curDate select 1), (if (_curDate select 2 < 10) then { "0" } else { "" }) + str (_curDate select 2) ];
it can be shortened to: (no intermediary variable but more request to date)
private _ddMMyyyy = format ["%3/%2/%1", date select 0, (if (date select 1 < 10) then { "0" } else { "" }) + str (date select 1), (if (date select 2 < 10) then { "0" } else { "" }) + str (date select 2) ];
EDIT: or to
private _ddMMyyyy = format ["%4%5/%2%3/%1", date select 0, ["", "0"] select (date select 1 < 10), date select 1, ["", "0"] select (date select 2 < 10), date select 2 ];