resize: Difference between revisions

From Bohemia Interactive Community
Jump to navigation Jump to search
No edit summary
(Add example)
Line 25: Line 25:


|descr= Changes the size of the given array. The command does not return new array, it resizes the source array to the desired number of elements.
|descr= Changes the size of the given array. The command does not return new array, it resizes the source array to the desired number of elements.
If the new size is bigger than the current size, the new places are filled with [[nil]]. Since Arma 3 2.10 resized positions can be filled with given value. [[Array]] and [[HashMap]] values are copied.
If the new size is bigger than the current size, the new places are filled with [[nil]]. The {{Link|#Syntax 2|alternative syntax}} allows to fill resized positions with a given value. [[Array]] and [[HashMap]] values are copied.


|s1= array [[resize]] count
|s1= array [[resize]] count
Line 46: Line 46:




|x1= <sqf>_arrayNum = [0,1,2,3,4];
|x1= <sqf>
_arrayNum = [0,1,2,3,4];
_arrayNum resize 2; // _arrayNum is now [0,1]
_arrayNum resize 2; // _arrayNum is now [0,1]
_arrayNum resize 5; // _arrayNum is now [0,1,nil,nil,nil]</sqf>
_arrayNum resize 5; // _arrayNum is now [0,1,nil,nil,nil]
</sqf>
 
|x2= <sqf>
private _array = [0, 1, 2];
_array resize [5, -1]; // _array is now [0, 1, 2, -1, -1]
 
private _array = [0, 1, 2];
_array resize [1, -1]; // _array is now [0]
 
private _array = [0, 1, 2];
_array resize [1, "something"]; // _array is now [0, 1, 2, "something", "something"]
</sqf>


|seealso= [[set]] [[reverse]] [[deleteAt]] [[deleteRange]]
|seealso= [[set]] [[reverse]] [[deleteAt]] [[deleteRange]]

Revision as of 15:08, 15 June 2022

Hover & click on the images for description

Description

Description:
Changes the size of the given array. The command does not return new array, it resizes the source array to the desired number of elements. If the new size is bigger than the current size, the new places are filled with nil. The alternative syntax allows to fill resized positions with a given value. Array and HashMap values are copied.
Groups:
Arrays

Syntax

Syntax:
array resize count
Parameters:
array: Array
count: Number - the new array size
Return Value:
Nothing

Alternative Syntax

Syntax:
array resize [count, fill]
Parameters:
array: Array
count: Number - the new array size
fill: Anything - value to fill added positions
Return Value:
Nothing

Examples

Example 1:
_arrayNum = [0,1,2,3,4]; _arrayNum resize 2; // _arrayNum is now [0,1] _arrayNum resize 5; // _arrayNum is now [0,1,nil,nil,nil]
Example 2:
private _array = [0, 1, 2]; _array resize [5, -1]; // _array is now [0, 1, 2, -1, -1] private _array = [0, 1, 2]; _array resize [1, -1]; // _array is now [0] private _array = [0, 1, 2]; _array resize [1, "something"]; // _array is now [0, 1, 2, "something", "something"]

Additional Information

See also:
set reverse deleteAt deleteRange

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
DreadedEntity - c
Posted on Nov 13, 2014 - 06:26 (UTC)
Use this number to resize the array to the number of elements desired, not the desired index of the final element.
resize cannot be used to create a new array.