data:image/s3,"s3://crabby-images/375b7/375b7b320e8e077950fecffb1efc0697cf3e3d60" alt="@thi.ng/geom-subdiv-curve"
data:image/s3,"s3://crabby-images/40b03/40b0301827effcc0b18012a6ea4ec12c32aacf2f" alt="Mastodon Follow"
[!NOTE]
This is one of 198 standalone projects, maintained as part
of the @thi.ng/umbrella monorepo
and anti-framework.
🚀 Please help me to work full-time on these projects by sponsoring me on
GitHub. Thank you! ❤️
About
Freely customizable, iterative nD subdivision curves for open / closed geometries. This is a support package for @thi.ng/geom.
Based in principle on:
Available subdivision schemes
The following schemes are available as presets and their effects illustrated.
Chaikin subdivision
SUBDIV_CHAIKIN
is supported for open & closed geometries.
data:image/s3,"s3://crabby-images/8f944/8f94408cfa82af8edc1bd08a8083a0bd358538ea" alt="SUBDIV_CHAIKIN preset on open geometry"
data:image/s3,"s3://crabby-images/16163/16163822d48520d04710dca491e1601050180c2e" alt="SUBDIV_CHAIKIN preset on closed geometry"
Cubic subdivision
SUBDIV_CUBIC
is only supported for closed geometries (at current).
data:image/s3,"s3://crabby-images/1490b/1490b9650808dfaeb0ba5c7cc0f48f2526dd68d3" alt="SUBDIV_CUBIC preset on closed geometry"
Dyn-Levin-Gregory subdivision
SUBDIV_DLG
is only supported for closed geometries (at current).
data:image/s3,"s3://crabby-images/fd27a/fd27a3b348049ad20d60f00b4cff7eede6361383" alt="SUBDIV_DLG preset on closed geometry"
Displacement subdivision
SUBDIV_DISPLACE
is a higher order, customizable subdivision and supported for open & closed geometries.
data:image/s3,"s3://crabby-images/bb27c/bb27cdc09caace200c98e6d1421828be34d5efe8" alt="SUBDIV_DISPLACE preset on open geometry"
data:image/s3,"s3://crabby-images/c9fdc/c9fdcfedbcf6db1860aa7d0675f58eb5aa3e716a" alt="SUBDIV_DISPLACE preset on closed geometry"
Split at midpoints
SUBDIV_MID
is supported for open & closed geometries.
data:image/s3,"s3://crabby-images/4f208/4f208ab735595e8375d0bdb1e0562b32734b2cf8" alt="SUBDIV_MID preset on open geometry"
data:image/s3,"s3://crabby-images/d49ce/d49ce107c7f74c02b761c50be6c4a3465a156790" alt="SUBDIV_MID preset on closed geometry"
Split at thirds
SUBDIV_THIRDS
is supported for open & closed geometries.
data:image/s3,"s3://crabby-images/7c58b/7c58b3880c105b85046b629a819464bf42c30930" alt="SUBDIV_THIRDS preset on open geometry"
data:image/s3,"s3://crabby-images/e08a3/e08a318636f556566e6fe036991ad21286e9afd1" alt="SUBDIV_THIRDS preset on closed geometry"
Status
STABLE - used in production
Search or submit any issues for this package
Related packages
Installation
yarn add @thi.ng/geom-subdiv-curve
ESM import:
import * as gsc from "@thi.ng/geom-subdiv-curve";
Browser ESM import:
<script type="module" src="https://esm.run/@thi.ng/geom-subdiv-curve"></script>
JSDelivr documentation
For Node.js REPL:
const gsc = await import("@thi.ng/geom-subdiv-curve");
Package sizes (brotli'd, pre-treeshake): ESM: 801 bytes
Dependencies
API
Generated API docs
import * as gsc from "@thi.ng/geom-subdiv-curve";
gsc.subdivide([[0,0], [100,0], [100,100], [0,100]], [gsc.SUBDIV_CHAIKIN], true);
Authors
If this project contributes to an academic publication, please cite it as:
@misc{thing-geom-subdiv-curve,
title = "@thi.ng/geom-subdiv-curve",
author = "Karsten Schmidt",
note = "https://thi.ng/geom-subdiv-curve",
year = 2016
}
License
© 2016 - 2024 Karsten Schmidt // Apache License 2.0