Codename Logo Codename Logo

Events/Notetype Scripts

APIWiki

Events/Notetype Scripts

Events

Events can be found in ./data/events. There's currently 3 files used for events: a script file, a JSON file to determine the parameters of it, and an image file for it's icon. (they all need to have the same name as the event)

First, we'll go over making the JSON file. The JSON file holds all parameters required for the Event, and each parameter can have different types. Each parameter type is listed here:

{
    "params": [
        {
            "name": "Bool",
            "type": "Bool",
            "defaultValue": false
        },
        {
            "name": "Int",
            "type": "Int(0, 99, 1)",
            "defaultValue": 0
        },
        {
            "name": "Float",
            "type": "Float(0, 99, 1, 2)",
            "defaultValue": 0.00
        },
        {
            "name": "String",
            "type": "String",
            "defaultValue": "nothing"
        },
        {
            "name": "StrumLine",
            "type": "StrumLine",
            "defaultValue": 0
        },
        {
            "name": "ColorWheel",
            "type": "ColorWheel",
            "defaultValue": "#FFFFFF"
        },
        {
            "name": "DropDown",
            "type": "DropDown('entry one', 'entry two')",
            "defaultValue": "entry one"
        }
    ]
}

(you can copy these for your own JSON file)
There's a lot of them but we'll go over each one.

Image showing all of the different types of parameters

Now that we have established the Parameters, we can go over scripting the event now. A basic flash camera event looks something like this:

function onEvent(e) {
    if (e.event.name == "Flash Camera") {
        var params:Array = e.event.params;
        camGame.flash(params[1], params[0]);
    }
}

In this example, we assume that we set our parameters to be the duration of the flash (float), and the color of it (colorwheel).
Image showing a 2 parameter event, float and colorwheel, for a custom event named Flash Camera

The order of the parameters in e.event.params corresponds to the order you've put the params in.

For the icon, place a (preferably 16x16) image in the same directory as the event files.

Write about .pack files later

Note types

Making note types only consists of 2 files: the script file and the note sprites.

Putting the sprites in ./images/game/notes and naming them after the note type name will automatically replace the default note sprites with those.

Writing a script for the note types is very easy. Though only one script is ran for all existing note types instead of each note, you can still code actions for them.
For example here is code for triggering actions when the player presses it:

function onPlayerHit(event) {
    if (event.noteType == "Damage Note") {
        health -= 0.5;
        boyfriend.playAnim("hurt");
    }
}
Written by: Frakits
Last updated: 2024-08-29