Skip to content

Expressions

When adding a condition or an action to an event, some fields have the following icons alongside them:

These icons indicate that the field accepts an expression. An expression is a formula, like in mathematics, that can be composed of:

Tip

For a complete list of the function expressions that GDevelop provides out of the box, refer to expressions reference.

Numbers

When the following icon appears alongside a field, the field accepts a numeric expression:

The following values are examples of numeric expressions, composed of a single number:

  • 0
  • -10
  • 25.5

You can also use mathematical operators to add, subtract, multiply, and divide numbers:

  • 2+2
  • 3-1
  • 10*10
  • 99/3

This is the complete list of operators:

  • + (add)
  • - (subtract)
  • * (multiply)
  • / (divide)

Finally, functions can be used - see the next sections.

Text

When the following icon appears alongside a field, the field accepts a text expression:

The following values are examples of text expressions, composed of a single text:

  • "Hello world"
  • "This is a text expression"
  • "GDevelop is cool!"

All texts must be wrapped in double quotes. Without the double quotes, GDevelop assumes the value is a function or a variable.

You can use the + operator to concatenate two or more strings of text. For example, "Hello" + "World" becomes "HelloWorld". The other operators are not valid when working with text (it does not make sense to subtract, multiply or divide a text by another).

Variables (or properties)

Warning

Writing the name of variables (or properties) inside an expression will be available in the upcoming version of GDevelop. In the meantime, use Variable or VariableString to access the value of a variable.

In an expression, you can write the name of a variable (a scene variable, a global variable). For example, if a variable called Score was added to the scene, you can simply write: 2 * Score to compute the score value multiplied by two.

You can also access to the value of a variable of an object by writing the object name followed by a dot and the name of the variable. For example: Player.Ammo or Player.CoinEarned.

Finally, when you're editing a behavior or a custom object inside an extension, you can also access the properties of this behavior or object by writing their name, like variables.

Functions

Often, it's necessary to calculate complex values using data coming from the game. For example, you might want to compute something like a score according to the X and Y coordinates of the player.

This is where functions are useful.

You can use functions to dynamically calculate values while the game is running. For example, the X and Y functions calculate the coordinates of an object:

ObjectName.X()
ObjectName.Y()

Using a function is often referred to as calling a function.

Tip

If you're familiar with formulas in spreadsheets, functions in programming languages, or functions in mathematics, functions in GDevelop are the same thing.

Syntax

There are three types of functions:

  • Functions without objects. For example: cos(3.14).
  • Functions with objects. For example: Player.X().
  • Functions with objects and behaviors. For example: Player.Animation::Index().

Functions without objects

Some functions exist independently of objects and behaviors. You don't need any object or behavior to call these functions.

These are some examples of functions without objects:

  • CurrentSceneName() - Get the name of the current scene.
  • FileSystem::DesktopPath() - Get the path of the "Desktop" directory.
  • ToNumber(<number>) - Convert a string into a number.

Note

The :: syntax is used to group functions related to a same feature or extension. For example, all of the file system functions are prefixed with FileSystem::. This helps keep related functions organized. The :: syntax does not change the behavior of the function.

Functions with objects

Some functions are called on objects. This means the function affects or retrieves data about a specific object.

These are some examples of functions that are used with objects. The placeholder <object> must be replaced with the name of an object in your game:

  • <object>.Angle() - Get the angle of the object (in degrees).
  • <object>.Layer() - Get the name of the layer that the object is on.
  • <object>.ObjectName() - Get the name of the object.

Functions with objects and behaviors

Some functions are functions provided by a behavior attached to an object. This means the function affects or retrieves data about a specific behavior that is attached to an object. This is often useful to manipulate or read data from the behavior.

These are some examples of functions with objects and behaviors:

  • <object>.Pathfinding::Speed()
  • <object>.Physics2::Friction()
  • <object>.PlatformerObject::Gravity()

Note

You can see again the :: syntax here. This separate the behavior name and the name of the function. This is useful in case you have multiple behaviors on a single object.

Arguments

Some functions accept arguments. An argument is a value that:

  • can be passed into a function
  • affects the output of the function

For example, the ToString function converts a number into a string, but it can't do anything unless you provide it with a number. That number is the argument. In the following example, the number 42 is the argument:

ToNumber(42)

Some functions, such as the RandomInRange function, accept multiple arguments:

RandomInRange(3, 10)

When a function accepts multiple arguments, each argument must be separated by a comma.

Return values

When a function calculates a value, it's said to return that value. This value is the output of the function. For example, if the X coordinate of an object is 42, the ObjectName.X() function returns 42. The value returned by a function depends on the object, the arguments, and the state of the game.

Functions can return numbers or strings. The type of value a function returns determines whether or not a function can be used in a field. For example, the ToString function returns a string, so it can't be used in a field that expects a number, while the ToNumber function returns a number, so it can't be used in a field that expects a string.