guidebook/docs/custom-doodads/index.md

4.4 KiB

Creating Custom Doodads

Sketchy Maze is designed to be modder friendly and provides tools to help you create your own custom doodads to use in your levels.

You can draw the sprites for the doodad either in-game or using an external image editor. Then, you can program their behavior using JavaScript to make them "do" stuff in-game and interact with the player and other doodads.

In-game Doodad Editor

The in-game level editor can be used to create custom doodads. As of Sketchy Maze v0.8.0, doodads can be authored entirely in-game without needing to use the doodad command-line tool.

Screenshot of the Doodad editor

See Drawing Doodads for details.

Using external editors

You may find it more comfortable to draw your doodads in an external image editor. All of the game's built-in doodads were drawn in The GIMP. The doodad command-line tool that ships with the game is able to convert a series of PNG images into a doodad, attach a JavaScript, set tags, and so on.

See External Editors for Doodads

Example Doodads

There are some example custom doodads you can check out at https://code.sketchymaze.com/declassified/doodads. There you will find example custom doodads to make your own player characters, Warp Doors, and more.

Naming Convention

It is strongly encouraged that you name your custom doodad files with a prefix or something to namespace them apart from the built-in doodads.

For example: if you made a custom doodad named "door-red.doodad" it would actually conflict with the built-in doodad of the same name, and your custom doodad would take priority over the built-in one.

By prefixing your custom doodad filenames with your initials or name, you will minimize the likelihood that your doodad conflicts with a built-in from a future game release or with custom doodads made by other players than yourself.

Future versions of the game will likely prevent saving a new doodad with the same filename of a built-in one.

Categories

The in-game Doodad Dropper window of the level editor shows a categorical view of doodads: Objects, Doors, Gizmos, Creatures, and All.

Categories are managed by setting custom tags on your .doodad file, which can be done by the doodad tool like so:

doodad edit-doodad --tag "category=objects" example.doodad

The "category" tag should hold a lowercase value. Only supported categories are recognized, which include: objects, doors, gizmos, creatures.

A doodad can appear under multiple categories by joining them with a comma:

doodad edit-doodad --tag "category=doors,gizmos" example.doodad

Every doodad also appears in the "All" tab. In the future, custom tags will be editable using in-game UI when creating a custom doodad.

Profile Directory

Custom doodads and levels will go in your Profile Directory, into folders named "doodads" and "levels" respectively.

To share your custom doodads with others, you can copy the .doodad files out of your doodads folder. To install doodads made by others, place their .doodad files into your doodads folder, and they will appear in-game to drag and drop them into your level.

doodad (Command Line Tool)

Your copy of the game should have shipped with a doodad command-line tool bundled with it. On Windows it's called doodad.exe and should be in the same folder as the game executable. On Mac OS, it is located inside the .app bundle.

The doodad tool provides a command-line interface to create and inspect doodad and level files from the game. You'll need to use this tool, at the very least, to attach a JavaScript to your doodad to make it "do" stuff in-game.

You can create a doodad from PNG images on disk, attach or view the JavaScript source on them, and view/edit metadata.

# (the $ represents the shell prompt in a command-line terminal)

# See metadata about a doodad file.
$ doodad show /path/to/custom.doodad

# Create a new doodad based on PNG images on disk.
$ doodad convert frame0.png frame1.png frame2.png output.doodad

# Add and view a custom script attached to the doodad.
$ doodad install-script index.js custom.doodad
$ doodad show --script custom.doodad

More info on the doodad program here.