JavaScript Code events
This event allows you to add custom JavaScript code in your game. It's only meant to be used by advanced users who are familiar with JavaScript programming.
To add a JavaScript event, click on the + button in the Events Sheet toolbar, and select JavaScript code:
When added, click on the code to edit it. The code will be executed each time the event is reached by GDevelop.
In all JavaScript events, you have access to a variable named runtimeScene
. This variable represents the scene being played. Below is an example of a standard GDevelop event, and an equivalent event that uses a JavaScript:
If you click on "Click here to choose objects to pass to JavaScript" next to the runtimeScene
parameter, you get to choose an object from the scene. The instances of this object will be passed to your function as an array called objects
:
This array is exactly like what an action or a condition would use. For example, the illustration below is an event using a JavaScript event as a sub-event. The JavaScript event will manipulate the enemies that are colliding with the player:
Tip
The recommended way of using JavaScript events is to implement new actions, conditions or behavior thanks to extensions. They can be reuse from project to project and shared with the community. Learn more about this in the extension page.
Examples
Tip
See it in action! 🎮
Open these examples online. You can do this with the links given below. There is a number of more examples available when you ask GDevelop to create a new project, then click the examples button.
Text to speech
JavaScript blocks in platformer
Documentation 📚
- Read the game engine documentation to get started.
- You can also browse directly the GDJS game engine source code.
Code examples
Read and change the value of a variable
const myVar = runtimeScene.getVariables().get("MyVar");
const myVar2 = runtimeScene.getVariables().get("MyVar2");
const currentValue = myVar.getAsNumber();
myVar.setNumber(currentValue + 1);
myVar2.setString("Hello, world");
See the documentation of gdjs.Variable and gdjs.VariablesContainer.
Move object at the position of another, check if the game is rendering the first frame
const players = runtimeScene.getObjects("Player");
const playerHitBoxes = runtimeScene.getObjects("PlayerHitBox");
// Stop early if for some reason the player or the hitbox object is not found.
if (playerHitBoxes.length === 0 || players.length === 0) return;
// At the first frame only (i.e: at the beginning of the scene).
if (runtimeScene.getTimeManager().isFirstFrame()) {
// Hide the first instance of PlayerHitBoxes.
playerHitBoxes[0].hide();
}
// Set the position of the Player object.
players[0].setX(playerHitBoxes[0].getX() - 12);
players[0].setY(playerHitBoxes[0].getY());
Equivalent events would be:
Change animation according to some conditions on the behavior of an object
Tip
In the code below, we use a comment which is called an annotation.
By writing the annotation /** @type {gdjs.XXX} */
just before the declaration of a variable in JavaScript, you let the code editor know that the variable has the type gdjs.XXX. The editor will be able to assist you by providing autocompletion while you type (or when you hover over a word).
Most of the time annotations are not needed. The methods that you are using are already setup with type annotations. But when you use a list of objects, you may want to access this object specific method (for example, methods to modify the animation of a sprite object). In this case, you could write /** @type {gdjs.SpriteRuntimeObject} */
.
If you don't do this, the code will still work, but the editor will only be able to provide you with the methods of gdjs.RuntimeObject
(the base class).
When you get the behavior from an object, you also know what kind of behavior you're getting. Let the editor know this using an annotation (otherwise, you'll only get autocompletion for the base class, gdjs.RuntimeBehavior
).
const players = runtimeScene.getObjects("Player");
const playerHitBoxes = runtimeScene.getObjects("PlayerHitBox");
if (playerHitBoxes.length === 0 || players.length === 0) return;
/** @type {gdjs.SpriteRuntimeObject} */
const player = players[0];
/** @type {gdjs.PlatformerObjectRuntimeBehavior} */
const platformerBehavior = playerHitBoxes[0].getBehavior("PlatformerObject");
if (platformerBehavior.isJumping() || platformerBehavior.isFalling()) {
player.setAnimation(1);
} else if (platformerBehavior.isOnFloor()) {
if (!platformerBehavior.isMoving()) {
player.setAnimation(0);
} else {
player.setAnimation(2);
}
}
const LEFTKEY = 37;
const RIGHTKEY = 39;
if (runtimeScene.getGame().getInputManager().isKeyPressed(LEFTKEY)) {
player.flipX(true);
} else if (runtimeScene.getGame().getInputManager().isKeyPressed(RIGHTKEY)) {
player.flipX(false);
}
Equivalent events would be:
Set the position of the camera to the position of an object
if (!objects.length) return;
// Here, "objects" refer to a list of "Player", which should be selected
// in the configuration of the function.
runtimeScene.getLayer("").setCameraX(objects[0].getX());
This equivalent event would be:
Fade out a sprite object after it is on the floor (using the Platformer Object behavior)
objects.forEach(object => {
/** @type {gdjs.SpriteRuntimeObject} */
const enemy = object;
/** @type {gdjs.PlatformerObjectRuntimeBehavior} */
const platformerBehavior = object.getBehavior("PlatformerObject");
if (enemy.getAnimation() === 1 && platformerBehavior.isOnFloor() && !platformerBehavior.isMoving()) {
object.activateBehavior("PlatformerObject", false);
enemy.setOpacity(enemy.getOpacity() - 50 * object.getElapsedTime(runtimeScene) / 1000);
if (enemy.getOpacity() === 0) {
object.deleteFromScene(runtimeScene);
}
}
});
The equivalent events would be:
Use JavaScript to get the value of a parameter of a function
When use a JavaScript code block inside a function of an extension, a custom behavior or a custom object, you can access to the parameters of this function. The way you access to the parameter depends on the type of this parameter.
If the parameter is of type Objects
, you can get the array of instances passed to this object:
To get the array of instances, use the function eventsFunctionContext.getObjects
:
eventsFunctionContext.getObjects("myParameter");
In this case, with a parameter named RotatedObjects
, if you want rotate the object by 45 degrees, you can do:
const objects = eventsFunctionContext.getObjects("RotatedObjects");
const firstInstance = objects[0];
firstInstance.setAngle(45);
You can also read the value of parameters that are numbers or strings. For example, if you have a parameter with type Number
:
You can read it in the JavaScript code block with eventsFunctionContext.getArgument
:
const angle = eventsFunctionContext.getArgument("Angle");
The same code can be used to access string, number or boolean parameters.
Learn by reading code from the community
Extensions can be implemented with events and JavaScript or a mix of both. Looking at existing extensions can help a lot to understand the API or how the extension system works.
This is a few instances of extensions that use JavaScript:
- The Noise generator extension uses a noise library and exposes its features through expressions, action and conditions.
- The 3D object shake extension uses the same noise library from the above extension but exposes a behavior that makes 3D objects shake.
- The Boids movement extension exposes a behavior to users and uses a R-Tree internally to quickly check neighbors.
- The Object stack extension exposes conditions that pick object instances according to their position in a stack.
- The Clipboard extension uses an asynchronous web API and implements fallbacks to Electron API or Cordova plugins.