You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 

5.6 KiB

Creating custom events

HeaderImage

Introduction

What are Dialogic events?

Events are visual representation of data. Whenever you create one event in your timeline, you are modifying a dictionary with a lot of keys and values. Each pair will contain all the information needed to perform an action during the game.

What makes a custom event?

A custom event is made up of a two main parts: the Event Block and the Event Handling Script.

The Event Block is the scene that will be shown in the timeline editor. It needs to inherit Dialogic's EventTemplate.tscn scene.

In most cases you will additionally need scenes that have all the setting controls in them. These will be the "content" of your event block. This kind of scenes will have to extend the EventPart.gd script.

Here is a very simple example of an EventBlock: EventBlock It contains two EventParts, a header and a body.

The Event Handling Script is what contains the logic and what will happen when your event happens in the game. This script will need the handle_event() function that will be called if the event is reached.

All of the files that are used for creating a custom Event Block and Handling Script should be in this directory: res://dialogic/custom-events. That way Dialogic can recognize it and show it in your timeline editor.

Making your first custom event in 6 steps

Let's now create a simple event that will print some text to the Output panel in Godot.

Create the event

Go to the settings page and in the custom events section hit the New button. Fill in a name for your event, a folder name and an id. For the id's I recommend using your name or a string unique to you followed by a number. The id has to be different for every event!!! This is why I recommend the unique string, because it will enable you to share the event with others without breaking their games. Creating

When you are ready, hit Create. You will see the folder appear in the FileSystem under res://dialogic/custom-events/.

If you go to the timeline editor now, you should already be able to see your event in the event list.

What happened

This little menu already created a number of things for you:

  • The EventBlock (EventBlock.tscn)
  • An example EventPart (EventPart_Example.gd/.tscn)
  • The event handling script (event_+EVENTID+.gd)
  • A stylebox for your event (Stylebox.tres)

What next

The automatic process already setup a lot. But it didn't know the purpose of our event. So we will have to add that.

| Adding the data

First we want to open the EventBlock.tscn scene. (Do not rename this scene!)

Select its root node and look at it's exported variables in the inspector.

We will need to add all the data, that our event can have to the event_data. You can see, that it alread contains your event id. This needs to be there, do not delete it!

I want to be able to set a text that will be printed, when my event is activated, so I'll add an information slot for that: EventData

| Icon and Stylebox

You can also change your events icon in the inspector. Just drag an image into the Event Icon.

Below that, you can open the Stylebox and change its background color, to give your event a unique look.

| The Event Blocks Content (EventParts)

Right now your event block will be empty so let's change that (if you want to).

The content of an EventBlock is separated as EventParts. This allows for some reuse. There are two places EventParts can be in an EventBlock: The Header (always visible) and the Body (can be hidden).

An EventBlock does not have to have a body nor a header EventPart. For example the End Branch event has none.

There is already a simple example EventPart (Script and Scene) included. You can change it as much as you want.

| Loading the data

In load_data() you will need to set the values of your control nodes. This function is called when the event is added to the timeline editor.

| Saving changes to the data

When the values get changed (listen to it via signals) set the according value in the event_data dictionary and call data_changed().

This is pretty much all you need to know. If you want to find more examples you can go to res://addons/dialogic/Editor/Events/Parts/ and look at the EventParts that shape Dialogic's default blocks.

| Using the EventPart

Once you finished everything in your EventPart(s) you need to go into the EventBlock scene and set the header/body variable in the inspector to the new scene(s).

| The event handler script (event_yourname_000.gd)

Once you have your EventBlock finished, you need to add the event handling logic.

| The handle_event() function

If you open the script you will see, that there is only one function by default, the handle_event() function.

It comes with two usefull pieces of information: the event_data and a reference to the dialog_node.

For me I'll just add print(event_data['print_text'] there. But of course you can do a lot more.

Some more stuff is already explained in the script:

Continue

Use dialog_node.load_next_event() to continue with the next event.

Waiting

If you don't want the player to interrupt your event, set dialog_node.waiting to true while your event is handled. Don't forget to set it back to false.

And done!

Great, you've created your first custom event for dialogic.

Make sure to check Emilio's Discord server just in case someone has already created the custom event that you need. They are super easy to import!