Giter VIP home page Giter VIP logo

libgeos.jl's Introduction

LibGEOS.jl

CI codecov

LibGEOS is a package for manipulation and analysis of planar geometric objects, based on the libraries GEOS (the engine of PostGIS) and JTS (from which GEOS is ported). This package wraps the GEOS C API, see its usage and reference docs.

Among other things, it allows you to parse Well-known Text (WKT).

p1 = readgeom("POLYGON((0 0,1 0,1 1,0 0))")
p2 = readgeom("POLYGON((0 0,1 0,1 1,0 1,0 0))")
p3 = readgeom("POLYGON((2 0,3 0,3 1,2 1,2 0))")

Example 1

Add a buffer around them

g1 = buffer(p1, 0.5)
g2 = buffer(p2, 0.5)
g3 = buffer(p3, 0.5)

Example 2

and take the union of different geometries

polygon = LibGEOS.union(g1, g3)

Example 3

GEOS functionality is extensive, so coverage is incomplete, but the basic functionality for working with geospatial data is already available. I'm learning as I go along, so documentation is lacking, but if you're interested, you can have a look at the examples in the examples/ folder, or the tests in test/test_geo_interface.jl and test/test_geos_operations.jl.

Conversion to/from GeoInterface objects

GeoInterface.jl compatible geometries from many packages including GeometryBasics.jl, Shapefile.jl, GeoJSON.jl, KML.jl, ArchGDAL.jl, GADM.jl and others can be easily converted to LibGEOS geometries using:

GeoInterface.convert(LibGEOS, other_package_geometry)

To broadcast this over a vector or iterable we need to use Ref on LibGEOS:

GeoInterface.convert.(Ref(LibGEOS), iterable_of_geometries)

The same applies in reverse, such as for interop with the Makie.jl/GeometryBasics.jl ecosystem:

GeoInterface.convert(GeometryBasics, libgeos_geometry)

For packages like Shapefile.jl and GeoJSON.jl, converting to their objects isn't possible, as theyre not particularly useful on their own. Instead, we can just write directly:

Shapefile.write("myfile.shp", libgeos_geometry)

GeoInterface methods

GeoInterace.jl OGC standards methods work on LibGEOS objects:

  • GeoInterface.distance
  • GeoInterface.buffer
  • GeoInterface.convexhull
  • GeoInterface.equals
  • GeoInterface.disjoint
  • GeoInterface.intersects
  • GeoInterface.touches
  • GeoInterface.within
  • GeoInterface.contains
  • GeoInterface.overlaps
  • GeoInterface.crosses
  • GeoInterface.symdifference
  • GeoInterface.difference
  • GeoInterface.intersection
  • GeoInterface.union

See the GeoInterface.jl API docs for details.

Exported LibGEOS geometries:

  • GeometryCollection
  • LineString
  • LinearRing
  • MultiLineString
  • MultiPoint
  • MultiPolygon
  • Point
  • Polygon
  • STRtree

Exported LibGEOS functions:

  • area
  • boundary
  • buffer
  • bufferWithStyle
  • centroid
  • constrainedDelaunayTriangulation
  • containsproperly
  • convexhull
  • coveredby
  • covers
  • crosses
  • delaunayTriangulation
  • delaunayTriangulationEdges
  • difference
  • disjoint
  • distance
  • endPoint
  • envelope
  • equals
  • equalsexact
  • exteriorRing
  • geomLength
  • getGeometries
  • getGeometry
  • getPrecision
  • getXMax
  • getXMin
  • getYMax
  • getYMin
  • hasZ
  • hausdorffdistance
  • interiorRing
  • interiorRings
  • interpolate
  • interpolateNormalized
  • intersection
  • intersects
  • isClosed
  • isEmpty
  • isRing
  • isSimple
  • isValid
  • lineMerge
  • minimumRotatedRectangle
  • nearestPoints
  • node
  • numGeometries
  • numPoints
  • overlaps
  • pointOnSurface
  • polygonize
  • prepareGeom
  • project
  • projectNormalized
  • query
  • readgeom
  • setPrecision
  • sharedPaths
  • simplify
  • snap
  • startPoint
  • symmetricDifference
  • topologyPreserveSimplify
  • touches
  • unaryUnion
  • union
  • uniquePoints
  • within
  • writegeom

Installation

  1. At the Julia prompt, run
pkg> add LibGEOS

This will install both the Julia package and GEOS shared libraries together. The GEOS build comes from GEOS_jll, and the build script can be found in Yggdrasil.

  1. Test that LibGEOS works by runnning
pkg> test LibGEOS

Ecosystem

  • All GeoInterface.jl compatible geometries will work in LibGEOS without conversion.
  • Makie support for LibGEOS is available via LibGEOSMakie.jl
  • LibGEOS integrates with GeoInterface.jl making it easy to combine LibGEOS with other geometry packages.

libgeos.jl's People

Contributors

visr avatar yeesian avatar jw3126 avatar mathieu17g avatar jaakkor2 avatar evetion avatar rafaqz avatar nraynaud avatar garborg avatar skygering avatar omritreidel avatar github-actions[bot] avatar dependabot[bot] avatar melonedo avatar meggart avatar alex-s-gardner avatar staticfloat avatar felixcremer avatar juliatagbot avatar maxfreu avatar simondanisch avatar tkelman avatar

Watchers

Alejandro Quirós Rodríguez avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.