📕 canvas-sketch → Documentation → CLI Docs
Below are the docs for the canvas-sketch-cli
command-line interface (CLI). This tool requires you to have Node.js v8+ and npm v5+ already installed.
💡 If you are just getting started, you may want to look at some of the guides first, such as the Installation guide, or A "Hello, World" Sketch.
- Usage
- Creating Sketches
- Running Sketches
- Building to a Website
- FFMPEG Streaming
- MP4 and GIF Conversion Utilities
Usage:
canvas-sketch [file] [opts] -- [browserifyArgs]
Examples:
canvas-sketch my-file.js
canvas-sketch --build --dir public/
canvas-sketch --new --template=three --open
canvas-sketch src/sketch.js --new
Options:
--help, -h Show help message
--version, -v Display version
--new, -n Stub out a new sketch
--template, -t Set the template to use with --new,
e.g. --template=three or --template=penplot
--open, -o Open browser on run
--hot Enable Hot Reloading during development
--output Set output folder for exported sketch files
--dir, -d Set output directory, defaults to '.'
--port, -p Server port, defaults to 9966
--no-install Disable auto-installation on run
--force, -f Forces overwrite with --new flag
--pushstate, -P Enable SPA/Pushstate file serving
--quiet Do not log to stderr
--build Build the sketch into HTML and JS files
--no-compress Disable compression/minification during build
--inline When building, inline all JS into a single HTML
--name The name of the JS file, defaults to input file name
--js The served JS src string, defaults to name
--html The HTML input file, defaults to a basic template
--stream, -S Enable ffmpeg streaming for MP4/GIF formats
--https Use HTTPS (SSL) in dev server instead of HTTP
--source-map Source map option, can be false, "inline",
"external", or "auto" (default)
You can use the --new
and --template
flags to create a new sketch. You can also pipe source code directly into the command.
# Make a new sketch file called 'my-sketch.js' and run it
canvas-sketch my-sketch.js --new
# Create a sketch and open the browser on start
canvas-sketch src/sketch.js --new --open
# Write & launch a sketch from clipboard
pbpaste | canvas-sketch --new --open
Once running, you can open the browser to http://localhost:9966/ to start editing.
Currently the following --template
types are supported:
For example, to start a new ThreeJS sketch:
canvas-sketch sketch.js --new --template=three --open
You can also specify your own template file using an absolute or relative path (starting with .
or a path separator).
canvas-sketch sketch.js --template=./mytemplate.js
When you create a sketch, it will also start the development server. You can omit the --new
flag to run an existing sketch:
canvas-sketch mysketch.js
You can include the --hot
flag if you wish to enable Hot Reloading:
canvas-sketch mysketch.js --hot
If you are building your website into a public/
, app/
or other sub-directory, you may need to specify this directory for assets to load with correct paths:
canvas-sketch mysketch.js --dir public
You can also specify browserify transforms after a full --
stop:
canvas-sketch mysketch.js -- -t bubleify
You can use the --build
command to generate static HTML and JS files from your sketch input. These files can be placed into your favourite web hosting solution to share your sketches online.
Other examples:
# Render website to 'public/' without minification
canvas-sketch mysketch.js --dir public --build --no-compress
# Render website to a single standalone file called 'index.html'
canvas-sketch mysketch.js --name index --build --inline
# Render a website using a different HTML file and custom JS src
canvas-sketch src/index.js --html=src/page.html --js=bundle.js
The HTML file can include {{entry}}
which will get replaced by the <script>
tag definition used by the build tool. Example:
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, shrink-to-fit=0, user-scalable=no, minimum-scale=1.0, maximum-scale=1.0">
<title>canvas-sketch</title>
<link rel="stylesheet" href="main.css">
</head>
<body>
{{entry}}
</body>
</html>
Note that main.css
is relative to the directory being served, which defaults to the working directory, but can be set differently during development and build with the --dir
flag.
Note: This feature needs at least
[email protected]
and[email protected]
to work.
If you have ffmpeg
installed and visible in your path, you can enable streaming into GIF and MP4 files instead of exporting sequences of frames. See How to Install ffmpeg
for installation instructions.
The command looks like this:
# Save animation to MP4 file
canvas-sketch animation.js --output=tmp --stream
# Save animation to GIF file
canvas-sketch animation.js --output=tmp --stream=gif
# Save animation to GIF but scale it down to 512 px wide
canvas-sketch animation.js --output=tmp --stream [ gif --scale=512:-1 ]
If you pass --stream
with no options, it will default to --stream=mp4
.
This flag supports the "subarg" pattern, which might look a bit strange but it allows us to pass options into the --stream
flag. These options are:
--scale
,-s
for scalingwidth:height
, you can use-1
which means 'auto' (preserve aspect ratio)--time
,-t
for the duration, such as-t=4s
for 4 second loop--start
,-s
for the start time, such as-s=1s
to start after 1 second
Note that GIF should generally not exceed 50 FPS, otherwise it may produce choppy outputs.
The canvas-sketch-cli
comes equipped with two built-in utilities for converting image sequences to GIF and MP4 formats.
canvas-sketch-gif
converts input to GIFcanvas-sketch-mp4
converts input to MP4
These tools depend on ffmpeg
and expect it to be available on the PATH environment.
Example usage:
# Do some sketching and export sequence to tmp/
canvas-sketch foo.js --output=tmp/
# Now convert the sequence of 0-padded PNGs to a GIF
canvas-sketch-gif tmp/ output.gif --fps=24
# Or to a MP4 file, generating a new filename by timestamp
canvas-sketch-mp4 tmp/ --fps=24
# You can specify an exact frame sequence/extension
canvas-sketch-mp4 tmp/%02d.png
# You can also use the tool to convert MP4 to GIF and vice versa
canvas-sketch-mp4 anim.mp4 anim.gif
💡
Make sure to match the
--fps
flag to your{ fps }
sketch settings for best results.
You can read the full CLI documentation in Converting GIF and MP4 Files.