JSPM

@thi.ng/geom-splines

2.2.46
  • ESM via JSPM
  • ES Module Entrypoint
  • Export Map
  • Keywords
  • License
  • Repository URL
  • TypeScript Types
  • README
  • Created
  • Published
  • Downloads 796
  • Score
    100M100P100Q110658F
  • License Apache-2.0

nD cubic & quadratic curve analysis, conversion, interpolation, splitting

Package Exports

  • @thi.ng/geom-splines
  • @thi.ng/geom-splines/cubic-arc
  • @thi.ng/geom-splines/cubic-bounds
  • @thi.ng/geom-splines/cubic-closest-point
  • @thi.ng/geom-splines/cubic-from-breakpoints
  • @thi.ng/geom-splines/cubic-from-controlpoints
  • @thi.ng/geom-splines/cubic-line
  • @thi.ng/geom-splines/cubic-quadratic
  • @thi.ng/geom-splines/cubic-sample
  • @thi.ng/geom-splines/cubic-split
  • @thi.ng/geom-splines/cubic-tangent
  • @thi.ng/geom-splines/point-at
  • @thi.ng/geom-splines/quadratic-bounds
  • @thi.ng/geom-splines/quadratic-closest-point
  • @thi.ng/geom-splines/quadratic-line
  • @thi.ng/geom-splines/quadratic-sample
  • @thi.ng/geom-splines/quadratic-split
  • @thi.ng/geom-splines/quadratic-tangent

Readme

@thi.ng/geom-splines

npm version npm downloads Mastodon Follow

This project is part of the @thi.ng/umbrella monorepo and anti-framework.

About

nD cubic & quadratic curve analysis, conversion, interpolation, splitting. This is a support package for @thi.ng/geom.

Current implementations partially based on toxiclibs (Java) and Clojure version of thi.ng/geom.

Status

STABLE - used in production

Search or submit any issues for this package

Installation

yarn add @thi.ng/geom-splines

ES module import:

<script type="module" src="https://cdn.skypack.dev/@thi.ng/geom-splines"></script>

Skypack documentation

For Node.js REPL:

const geomSplines = await import("@thi.ng/geom-splines");

Package sizes (brotli'd, pre-treeshake): ESM: 2.38 KB

Dependencies

Usage examples

Several demos in this repo's /examples directory are using this package.

A selection:

Screenshot Description Live demo Source
Polygon to cubic curve conversion & visualization Demo Source

API

Generated API docs

Cubic curve conversion from polygons & polylines

Currently, there're two ways to convert a polygon/polyline into a sequence of cubic curve segments. Both modes support customizable curve tightness.

Furthermore, both conversion modes can be instructed to use uniformly scaled control point tangents: In uniform mode, the tangents have a uniform, user defined length, resulting in equidistant control points for each poly vertex. In non-uniform mode, each tangent is scaled by the length of its parent poly edge.

Poly vertices as control points

In this mode the curve always goes through the midpoints each polygon edge, with the original polygon vertices being used to compute control points.

Proportional tangent scale Uniform tangent scale

Poly vertices as break points

In this mode the curve always goes through the original polygon vertices and additional control points are created via symmetric tangents at each poly vertex. The tangents themselves are computed via the bisector of each vertex corner, taking into the convexity of each poly vertex.

Proportional tangent scale Uniform tangent scale

Authors

If this project contributes to an academic publication, please cite it as:

@misc{thing-geom-splines,
  title = "@thi.ng/geom-splines",
  author = "Karsten Schmidt",
  note = "https://thi.ng/geom-splines",
  year = 2016
}

License

© 2016 - 2023 Karsten Schmidt // Apache License 2.0