Popularity
7.0
Declining
Activity
8.8
Growing
597
36
73

Programming language: Rust
Tags: Geospatial    
Latest version: v0.14.0

GeoRust alternatives and similar packages

Based on the "Geospatial" category

Do you think we are missing an alternative of GeoRust or a related project?

Add another 'Geospatial' Package

README

geo

Build Status geo on Crates.io Coverage Status

geo

Geospatial Primitives, Algorithms, and Utilities

The geo crate provides geospatial primitive types such as Point, LineString, and Polygon, and provides algorithms and operations such as:

  • Area and centroid calculation
  • Simplification and convex hull operations
  • Euclidean and Haversine distance measurement
  • Intersection checks
  • Affine transforms such as rotation and translation.

Please refer to the documentation for a complete list.

The primitive types also provide the basis for other functionality in the Geo ecosystem, including:

Example

use geo::{line_string, polygon};
use geo::convex_hull::ConvexHull;

// An L shape
let poly = polygon![
    (x: 0.0, y: 0.0),
    (x: 4.0, y: 0.0),
    (x: 4.0, y: 1.0),
    (x: 1.0, y: 1.0),
    (x: 1.0, y: 4.0),
    (x: 0.0, y: 4.0),
    (x: 0.0, y: 0.0),
];

// Calculate the polygon's convex hull
let hull = poly.convex_hull();

assert_eq!(hull.exterior(), line_string![
    (x: 0.0, y: 0.0),
    (x: 0.0, y: 4.0),
    (x: 1.0, y: 4.0),
    (x: 4.0, y: 1.0),
    (x: 4.0, y: 0.0),
    (x: 0.0, y: 0.0),
]);

Contributing

Contributions are welcome! Have a look at the issues, and open a pull request if you'd like to add an algorithm or some functionality.

License

Licensed under either of

at your option.

Contribution

Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in the work by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions.


*Note that all licence references and agreements mentioned in the GeoRust README section above are relevant to that project's source code only.