2.22.2 โ€ข Published 1 year ago

@freesewing/plugin-export-dxf v2.22.2

Weekly downloads
73
License
MIT
Repository
github
Last release
1 year ago

FreeSewing

@freesewing/plugin-export-dxf

A FreeSewing plugin to export your pattern as DXF-ASTM

๐Ÿšจ๐Ÿšจ This packages is deprecated ๐Ÿšจ๐Ÿšจ

This package will not be part of FreeSewing v3.

About

This plugin adds the ability to export patterns to DXF-ASTM.

DXF (Drawing interchange format) is a file format developed by Autodesk (of AutoCADยฎ fame).
The DXF-ASTM variety is a subset of the format, specifically targetted at the garment industry.

ASTM is the American Society for Testing and Materials โ€” a standards body โ€” that published the format. DXF-ASTM is the successor of DXF-AAMA which was developed by the American Apparel Manufacturers Association which reveals the origins of the file format.

Usage

Instantiate your pattern, and use the plugin. It will add the exportDxf() method to the pattern object. This method will return the DXF-ASTM output.

import models from '@freesewing/models'
import Aaron from '@freesewing/aaron'
import exportDxfPlugin from '@freesewing/plugin-export-dxf'

const settings = {
  // Make sure to set complete to false
  complete: false,
  measurements: models.withoutBreasts.size42
}

let dxf = new Aaron(settings).use(exportDxfPlugin).draft().exportDxf()

Configuration

This plugin takes a configuration object as a second parameter to the pattern.use() method.

Precision

The precision property determines the length of the line segments used to approximate curves. The generated DXF-ASTM output will only contain straight lines, so curves will be approximated wiht lines segments.

The precision sets the length of those segments in mm. In the example below, the precision is set to 25 resulting in the use of line segments 25mm (1 inch) to approximate the curve.

let config = {
  precision: 25
}

let dxf = new Aaron(settings).use(exportDxfPlugin, config)

The default precision is 1, giving you 1mm long line segments to approximate curves.

Reasons to use this plugin

This plugin can export your pattern to DXF-ASTM so you can import it to your 3D software of choice.

Reasons to not use this plugin

Because DXF is inferior to SVG in every way

DXF (and DXF-AAMA and DXF-ASTM with it) are rooted in the world of industrial manufacturing. And it shows.

Nowadays, it's easy to think of the DXF file format as a bit of an embarassment.
But it is deliberatly kept dumb so that old industrial CNC milling machines, plotters, laster cutters and whatnot, can handle the format.

Because this plugin does not implement all of DXF

This plugin does the minimum to allow export of FreeSewing patterns into 3D garment tools. It expexts the input pattern to only include the outlines.

That means, no seam allowance, or titles, no notches, and so on.

Note: this is the last v2 minor release

We'll be moving to a new major version (v3) so this is the last minor release. We'll continue to support this while we work on v3, and backport important fixes.

Once v3 is out, we'll drop official support for v2.

What am I looking at? ๐Ÿค”

This repository is our monorepo holding all our NPM designs, plugins, other NPM packages, and (web)sites.

This folder holds: @freesewing/plugin-export-dxf

If you're not entirely sure what to do or how to start, type this command:

npm run tips

If you don't want to set up a dev environment, you can run it in your browser:

Open in Gitpod

We recommend that you fork our repository and then put gitpod.io/#<entire-url-of-your-fork into a browser to start up a browser-based dev environment of your own.

About FreeSewing ๐Ÿ’€

Where the world of makers and developers collide, that's where you'll find FreeSewing.

If you're a maker, checkout freesewing.org where you can generate our sewing patterns adapted to your measurements.

If you're a developer, our documentation is on freesewing.dev. Our core library is a batteries-included toolbox for parametric design of sewing patterns. But we also provide a range of plugins that further extend the functionality of the platform.

If you have NodeJS installed, you can try it right now by running:

npx create-freesewing-pattern

Or, consult our getting started guides for Linux, MacOS, or Windows.

We also have a pattern design tutorial that walks you through your first parametric design, and a friendly community with people who can help you when you get stuck.

Support FreeSewing: Become a patron ๐Ÿฅฐ

FreeSewing is an open source project run by a community, and financially supported by our patrons.

If you feel what we do is worthwhile, and you can spend a few coind without hardship, then you should join us and become a patron.

Links ๐Ÿ‘ฉโ€๐Ÿ’ป

License: MIT ๐Ÿค“

ยฉ Joost De Cock.
See the license file for details.

Where to get help ๐Ÿคฏ

Our chatrooms on Discord are the best place to ask questions, share your feedback, or just hang out.

If you want to report a problem, please create an issue.

Contributors โœจ

Thanks goes to these wonderful people (emoji key):

This project follows the all-contributors specification. Contributions of any kind welcome!

2.22.2

1 year ago

2.22.0-rc.0

2 years ago

2.22.1

