Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/jscad/openjscad.org
JSCAD is an open source set of modular, browser and command line tools for creating parametric 2D and 3D designs with JavaScript code. It provides a quick, precise and reproducible method for generating 3D models, and is especially useful for 3D printing applications.
https://github.com/jscad/openjscad.org
2d-design 3d-design 3mf amf csg dxf hacktoberfest javascript jscad modular monorepo obj openjscad stl svg x3d
Last synced: about 1 month ago
JSON representation
JSCAD is an open source set of modular, browser and command line tools for creating parametric 2D and 3D designs with JavaScript code. It provides a quick, precise and reproducible method for generating 3D models, and is especially useful for 3D printing applications.
- Host: GitHub
- URL: https://github.com/jscad/openjscad.org
- Owner: jscad
- License: mit
- Created: 2013-03-10T12:20:55.000Z (over 11 years ago)
- Default Branch: master
- Last Pushed: 2024-04-08T08:17:52.000Z (7 months ago)
- Last Synced: 2024-04-14T12:12:46.517Z (7 months ago)
- Topics: 2d-design, 3d-design, 3mf, amf, csg, dxf, hacktoberfest, javascript, jscad, modular, monorepo, obj, openjscad, stl, svg, x3d
- Language: JavaScript
- Homepage: https://openjscad.xyz/
- Size: 53.7 MB
- Stars: 2,506
- Watchers: 125
- Forks: 500
- Open Issues: 133
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- Contributing: CONTRIBUTING.md
- License: LICENSE
- Code of conduct: CODE_OF_CONDUCT.md
Awesome Lists containing this project
README
# JSCAD (previously known as OpenJSCAD)
>*JSCAD* is a set of modular, browser and command line tools for creating parametric 2D and 3D designs with JavaScript code.
There are many ways to use JSCAD:
An [online version](https://openjscad.xyz/), [self hostable web based ui](./packages/web), as [CLI](./packages/cli) (command-line interface) for server-side computations with Node.js, as well as an experimental [desktop app](./packages/desktop) or [individual Node.js packages](./packages/README.md)!!
This repository is a [monorepo](https://medium.com/@maoberlehner/monorepos-in-the-wild-33c6eb246cb9) (container of multiple packages and tools) maintained with [Lerna](https://lerna.js.org/)
[![Build Status](https://travis-ci.org/jscad/OpenJSCAD.org.svg?branch=master)](https://travis-ci.org/jscad/OpenJSCAD.org)
[![Stability](https://img.shields.io/badge/stability-stable-success)](https://github.com/emersion/stability-badges#stable)
[![All Dependencies](https://img.shields.io/librariesio/github/jscad/OpenJSCAD.org)](https://github.com/jscad/OpenJSCAD.org)[![User Group](https://img.shields.io/badge/maintained%20by-user%20group-blue)](https://openjscad.nodebb.com/)
[![Lerna](https://img.shields.io/badge/maintained%20with-lerna-blue)](https://lerna.js.org/)
[![JavaScript Style Guide](https://img.shields.io/badge/code_style-standard-blue)](https://standardjs.com)[![Backers](https://img.shields.io/opencollective/backers/openjscad)](https://opencollective.com/openjscad)
[![Sponsors](https://img.shields.io/opencollective/sponsors/openjscad)](https://opencollective.com/openjscad)## Table of Contents
- [Usage](#usage)
- [Documentation](#documentation)
- [Contributing](#contributing)
- [Community](#community)
- [Acknowledgements](#acknowledgements)
- [Backers](#backers)
- [Sponsors](#sponsors)
- [License](#license)
- [See also](#see-also)## Usage
There are different 'flavors' of JSCAD that you can use based on your needs
- web: online (no install) simply go to [https://openjscad.xyz/](https://openjscad.xyz/)
- web: self hosted: can be found [here](./packages/web)
- cli: command line interface : can be found [here](./packages/cli)
- desktop app: pre pre alpha work in progress can be found [here](./packages/desktop)!
- node.js: custom mix and match of packages
* all the packages are available [on NPM](https://www.npmjs.com/search?q=%40jscad) under the '@jscad' name### Immediate Use (no installation)
Go to *[OpenJSCAD.xyz](https://openjscad.xyz)* (Tested browsers include Chrome, Edge, Firefox, Opera, Safari)
### Use within a Web Site (pre built files, from GitHub)
Please see [here for details](./packages/web/README.md)
### Use as Command Line Interface (CLI)
Please see [here for details](./packages/cli/README.md)
### Use of components and viewer in websites
Please see [here for details](./packages/utils/regl-renderer/README.md)
### Use of the different modular components directly
From version 1.0.0 onwards, almost all the individual parts of this project are available
directly as scoped NPM packages, and can be used independently from the main repository.
The full list of these is available [here](./packages/README.md) and [here](https://www.npmjs.com/org/jscad)One example of what can be achieved with this can be found [here](https://esnextb.in/?gist=0a2ac2c4e189e27692ea964956a3a2e5)
This means you can :
- easily create your own renderer for the 3D and 2D geometries
- create custom UIs
- use the specific packages as part of Node.js or Browserify projects
- cherry pick formats you want to use for input/output without needing the dependencies of **all** packages
- lots more !This will be expanded upon in the future, and is the backbone of the newer, modular JSCAD project.
## Documentation
- [JSCAD User Guide](https://openjscad.xyz/guide.html)
- [API Reference](https://openjscad.xyz/docs/)## Contributing
The various JSCAD packages and all source code are part of the JSCAD Organization, and maintained by a group of volunteers.
We welcome and encourage anyone to pitch in but please take a moment to read the following guidelines.* If you want to submit a bug report please make sure to follow the [Reporting Issues](https://github.com/jscad/OpenJSCAD.org/wiki/Reporting-Issues) guide. Bug reports are accepted as [Issues](https://github.com/jscad/OpenJSCAD.org/issues/) via GitHub.
* If you want to submit a change or a patch, please read the [Contributing Guide](./CONTRIBUTING.md). New contributions are accepted as [Pull Requests](https://github.com/jscad/OpenJSCAD.org/pulls/) via GitHub.
* We only accept bug reports and pull requests on **GitHub**.
* If you have a question about how to use JSCAD, then please start a conversation at the [JSCAD User Group](https://openjscad.xyz/forum.html). You might find the answer in the [JSCAD User Guide](https://openjscad.xyz/guide.html).
* If you have a change or new feature in mind, please start a conversation with the [Core Developers](https://openjscad.xyz/forum.html) and start contributing changes.
Small Note: If editing this README, please conform to the [standard-readme](https://github.com/RichardLitt/standard-readme) specification.
A BIG THANKS to all the people who have already contributed to the JSCAD project!
## Community
Discuss designs or issues
* [JSCAD User Group](https://openjscad.xyz/forum.html)Or chat with other users
* [Discord Community](https://openjscad.xyz/discord.html)HUGE THANKS and SHOUTOUT to [nodeBB](https://nodebb.org/) for hosting our (awesome) forum for free ! Thanks a lot !
## Acknowledgements
JSCAD and all sub components are built upon great open source packages, and contributions.
Early CSG Library by:
- Evan Wallace,
- Eduard Bespalov,
- Joost Nieuwenhuijse,
- Alexandre GirardXML parsing:
- [sax](https://github.com/isaacs/sax-js)Tooling:
- [browserify](https://browserify.org/)
- [babel](https://babeljs.io/)and many more!
## Backers
Thank you to all our backers! 🙏 [[Become a backer](https://opencollective.com/openjscad#backer)]
## Sponsors
This project has some awesome sponsors! [[Become a sponsor](https://opencollective.com/openjscad#sponsor)]
Your logo will show up here with a link to your website.## License
[The MIT License (MIT)](./LICENSE)
(unless specified otherwise)## See Also
- [OpenJsCAD](https://joostn.github.io/OpenJsCad/), starting point of JSCAD
- [OpenSCAD.net](https://garyhodgson.github.io/openscad.net/), another place of inspiration, where the OpenSCAD translator was adapted fromThat's all for now,
The JSCAD Organization