Overview
A variable can be a number, string, boolean (true or false), color, array, or ‘any.’ All variables have an initial value, but that value can be changed through user interaction, making variables very useful for prototyping.Creating a Variable
Before you use a variable, you need to define it in the Variables Panel, only on macOS.Variable Scope
First, you need to choose where the variable can be used. Variables have three possible scopes: global, page, and component.- Global Variables: Variables that can be used, updated, and displayed throughout an entire project. For example, if you wanted to save a user’s name from an input text field and use their name on other pages of the app, you would use a global variable.
- Page Variables: Variables that can be used on the page they are created on. They cannot be used across different pages.
- Component Variables: Variables that can only be used or edited on a main component. Each instance of the component will have its own distinct variable value. For example, if you wanted to create a social media post “like count,” you would use a component variable.
- Prefab Variables: variables that are specific to the prefab they were created on. They can only be edited within the prefab, and they’ll exist anywhere the prefab is used.
Variable Properties
Once you choose the scope, add a new variable to that scope’s list by clicking the plus button.
- Name: Name your variable whatever you’d like, as long as there are no spaces. We recommend making the name something short, easy to remember, and descriptive.
- Type: Specify if your variable should be a number, string, bool, array, dictionary, color, secure entry, or “any”. The type should depend on your use case.
- A number variable stores a numerical value. Use a number variable to:
- Save a stepper or slider’s value
- Track the number of lives remaining in a game
- Store the Y location of a user’s tap
- A string variable holds a text value, which can store anything from a single character to an entire paragraph of text. Use a string variable to:
- Save the text a user inputs in a text field
- A boolean variable stores either True or False (On / Off). Use a bool variable to:
- Track if a user has tapped a button
- Track if a user is actively panning
- Determine if a toggle is switched on or off
- Create conditional statements
- An array variable stores an ordered collection of data. Use an array variable to:
- Store a list of usernames
- Store a list of numbers
- Store several boolean values
- Modify lists
- A dictionary variable stores information as key-value pairs. Use a dictionary variable to:
- Store external data from a Fetch API or JSON response
- A color variable stores an ordered collection of data. Use an color variable to:
- Store a HEX code
- Store a RGBA value
- An “any” variable can store any value. Use an “any” variable to:
- Save an element to use it’s properties. For example: set a stack as a variable, cast it as an element, and use its width: variable.asElement().width
- A number variable stores a numerical value. Use a number variable to:
- Value: Set the initial/default value of your variable. This is often ‘0’ for number variables, “” (empty string) for string variables, and ‘off’ for bool variables, but there are situations where you want to use a different initial value.
- Set Value to (nil): Turning this on sets your variable to empty. Empty variables indicate that the variable has not been set/used through interaction.
- You might create an empty variable to set a condition to false prior to user interaction.
- Description: Add an optional description of what your variable is used for. This is helpful when collaborating with teammates and sharing Play files with engineers.
Using a Variable
Set Variable
The Set Variable action lets you update the value of one or more variables through an interaction. You’ll select the variable on the left side of the equals sign (=), and enter the new value on the right, using the Expressions Editor. You can enter a hard-coded value into the Expression Editor, like “Hello”, 20, or True, to set a variable to something specific. You can also use properties and equations as the variable’s value. For example, you could set a variable as…- An input text field’s value (probably a string)

- The X or Y location of a user’s tap

- An updated count


Set Array
The Set Array action lets you dynamically alter the items in an array variable. Set Array actions can add new items to an array, remove items from an array, or sort array items.Using Variables as Values
You can use a variable as the value for any property in Play. For example, you can set the value of a text element to a variable by using a Set Text action. In the Set Text action’s Value property, open the Expression Editor and type the variable name.
Variables in Expressions and Conditions
Once a variable is defined, you can use it to simplify expressions and conditions. Since variables often change through Set Variable actions, using them in conditions allows for more responsive interactions. In this example, a user adds an item to their cart using a stepper. If they add three or more, a discount is applied to the price of each item.
12.99
. If it’s false, the price is set to 15.49
.
Then, you can use both variables to calculate the total price (item quantity * item price) in the Expression Editor.
