11 releases (7 breaking)

0.8.0 Oct 19, 2023
0.7.3 Mar 16, 2022
0.7.1 Nov 13, 2021
0.7.0 Jul 10, 2021
0.1.0 Aug 19, 2019

#397 in Algorithms

Download history 1756/week @ 2024-09-13 1991/week @ 2024-09-20 1476/week @ 2024-09-27 1912/week @ 2024-10-04 1940/week @ 2024-10-11 1657/week @ 2024-10-18 1873/week @ 2024-10-25 1937/week @ 2024-11-01 2184/week @ 2024-11-08 2781/week @ 2024-11-15 2368/week @ 2024-11-22 2924/week @ 2024-11-29 2752/week @ 2024-12-06 2522/week @ 2024-12-13 686/week @ 2024-12-20 380/week @ 2024-12-27

7,184 downloads per month
Used in 7 crates

ISC license

45KB
1K SLoC

geo-clipper

This crate allows to perform boolean and offset operations on polygons.

crate.io docs.rs

It makes use of clipper-sys which is a binding to the C++ version of Clipper.

Example

The following example shows how to compute the intersection of two polygons. The intersection method (as well as difference, union and xor) is provided by the Clipper trait which is implemented for some geo-types.

use geo_types::{Coord, LineString, Polygon};
use geo_clipper::Clipper;

let subject = Polygon::new(
    LineString(vec![
        Coord { x: 180.0, y: 200.0 },
        Coord { x: 260.0, y: 200.0 },
        Coord { x: 260.0, y: 150.0 },
        Coord { x: 180.0, y: 150.0 },
    ]),
    vec![LineString(vec![
        Coord { x: 215.0, y: 160.0 },
        Coord { x: 230.0, y: 190.0 },
        Coord { x: 200.0, y: 190.0 },
    ])],
);

let clip = Polygon::new(
    LineString(vec![
        Coord { x: 190.0, y: 210.0 },
        Coord { x: 240.0, y: 210.0 },
        Coord { x: 240.0, y: 130.0 },
        Coord { x: 190.0, y: 130.0 },
    ]),
    vec![],
);

let result = subject.intersection(&clip, 1.0);

Dependencies

~0.8–1.2MB
~26K SLoC