Skip to content

Latest commit

 

History

History
224 lines (158 loc) · 7.79 KB

cli.md

File metadata and controls

224 lines (158 loc) · 7.79 KB

📕 canvas-sketchDocumentation → CLI Docs


canvas-sketch-cli — 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.

Contents

Usage

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)

Creating a Sketch

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.

Templates

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

Running Sketches

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

Building to a Website

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.

FFMPEG Streaming

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 scaling width: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.

MP4 and GIF Conversion Utilities

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 GIF
  • canvas-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.