#Embroidery on Art Blocks Engine
In addition to providing a browser-based live view and media files generated from your project script, Art Blocks Engine provides tools to embroider your generative artwork on garments and accessories.
#Requirements
In order to get started, you will need:
- Testnet project shell on Art Blocks Engine Refer to documentation for setup instructions*
- Embroidery machine and software drivers compatible with DST or PES files If you are new to embroidery, we recommend the Brother PE800
- JavaScript utilities for manipulating SVG markup Clone the embroidery template repository for an example: ‣
#Quick Start
- Deploy a new project shell to your Art Blocks Engine testnet contract
- Upload a project script that includes a global function named
generateEmbroiderySVG
that returns a string containing SVG markup for embroidery - Use the Embroidery File Downloader to generate embroidery files for minted tokens
#Project Script Requirements
In addition to following the typical guidelines and constraints for Art Blocks projects, your project script should include a global function that is only used for embroidery.
#Generating SVG for Embroidery
Implement a global function with the following type signature:
For example, you may include a function similar to code below:
#Functional Requirements
In order to correctly generate files for embroidery, you must:
- Implement a
generateEmbroiderySVG
global function that returns the full markup of an<svg>
element as a string - Optional: accept a
width
andheight
parameter (millimeters) used to resize the contents of the SVG to accommodate different garment sizes - Render a digital-only version of the art using a separate
<svg>
or<canvas>
that is displayed to the user and thumbnailed in token metadata (similar to any digital-only Art Blocks project) - Inline all libraries and code used in your project that are not configured as an on-chain dependency
#Known Limitations
- Avoid using SVG fills - instead, to create the visual appearance of a fill, the SVG should contain the exact paths the embroidery needle should follow
- Avoid using asynchronous code or promises inside of the
generateEmbroiderySVG
function - the function should return valid SVG markup immediately - Provide margins (bleed) matching the precision of the embroidery machine to improve manufacturing yield
- Match all colors used in your design to the colors of thread available to you for embroidering
#Embroidery in Production
In addition to the typical steps required for moving an Art Blocks Engine project to mainnet, there are additional considerations for embroidery projects.
#Logistics and Fulfillment
There are three primary customer experiences enabled for embroidery on Art Blocks Engine:
- Drop-shipped or batched production
Consider the lead times, available materials, and the process for sending files to embroidery service providers. - Live in-person pop-up events
Consider space constraints and measure the amount of time required to fulfill a single embroidered object. - At-home embroidery for token holders
Consider how and when you would like to provide your users with a link to download embroidery files for a project.
#Option 1: Batched Production
To facilitate automated testing and batched production, we provide a rate-limited API for converting Art Blocks Engine projects into DST and PES embroidery files. Note: the API endpoints provided for batched production are rate-limited, and cannot be linked from a public web site.
For example, the following commands illustrate how you can download individual embroidery files for tokens on an Art Blocks Engine project:
#Option 2: Live Events
To facilitate live events, operators of a pop-up booth can use the Embroidery File Downloader on a laptop or iPad to quickly download the relevant embroidery files for a given minted token.
#Option 3: Home Embroidery
If you would like to provide your token holders with a link to download DST or PES files of their minted tokens, please contact us for access to the API dashboard. To generate embroidery files in an S3 bucket that may be linked from a public web site, you will need to add your project in the API dashboard here: https://minting-api.artblocks.io/admin/embroidery/embroideryproject/