Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/AndrewSink/3D-Low-Poly-Generator
3D Low Poly Generator / Mesh Decimation Tool
https://github.com/AndrewSink/3D-Low-Poly-Generator
Last synced: 2 months ago
JSON representation
3D Low Poly Generator / Mesh Decimation Tool
- Host: GitHub
- URL: https://github.com/AndrewSink/3D-Low-Poly-Generator
- Owner: AndrewSink
- License: mit
- Created: 2021-11-27T16:12:57.000Z (about 3 years ago)
- Default Branch: main
- Last Pushed: 2022-07-31T16:02:20.000Z (over 2 years ago)
- Last Synced: 2023-11-07T17:23:32.764Z (about 1 year ago)
- Language: JavaScript
- Size: 20.8 MB
- Stars: 132
- Watchers: 5
- Forks: 18
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
- awesome - AndrewSink/3D-Low-Poly-Generator - 3D Low Poly Generator / Mesh Decimation Tool (JavaScript)
- awesome - AndrewSink/3D-Low-Poly-Generator - 3D Low Poly Generator / Mesh Decimation Tool (JavaScript)
README
# 3D Low Poly Generator / Mesh Decimation Tool
Try it out: [3D Low Poly Generator](https://lowpoly3d.xyz/)
Find this project useful? You can buy me a [coffee on Ko-Fi](https://ko-fi.com/andrewsink)!
The 3D Low Poly Generator lets you import an .STL file and create a low poly masterpiece of your own, perfect for 3D printing! The entire process is done in-browser using [three.js](https://threejs.org/), so there's no additional software to load or learn. Just upload a file and start experimenting!
## Usage
The 'Triangle Reduction %' slider will adjust the overall amount of decimation. A higher number will result in a higher number of triangles removed.
Example:
Triangle Reduction 30%: 30% of triangles removed
Triangle Reduction 5%: 5% of triangles removed### Commands
**Decimate:** Updates current mesh with requested triangle reduction
**Reset:** Resets current mesh to original triangle count
**Export STL:** Exports an .stl with the current triangle count
**Export OBJ:** Exports an .obj with the current triangle count## How it works
The 3D Low Poly Generator uses the Simplifymodifier.js class to reduce a mesh by a set number of triangles.
## Time Estimation
The implementation of a time estimate was my wife's idea (thanks Erica!), and it makes the whole project feel more complete. Because the interface becomes unresponsive during processing and there is no progress bar, the time estimation can be used to know if a mesh *should* be finished after a certain amount of time.
I ran the 3D Low Poly Generator using several different models at various levels of triangle reduction, and logged the time and number of triangles reduced. The average I calculated was .00267 seconds per triangle removed.
This variable is used to calculate the overall amount of time required to reduce a mesh by a given number of triangles.
>var currentTri = currentTriangles
>var targetTri = currentTriangles - (Math.floor((decimatePercentage* currentTriangles)))
>var time = Math.floor((decimatePercentage * currentTriangles) * .00267)It's not 100% accurate, but it is able to give a good indication of the general amount of time required to process a mesh, as well as estimating how many triangles will be removed.
Read more here: https://3dwithus.com/low-poly-generator-reduce-stl-file-size-and-create-art