2 years ago

2.22.0

2 years ago

2.21.4-rc.0

2 years ago

2.21.0

2 years ago

2.21.2

2 years ago

2.21.1

2 years ago

2.21.3-rc.0

2 years ago

2.21.0-alpha.0

2 years ago

2.21.3

2 years ago

2.21.0-rc.1

2 years ago

2.21.0-rc.2

2 years ago

2.21.0-rc.3

2 years ago

2.20.8

2 years ago

2.19.8

2 years ago

2.19.9

2 years ago

2.19.6

2 years ago

2.19.7

2 years ago

2.20.5-rc.0

2 years ago

2.20.4-rc.0

2 years ago

2.19.7-rc.0

2 years ago

2.20.2

2 years ago

2.20.3

2 years ago

2.20.0-rc.0

2 years ago

2.20.0

2 years ago

2.20.1

2 years ago

2.19.8-rc.0

2 years ago

2.20.6

2 years ago

2.20.7

2 years ago

2.20.4

2 years ago

2.20.5

2 years ago

2.19.4

3 years ago

2.19.5

2 years ago

2.19.2

3 years ago

2.19.3

3 years ago

2.19.1

3 years ago

2.19.0-rc.0

3 years ago

2.19.0

3 years ago

2.19.0-alpha.0

3 years ago

2.19.0-alpha.1

3 years ago

2.19.0-alpha.2

3 years ago

2.18.0-rc.2

3 years ago

2.18.0

3 years ago

2.18.0-rc.0

3 years ago

2.18.0-rc.1

3 years ago

2.17.4

3 years ago

2.17.3

3 years ago

2.17.3-rc.0

3 years ago

2.17.2

3 years ago

2.17.1

3 years ago

2.17.0

3 years ago

2.17.0-rc.2

3 years ago

2.17.0-rc.1

3 years ago

2.17.0-rc.0

3 years ago

2.16.1-rc.0

3 years ago

2.16.1

3 years ago

2.16.2

3 years ago

2.15.1-rc.1

3 years ago

2.15.1-rc.0

3 years ago

2.15.4

3 years ago

2.15.2

3 years ago

2.15.3

3 years ago

2.15.1

3 years ago

2.16.0-rc.1

3 years ago

2.16.0-rc.0

3 years ago

2.16.0

3 years ago

2.15.5-rc.1

3 years ago

2.15.0

3 years ago

2.15.0-rc.1

3 years ago

2.15.0-rc.0

3 years ago

2.14.0

3 years ago

2.14.0-rc.1

3 years ago

2.14.0-rc.0

3 years ago

2.13.2

3 years ago

2.13.1

3 years ago

2.13.0

3 years ago

2.13.0-rc.0

3 years ago

2.12.1

3 years ago

2.12.0

3 years ago

2.12.0-rc.0

3 years ago

2.11.3

3 years ago

2.11.1

3 years ago

2.11.2

3 years ago

2.11.0

3 years ago

2.11.0-rc.4

3 years ago

2.11.0-rc.3

3 years ago

2.11.0-rc.2

3 years ago

2.11.0-rc.1

3 years ago

2.11.0-rc.0

3 years ago

2.10.8-rc.1

3 years ago

2.10.8-rc.0

3 years ago

2.10.7

3 years ago

2.10.6

3 years ago

2.10.5

3 years ago

2.10.4

3 years ago

2.10.3

4 years ago

2.10.2

4 years ago

2.10.1

4 years ago

2.10.1-rc.0

4 years ago

2.10.0

4 years ago

2.10.0-rc.0

4 years ago

2.10.0-rc.1

4 years ago

2.9.0

4 years ago

2.9.0-rc.6

4 years ago

2.9.0-rc.5

4 years ago

2.9.0-rc.4

4 years ago

2.9.0-rc.3

4 years ago

2.9.0-rc.2

4 years ago

2.9.0-rc.1

4 years ago

2.9.0-rc.0

4 years ago

2.8.2-rc.0

4 years ago

2.8.1

4 years ago

2.8.1-rc.0

4 years ago

2.8.0-beta.1

4 years ago

2.8.0-beta.0

4 years ago

2.8.0

4 years ago

2.7.2

4 years ago

2.7.1

4 years ago

2.7.1-beta.1

4 years ago

2.7.1-beta.0

4 years ago

2.7.1-alpha.2

4 years ago

2.7.1-alpha.1

4 years ago

2.7.1-alpha.0

4 years ago

2.7.0

4 years ago

2.7.0-beta.3

4 years ago

2.7.0-beta.2

4 years ago

2.7.0-beta.1

4 years ago

2.7.0-beta.0

4 years ago

2.7.0-alpha.2

4 years ago

2.7.0-alpha.1

4 years ago

2.7.0-alpha.0

4 years ago

2.6.0

4 years ago

2.6.0-rc.1

4 years ago

2.6.0-rc.0

4 years ago