vpype is the Swiss-Army-knife command-line tool for plotter vector graphics.
- What vpype is?
- How does it work?
- Examples
- What vpype isn't?
- Installation
- Documentation
- Feature overview
- Contributing
- License
vpype is the Swiss-Army-knife command-line tool for plotter vector graphics. Here is what it can do:
- laying out existing vector files with precise control on position, scale and page format;
- optimizing existing SVG files for faster and cleaner plots;
- creating HPGL output for vintage plotter;
- creating generative artwork through built-in commands or plug-ins;
- creating, modifying and processing multi-layer vector files for multi-colour plots;
- and much more...
vpype is highly extensible through plug-ins that can greatly extend its capabilities. For example, plug-ins already exists for plotting pixel art, half-toning with hatches, plotting text with Hershey fonts, applying hidden line removal, and much more.
vpype is also a well documented Python library useful to create generative art and tools for plotters. For example, the plotter generative art environment vsketch is built upon vpype.
Check the documentation for a more thorough introduction to vpype.
vpype works by building so-called pipelines of commands, where each command's output is fed to the next command's input.
Some commands load geometries into the pipeline (e.g. the read
command which loads geometries from a SVG file). Other commands modify these geometries, e.g. by cropping
them (crop
) or reordering them to minimize pen-up
travels (linesort
). Finally, some other commands
just read the geometries in the pipeline for display purposes (show
)
or output to file (write
).
Pipeline are defined using the vpype's CLI (command-line interface) in a terminal by typing vpype
followed by the
list of commands, each with their optional parameters and their arguments:
This pipeline uses five commands (in bold):
read
loads geometries from a SVG file.linemerge
merges paths whose extremities are close to each other (within the provided tolerance).linesort
reorder paths such as to minimise the pen-up travel.crop
, well, crops.write
export the resulting geometries to a SVG file.
There are many more commands available in vpype, see the overview below.
Some commands have arguments, which are always required (in italic). For example, a file path must be provided to the
read
command and dimensions must be provided to the crop
commands. A command may also have options which are, well,
optional. In this example, --page-size a4
means that the write
command will generate a A4-sized SVG (otherwise it
would have the same size as in.svg). Likewise, because --center
is used, the write
command will center geometries
on the page before saving the SVG (otherwise the geometries would have been left at their original location).
Note: although it is not required, commands are separated by multiple spaces for clarity in the following examples.
Load an SVG file, scale it to a specific size, and export it centered on an A4-sized, ready-to-plot SVG file:
vpype read input.svg scaleto 10cm 10cm write --page-size a4 --center output.svg
Optimize paths to reduce plotting time (merge connected lines and sort them to minimize pen-up distance):
vpype read input.svg linemerge --tolerance 0.1mm linesort write output.svg
Visualize the path structure of large SVG files, showing whether lines are properly joined or not thanks to a colorful display:
vpype read input.svg show --colorful
Load several SVG files and save them as a single, multi-layer SVG file (e.g. for multicolored drawings):
vpype read -l 1 input1.svg read -l 2 input2.svg write output.svg
Create arbitrarily-sized, grid-like designs like this page's top banner:
vpype begin grid -o 1cm 1cm 10 13 script alien_letter.py scaleto 0.5cm 0.5cm end show
Export to HPGL for vintage plotters:
vpype read input.svg write --device hp7475a --page-size a4 --landscape --center output.hpgl
vpype caters to plotter generative art and does not aim to be a general purpose (think Illustrator/InkScape) vector graphic tools. One of the main reason for this is the fact vpype converts everything curvy (circles, bezier curves, etc.) to lines made of small segments. vpype also dismisses the stroke and fill properties (color, line width, etc.) of the imported graphics. These design choices make possible vpype's rich feature set, but makes its use for, e.g., printed media limited.
For Windows, an installer is available here (note: plug-ins cannot be installed when using this installation method).
For other platforms, and when plug-ins are required, vpype can be installed from the Python Package Index using the following command:
pip install vpype
Python must previously be installed. Python version 3.8 is recommended to use vpype, although it is also compatible with Python 3.6 and 3.7. Python 3.9 should be avoided for the time being due to the lack of binary distribution for several dependencies.
For Linux, install Python with your OS's default package manager. For macOS, Python is best installed from either MacPorts or Homebrew. For Windows, use the official installer.
Check the documentation for more details, in particular on how to use a virtual environment (recommended).
The vpype CLI includes its own, detailed documentation:
vpype --help # general help and command list
vpype COMMAND --help # help for a specific command
In addition, the online documentation provides extensive background information on the fundamentals behind vpype, a cookbook covering most common tasks, the vpype API documentation, and much more.
- Easy to use CLI interface with integrated help (
vpype --help
andvpype COMMAND --help
) and support for arbitrary units (e.g.vpype read input.svg translate 3cm 2in
). - First-class multi-layer support with global or per-layer processing (e.g.
vpype COMMANDNAME --layer 1,3
) and layer edition commands (lmove
,lcopy
,ldelete
). - Powerful display command with adjustable units, optional per-line coloring, optional pen-up trajectories display and per-layer visibility control (
show
). - Geometry statistics extraction (
stat
). - Support for command history recording (
vpype -H [...]
) - Support for RNG seed configuration for generative plug-ins (
vpype -s 37 [...]
).
- Single- and multi-layer SVG input with adjustable precision, parallel processing for large SVGs, and supports percent or missing width/height (
read
). - Support for SVG output with fine layout control (page size and orientation, centering), layer support with custom layer names, optional display of pen-up trajectories, various option for coloring (
write
). - Support for HPGL output config-based generation of HPGL code with fine layout control (page size and orientation, centering).
- Powerful transform commands for scaling, translating, skewing and rotating geometries (
scale
,translate
,skew
,rotate
). - Support for scaling and cropping to arbitrary dimensions (
scaleto
,crop
). - Support for trimming geometries by an arbitrary amount (
trim
). - Arbitrary page size definition (
pagesize
).
- Line merging with optional path reversal and configurable merging threshold (
linemerge
). - Line sorting with optional path reversal (
linesort
). - Line simplification with adjustable accuracy (
linesimplify
). - Support for splitting all lines to their constituent segments (
splitall
). - Closed paths' seam location randomization, to reduce the visibility of pen-up/pen-down artifacts (
reloop
). - Support for generating multiple passes on each line (
multipass
). - Support for filtering by line lengths or closed-ness (
filter
). - Support for reversing order of paths within their layers (
reverse
).
- Generation of arbitrary primitives including lines, rectangles, circles, ellipses and arcs (
line
,rect
,circle
,ellipse
,arc
). - Generation of grid-like layouts (
grid
). - Generation of a frame around the geometries (
frame
). - Generation of random lines for debug/learning purposes (
random
)
- First-class support for plug-in extensions (e.g vpype-text, hatched, occult).
- Support for script-based generation (
script
). - Powerful and well-documented API for plug-ins and other plotter generative art projects.
Contributions to this project are welcome and do not necessarily require software development skills! Check the Contributing section of the documentation for more information.
This project is licensed under the MIT License - see the LICENSE file for details.