Doodad Program#

The game ships with a command-line program called doodad which assists in creating and managing custom doodads and levels.

The doodad tool can show and set details on .doodad and .level files used by the game, create new doodads from PNG images and attach custom JavaScript source to program behavior of doodads.

Where to Find It#

The doodad tool should be in the same place as the game executable.

On Windows, the program is called doodad.exe and comes in the zip file next to the game executable, doodle.exe.

On Linux, it will typically be at /opt/sketchymaze/doodad if you installed the game from a .rpm or .deb package, or else for Flatpak it's included within the app bundle and invoked like so:

$ flatpak run com.sketchymaze.Doodle doodad --help

On Mac OS, it is found inside the .app bundle; right-click the 'Sketchy Maze.app' to find the option to browse inside the .app bundle.

Usage#

Run doodad --help to get usage information.

The program includes several sub-commands, such as doodad convert. Type a subcommand and --help to get help on that command, for example:

doodad convert --help

Examples#

Here are some common scenarios and use cases for the doodad tool.

Show Level or Doodad Information#

Shows metadata and details about a level or doodad file.

# Usage:
doodad show [doodad or level filename]

Examples:

### About a doodad file
$ doodad show button.doodad
===== Doodad: button.doodad =====
Headers:
  File version: 1
  Game version: 0.7.0
  Doodad title: Button
        Author: Noah
        Locked: true
        Hidden: false
   Script size: 922 bytes

Palette:
  - Swatch name: Color<#000000+ff>
    Attributes:  solid
    Color:       #000000
  - Swatch name: Color<#666666+ff>
    Attributes:  none
    Color:       #666666
  - Swatch name: Color<#999999+ff>
    Attributes:  fire
    Color:       #999999

Layer 0: button1
Chunks:
  Pixels Per Chunk: 37^2
  Number Generated: 1
  Coordinate Range: (0,0) ... (36,36)
  World Dimensions: 36x36
  Use -chunks or -verbose to serialize Chunks

Layer 1: button2
Chunks:
  Pixels Per Chunk: 37^2
  Number Generated: 1
  Coordinate Range: (0,0) ... (36,36)
  World Dimensions: 36x36
  Use -chunks or -verbose to serialize Chunks

### About a level file
$ doodad show 'Tutorial 2.level'
===== Level: Tutorial 2.level =====
Headers:
  File version: 1
  Game version: 0.7.0
   Level title: Lesson 2: Keys & Doors
        Author: Noah P
      Password: 
        Locked: false

Palette:
  - Swatch name: rock
    Attributes:  solid
    Color:       #996600
  - Swatch name: grass
    Attributes:  solid
    Color:       #00ff00
  - Swatch name: stone
    Attributes:  solid
    Color:       #888888
  - Swatch name: water
    Attributes:  water
    Color:       #0099ff
  - Swatch name: spikes
    Attributes:  fire
    Color:       #ff0000
  - Swatch name: hot lava
    Attributes:  fire
    Color:       #ff3300

Level Settings:
  Page type: Bounded
   Max size: 2550x3300
  Wallpaper: legal.png

Attached Files:
  None

Actors:
  Level contains 35 actors
  Use -actors or -verbose to serialize Actors

Chunks:
  Pixels Per Chunk: 128^2
  Number Generated: 206
  Coordinate Range: (-128,0) ... (2559,3327)
  World Dimensions: 2687x3327
  Use -chunks or -verbose to serialize Chunks

Attach and Export Doodad Scripts#

Doodads are programmed in JavaScript and the script can be attached and read using the doodad program.

Usage:

# Set the doodad script from filename.js
doodad install-script filename.js custom.doodad

# View the script from a doodad file
doodad show --script custom.doodad

Example:

$ doodad show --script key-blue.doodad
// key-blue.doodad.js
function main() {
    var color = Self.GetTag("color");
    var quantity = color === "small" ? 1 : 0;

    Events.OnCollide(function(e) {
        if (e.Settled) {
            Sound.Play("item-get.wav")
            e.Actor.AddItem(Self.Filename, quantity);
            Self.Destroy();
        }
    })
}

Edit Level or Doodad Properties#

The doodad edit-level and doodad edit-doodad commands can set certain properties on these types of drawings.

Example:

$ doodad edit-level --title "My First Level" example.level

