{{pkg.description}}
Current implementation is partially based on toxiclibs (Java) and Clojure version thi.ng/geom-clj. Also see @thi.ng/geom-clip-poly sister package.
The following main functions are provided:
{{meta.status}}
{{repo.supportPackages}}
{{repo.relatedPackages}}
{{meta.blogPosts}}
{{pkg.install}}
{{pkg.size}}
{{pkg.deps}}
{{repo.examples}}
{{pkg.docs}}
import { clipPolylinePoly, liangBarsky2 } from "@thi.ng/geom-clip-line";
clipPolylinePoly(
// polyline vertices
[[10, -50], [30, 30], [-50, 50], [150, 50], [70, 70], [90, 150]],
// boundary polygon vertices
[[0, 0], [100, 0], [100, 100], [0, 100]]
);
// result is 3 polylines:
// (since the original is temporarily leaving the poly)
// [
// [ [ 22.5, 0 ], [ 30, 30 ], [ 0, 37.5 ] ],
// [ [ 0, 50 ], [ 100, 50 ] ],
// [ [ 100, 62.5 ], [ 70, 70 ], [ 77.5, 100 ] ]
// ]
// Liang-Barsky is optimized for rectangular clipping regions
liangBarsky2(
// line end points
[-10, -20], [30, 400],
// min/max clip rect
[0, 0], [100, 200]
)
// [ [ 0, 85 ], [ 10.952380952380953, 200 ], 0.25, 0.5238095238095238 ]
// returns undefined if line is completely outside the clip rect
liangBarsky2(
// line end points
[-10, -20], [-30, 400],
// min/max bbox
[0, 0], [100, 200]
)
// undefined