Arrays
What’s an array? #
Array is a special variable which can hold more than one value at a time.
If you have a list of items (for example viewer names), storing them in single variables would look like this:
- var name1 = “wolbee”
- var name2 = “Silverlink”
- var name3 = “Sebas”
This seems quite inefficient if you happen to have a lot of names to store. The answer is to store them all in an array, which can hold many values under a single name: names = ["wolbee", "Silverlink", "Sebas"]
.
Array manipulation #
If you want to retrieve a specific value (element) from an array, you can use the following formatting:
arrayName[position]
If we have an array names = ["wolbee", "Silverlink", "Sebas"]
, typing names[1]
would retrieve 'Silverlink'
(the first value of an array has position of 0).
Array position (also called index) can contain other variables or complex math, too.
Some command boxes allow you to use not only position, but also top for retrieving and manipulating values in an array. Selecting top will target a value at the END of an array (last index). 0 will target a value at the BEGINNING of an array (index of 0).
Array is cleared every time you close or reset SAMMI. If you wish to save it in a file, you can use Stringify Array and INI: Save Text commands.
Convert stacks saved in .ini files from LB1 to arrays in SAMMI #
If you’re using the same .ini files from LioranBoard 1, you will notice that your stringified stacks don’t get properly parsed when loaded back into SAMMI (they end up being objects instead of arrays).
Use this Stack to Array converter button:
Creates a new empty array.
You can populate it with Array Insert command.
Box Name | Type | Description |
---|---|---|
Array Name | String | Name of the new array |
Inserts a value into an array in a specific index (position), shifting other values to the right.
Supports setting the array value directly to objects/arrays without having to parse and stringify them.
The position you can insert the value to can be:
-
top - adds a value to the end of the array (same as
Array push
in Javascript)
-
0 - adds a value to the beginning of the array (same as
Array unshift
in Javascript)
-
index (position) to insert the value to (similar to
Array splice
in JavaScript)
Replaces a value inside an array, overriding the previous one. Position of all values remains the same.
Supports setting the array value directly to objects/arrays without having to parse and stringify them.
Pulls a value from an array by removing it from the array and saving it inside the selected variable. All remaining array value will be shifted by one.
Removes a value from an array from a specified index (position), shifting other values to the right.
This is similar to Array splice()
method in JavaScript.
yourArrayName[valueIndex]
to remove a value, both commands will achieve the same.
Box Name | Type | Description |
---|---|---|
Array Name | String | Name of the array |
Delete Position | Position to delete the value at. Can be top , 0 or index (position) of the value. |
Finds the first instance of a given value inside the array and returns its index(position) in the array.
Returns -1 if value was not found.
Box Name | Type | Description |
---|---|---|
Array Name | String | Name of the array to search for the value |
Save Array Position As | String | Name of the variable to save the index(position) of the found value |
Find value | The value to find in the array |
Find value | array | Result |
---|---|---|
“blue” | [“yellow”,”red”,”blue”,”orange”,”blue”] | 2 |
“blue” | [“yellow”,”red”,”blue cat”,”orange”] | -1 (not found) |
“blue” | [“yellow”,”Blue”,”blue cat”,”blue”] | 3 |
Returns a random value inside an array.
Very useful for displaying a random image or playing a random sound, to name some use cases.
The randomization will happen with an equal chance for each value.
_weight
added to its name and add values that will act as weights (chances to happen) to add to the randomization.
Save Variable As (position)
box in conjunction with the Get Button Variable command instead.
Box Name | Type | Description |
---|---|---|
Array Name | String | Name of the stack |
Save Variable As | String | Variable name to save the random value into |
Save Variable As (position) | String (optional) | You can enter a variable name here if you wish to get the index(position) of the random value in the array |
Sorts an array alphabetically or numerically (depending on its values) in an ascending/descending order.
If you have a mix of real and string values in your array, it will sort it based on the first array value.
Box Name | Type | Description |
---|---|---|
Array Name | String | Name of the array you want to sort |
Ascending | Checkbox | Checked = sort in ascending order, unchecked = sort in descending order |
Shuffles an array, randomizing the order of every value in it.
Box Name | Type | Description |
---|---|---|
Array Name | String | Name of the array you want to shuffle |
Returns the size of the array (= how many items it holds) and saves it into the given variable.
Returns 0 if the array is empty.
Box Name | Type | Description |
---|---|---|
Array Name | String | Name of the array |
Save Variable As | String | Variable name to save the size of the array |
Joins two arrays together. Appends another array at the end of first array.
Both arrays must already exist.
Box Name | Type | Description |
---|---|---|
Array Name | String | The array to append to |
Array To Transfer | String | The array to append at the end of the first array |
Returns a JSON string of the whole array.
You can use this command together with File: Save String command to save the whole array into a file. Once loading it back from the file, you can use Parse Array/Object command to turn the JSON string back into the original array.
Box Name | Type | Description |
---|---|---|
Save Variable As | String | Variable to save the JSON string of the array into |
Array Name | String | Name of the array to stringify |
Turns a JSON string into an array/object. Must be properly formatted (SAMMI will give you a warning if it finds any formatting errors).
This way you can easily create a prepopulated object/array, as it supports nesting.
Read more about JSON syntax at w3schools.com.
Box Name | Type | Description |
---|---|---|
Array/Object Name | String | Name of the variable to save the parsed array/object into |
String Array/JSON | JSON String | JSON string to parse |
JSON string before conversion | Result saved in the variable |
---|---|
["Lioran", "Melonax", "Cyanidesugar"] |
|
["Hello", "Hi", {"MyObject": [1, 2, 3]}] |
|
["Lioran", "Melonax", ["cat", "rabbit", "dog"]] |
The inner array does NOT get parsed. |
Creates and returns a new string by concatenating all of the elements in an array, separated by a specified separator string.
Box Name | Type | Description |
---|---|---|
Array Name | String | Name of your array |
Separator | String | How the values of the array are being separated |
Save Variable As | String | Variable to save the string as |
Saves in an array all the number values (of the original array) matching the specified criteria.
Box Name | Type | Description |
---|---|---|
New Array Name | String | Name of the array to save the matching values. |
Array Name | String | Name of the array to filter. |
Compare | Dropdown menu | Operator you wish to use to compare the array values with. |
Variable/Number | Number to compare the array values with. |
Array | Compare Type | Number | Returned Array |
---|---|---|---|
[1,2,3,4,5,6,7] | > | 5 | [6,7] |
[25,38,100,22,6] | <= | 25 | [25,22,6] |
[“text”,1,2,3,”more text”] | > | 2 | [3] |
Saves in an array the result of doing math with every value of the original array.
Box Name | Type | Description |
---|---|---|
New Array Name | String | Name of the array to save the returned array. |
Array Name | String | Name of the array to do math. |
Operator | Dropdown menu | Operator you wish to use on the array values. |
Value | Value to do Math. |
Array | Operator | Value | Returned Array |
---|---|---|---|
[1,2,3,4,5,6,7] | += | 5 | [6,7,8,9,10,11,12] |
[1,2,3,4] | concat | ” player” | [1 player,2 player,3 player,4 player] |
Similar to ‘Array Pull’ but without removing the value from the array.
Clears all the contents of an array, leaving it empty. Does not delete the array itself, you must use Delete Variable command for that instead.
Box Name | Type | Description |
---|---|---|
Array Name | String | Array name you wish to clear |