Available properties that can be modified are as follows:

  • edit-doodad
    • --title value: set the doodad's title (display name).
    • --author value: set the author's name (default is your OS username).
    • --tag value, -t value: set a custom tag (key=value format) on your doodad.
    • --hide, --unhide: edit the Hidden attribute on a doodad. Hidden doodads don't appear in the Doodad Dropper window of the level editor.
    • --lock, --unlock: edit the Locked attribute on a doodad. Locked doodads can not be opened for editing in-game.
  • edit-level
    • --title value: set the level's title.
    • --author value: set the author's name (default is your OS username).
    • --password value: set the password for the level (not currently used).
    • --type value: set the page type, one of: Bounded, Unbounded, NoNegativeSpace, Bordered.
      • Note: Bordered is not yet implemented, and behaves the same as Bounded.
    • --max-size WxH: set the page size for Bounded levels, like 2550x3300.
    • --wallpaper name.png: set the wallpaper image filename.
    • --lock, --unlock: edit the Locked attribute on a level. Locked levels can not be opened for editing in-game.
    • --remove-actor <name or id>: remove an actor from your level by its name or its UUID. For example: --remove-actor trapdoor.doodad removes every instance of trapdoor.doodad from the level geometry.

Remove actors from your level#

In case you inherit a level that needs custom doodads that you don't have, you'll get errors in the level editor about the missing doodads. One way to remedy this is to delete the offending doodads from the map, but you can't do this in the editor because the doodads don't have a sprite in your map.

First, use the doodad show --actors example.level command and look for the Actors segment of the result, e.g.:

$ doodad show --actors example.level
...
Actors:
  Level contains 16 actors
  List of Actors:
  -  Name: key-blue.doodad
     UUID: 15f09c12-5d00-4654-9725-8e1ba10004d7
       At: 362,1348
  -  Name: trapdoor-down.doodad
     UUID: 24f85095-d13c-42e2-9156-01cb4b84723c
       At: 897,398
  -  Name: crumbly-floor.doodad
     UUID: 9ba40fc2-acc7-4e6d-821a-f0248c2ad7e1
       At: 1243,1742
...

You can then delete these actors by either their Name (filename) or their UUID value. Deleting by name means that all instances of that doodad will be removed from the map.

$ doodad edit-level --remove-actor crumbly-floor.doodad example.level

Convert To/From Images#

The doodad convert command can turn PNG or BMP images into doodads or level files, and vice versa!

# Usage:
doodad convert [options] <input files.png> <output file.doodad>

Only PNG or bitmap images are supported.

Creating a Doodad from PNG images#

Suppose you have PNG images named "frame0.png" through "frame3.png" and want to create a doodad from those images. This will convert them to the doodad file "custom.doodad":

# Convert PNG images into a doodad.
doodad convert frame0.png frame1.png frame2.png frame3.png custom.doodad

# The same, but also attach custom tags with the doodad.
# The doodad script can check its tags and you can have one
# common script for multiple variations of a doodad, e.g.,
# all four of the built-in Colored Locked Doors share a script.
doodad convert --tag color=blue frame{0,1,2,3}.png custom.doodad

# Convert the doodad back into an image.
# NOTE: only the 1st frame (frame0) can be exported, currently.
doodad convert custom.doodad frame0.png

The order of the given PNG images will be the order of the doodad layers created; the first image will be Layer 0, the second Layer 1, and so on. The names of the image files will be the names of those layers, minus the .png or .bmp file extension.

Creating a Level from a PNG image#

A level file can be created from a PNG image:

# Usage:
doodad convert [options] input.png output.level

# Set which color is 'transparent' (to show the level wallpaper behind)
doodad convert --key '#ffffff' input.png output.level

Some considerations about this feature:

  • The Palette will be created from each distinct color value found in the original PNG image. The names of each color will be named after their hex color value, and no attributes are applied by default. You will need to edit the level palette to mark colors as solid, fire, water, etc.
  • The --key option (default #ffffff, white) sets the background color; pixels of this color in the input PNG will be 'transparent' in the level data, showing the wallpaper image behind.

Convert a level to a PNG image#

You can also convert a .level file into a PNG (or bitmap) image, creating a sort of "large screenshot" encompassing the entire level geometry.

# Usage:
doodad convert my.level output.png

Some considerations about this feature:

  • Doodads are not included in the output image; only the level geometry itself is.
  • Brush Patterns are not applied in the output image; each color swatch in your level will represent as solid pixel colors in the output image.

The image created by this command could be fed back in to re-create the level from that image, albeit with lots of information lost in the process, such as the names and properties of Palette swatches and all the doodad placements.