PEmbroider is an open library for computational embroidery with Processing. PEmbroider was developed during Endless March 2020 at the CMU Frank-Ratchye STUDIO for Creative Inquiry by Golan Levin, Lingdong Huang, and Tatyana Mustakos, with generous support from an anonymous donor and the Clinic for Open Source Arts (COSA) at the University of Denver. For questions, please contact Golan Levin. If you found this project useful, please consider making a donation.
PEmbroider includes file-writing code adapted from the EmbroidePy EmbroideryIO project, under EmbroidePy's MIT License. Additional thanks to our beta-test community; Chris Coleman, and the Processing Foundation; Huw Messie, Bryce Summers, Lea Albaugh, Dan Moore, and the staff of the STUDIO.
Intended primarily for artists, craftspersons, educators, makers, and schools, PEmbroider is free, open-source software released under both the GNU General Public Licence (GPLv3) and the Anti-Capitalist Software License (ACSL 1.4). In short: you are encouraged to use PEmbroider to make art; you are required to share your improvements to PEmbroider; and you are expressly forbidden from using PEmbroider to profiteer. More information on PEmbroider's license is below.
- Download the PEmbroider library .ZIP file for processing 3 or for processing 4
- Instructions for Getting Started
- Here's a Cheat Sheet
- Browse the Examples
- Read the Full API
- Motivation
- Features
- Examples
- Getting Started with PEmbroider in Processing
- How to Build PEmbroider From Source
- FAQ
- License
As this comparison of embroidery software shows, existing software for the creation of custom embroidery designs frequently costs thousands of dollars; is rarely cross-platform; and is almost never open-source. The free and open-source tools which do exist are either full-featured standalone GUI tools (Ink/Stitch, Embroidermodder) or large-scale libraries (EmbroidePy)—neither of which integrate easily with popular "creative coding" toolkits, nor easily allow for the creation of generative and computational designs.
PEmbroider, by contrast, is a free, cross-platform, open-source, lightweight Java library for generative embroidery design. It integrates with the popular Processing creative coding framework, providing ready access to a vast and diverse ecosystem of functionality including high quality typography, live interaction, motion capture, computer vision, GIS cartography, physics simulation, and much more.
PEmbroider is a embroidery library for the Java flavor of the Processing creative coding environment, suitable for generating embroidery designs computationally. PEmbroider has the following features:
- PEmbroider is structured similarly to other alternative renderers for Processing, providing basic drawing functions (lines, shapes, typography, etc.) that have drop-in compatibility with Processing code.
- PEmbroider is able to generate embroidery files in .DST, .EXP, .JEF, .PEC, .PES, .VP3, and .XXX file formats, suitable for consumer CNC embroidery machines such as those made by Brother, Janome, or Husqvarna-Viking.
- PEmbroider is also able to export .PDF, .SVG, .TSV, and .GCODE files for other 2D output devices such as CNC routers, AxiDraw pen plotters, etc. Although PEmbroider has not been primarily designed for plotter output, some of our hatching algorithms may be useful for this community.
- PEmbroider is able to generate embroidery designs from vector (.SVG) and black-and-white bitmap files (.PNG, .GIF).
- PEmbroider allows a variety of ways of composing shapes (including overlapping, cropping, and merging) using various computer vision and computational geometry algorithms.
- PEmbroider offers a wide range of embroidery hatching (fill) methods.
- PEmbroider generates optimized (shortest) paths using a modified Traveling Salesperson Problem solver, dramatically reducing embroidery time and material use.
PEmbroider has been tested on MacOS 10.13.6+ and Windows 10, using the STUDIO's Husqvarna Viking Designer Jade 35 embroidery machine.
Note: PEmbroider provides a visualization of the embroidery files it generates. However, PEmbroider has no functionality for loading or previewing pre-existing embroidery files; this is outside the scope of the project. To preview the contents of a .PES, .VP3, or other embroidery file, you will need to use embroidery viewing software, such as this or this. That said, it is possible to load SVGs and other images in Processing and use PEmbroider to generate embroidery designs from those.
PEmbroider comes with a variety of examples which demonstrate how to achieve different sorts of embroidery effects with lines, shapes, typography, images and more. Here are just some of them:
This section is primarily intended for end-users who wish to get started using PEmbroider to make embroidery designs.
- Be sure you have already installed Processing v.4.0a6 or higher.
- Download the precompiled PEmbroider library .ZIP directly from here. (If you're still on Processing 3, use this link instead).
- For an automated install, try using Processing's Contribution Manager. Navigate as follows in the Processing app: Sketch → Import Library → PEmbroider. This will open the Contribution Manager, where you can browse for PEmbroider.
- For a manual install, Unzip the PEmbroider .ZIP file and install it in your Processing Libraries directory. More detailed instructions for doing this can be found here.
- Restart Processing. You should now be able to open and run the included example programs, which you can find inside the PEmbroider directory, or here.
- To export embroidery files, make sure that
optimize()
andendDraw()
are called in your code. Theoptimize()
function produces much, much more efficient embroidery paths, whileendDraw()
is the code that actually exports the file. Note thatoptimize()
may take up to a minute to execute. - In the code for your sketch, be sure you have specified the correct file format extension for your embroidery machine. PEmbroider currently supports .DST, .EXP, .JEF, .PEC, .PES, .VP3, and .XXX. If your machine's format is not yet supported, try using this online converter, Ink/Stitch, or Embird.
- PEmbroider provides the
visualize()
function to view the planned stitches. You can also preview and validate your embroidery files with software such as this online viewer, Husqvarna/Viking PREMIER+ 2, or Brother PE-Design. - See here for instructions on using the STUDIO's Husqvarna Viking Designer Jade 35 embroidery machine.
This section is primarily intended for developers who wish to modify, extend, or contribute to the PEmbroider library itself.
To compile the library from source: First, open the project in Eclipse; then:
Follow this excerpt from processing/processing-library-template:
- From the Eclipse menu bar, choose Window → Show View → Ant. A tab with the title "Ant" will pop up on the right side of your Eclipse editor.
- Drag the
resources/build.xml
file in there, and a new item "ProcessingLibs" will appear.- Press the "Play" button inside the "Ant" tab.
If BUILD SUCCESSFUL: The Library template will start to compile, control messages will appear in the console window, warnings can be ignored. When finished it should say BUILD SUCCESSFUL. Congratulations, you're set and you can start modifying the library by making changes to the source code in the
src
directory.If BUILD FAILED: In case the compile process fails, check the output in the console, which will give you a closer idea of what went wrong. Errors may have been caused by Incorrect path settings in the
build.properties
file.
Here are the same steps, in screenshots:
If there are any issues, download a fresh copy of this repository, and try carefully following Processing's official documentation.
- Which output file formats are supported? .DST, .EXP, .JEF, .PEC, .PES, .VP3, and .XXX, as well as .PDF, .SVG, .TSV, and .GCODE.
- Which embroidery machine do you recommend? We cannot recommend which hardware is best for you. However, this review website has good things to say about the Janome Memory Craft 9850 ($1800, takes .JEF) and the Brother PE800 ($900, takes .PES and .DST). We developed our code using the Viking Jade 35 ($1000) and are pleased. The majority of our beta-testers have different kinds of Brother machines, for which our .DST files appear to behave well.
- Why can't PEmbroider read pre-existing embroidery design files? This is a purposeful limitation of the project's scope. Philosophically, PEmbroider is intended to do one thing well: to allow you to generate new embroidery designs, with code. There is already plenty of software that allows you to load other people's designs. If you would like to manipulate pre-existing embroidery files computationally, we recommend the EmbroidePy project.
- How can I learn to code in Processing? There's great documentation at the main Processing website, or you can check out Dan Shiffman's amazing Coding Train tutorials on YouTube.
- How can I learn to do machine embroidery? Here are YouTube tutorials for the Viking Jade 35, the Brother PE800, and the Brother SE600.
PEmbroider is Copyright © 2020, the Frank-Ratchye STUDIO for Creative Inquiry at Carnegie Mellon University. Intended primarily for artists, craftspersons, educators, makers, and schools, PEmbroider is free, open-source software released under both the GNU General Public Licence (GPLv3) and the Anti-Capitalist Software License (ACSL v. 1.4). In short:
- you are encouraged to use PEmbroider to make art;
- you are required to share your improvements to PEmbroider;
- and you are expressly forbidden from using PEmbroider to profiteer on the backs of artists, craftspersons, educators, makers, and schools. An example of this would be using PEmbroider to make commercial software such as (e.g.) Floriani Total Control Embroidery Software ($3499), DIME Designs in Machine Embroidery ($2999), Viking Premier Plus 2 Ultra ($2979), Hatch Embroidery Digitizer ($1099), Janome Artistic Digitizer Software ($1199), DesignerPlus Full Version ($1874), DRAWings PRO XI ($1299), etcetera.
This is anti-capitalist software, released for free use by individuals and organizations that do not operate by capitalist principles.
Permission is hereby granted, free of charge, to any person or organization (the "User") obtaining a copy of this software and associated documentation files (the "Software"), to use, copy, modify, merge, distribute, and/or sell copies of the Software, subject to the following conditions:
- The above copyright notice and this permission notice shall be included in all copies or modified versions of the Software.
- The User is one of the following:
- a. An individual person, laboring for themselves
- b. A non-profit organization
- c. An educational institution
- d. An organization that seeks shared profit for all of its members, and allows non-members to set the cost of their labor
- If the User is an organization with owners, then all owners are workers and all workers are owners with equal equity and/or equal vote.
- If the User is an organization, then the User is not law enforcement or military, or working for or under either.
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT EXPRESS OR IMPLIED WARRANTY OF ANY KIND, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.