Bremersee GeoJSON

This project contains classes for reading and writing GeoJSON with the Jackson JSON Processor.

License

License

Categories

Categories

Geo Business Logic Libraries Geospatial JSON Data
GroupId

GroupId

org.bremersee
ArtifactId

ArtifactId

bremersee-geojson
Last Version

Last Version

2.0.0
Release Date

Release Date

Type

Type

jar
Description

Description

Bremersee GeoJSON
This project contains classes for reading and writing GeoJSON with the Jackson JSON Processor.
Project Organization

Project Organization

bremersee.org

Download bremersee-geojson

How to add to project

<!-- https://jarcasting.com/artifacts/org.bremersee/bremersee-geojson/ -->
<dependency>
    <groupId>org.bremersee</groupId>
    <artifactId>bremersee-geojson</artifactId>
    <version>2.0.0</version>
</dependency>
// https://jarcasting.com/artifacts/org.bremersee/bremersee-geojson/
implementation 'org.bremersee:bremersee-geojson:2.0.0'
// https://jarcasting.com/artifacts/org.bremersee/bremersee-geojson/
implementation ("org.bremersee:bremersee-geojson:2.0.0")
'org.bremersee:bremersee-geojson:jar:2.0.0'
<dependency org="org.bremersee" name="bremersee-geojson" rev="2.0.0">
  <artifact name="bremersee-geojson" type="jar" />
</dependency>
@Grapes(
@Grab(group='org.bremersee', module='bremersee-geojson', version='2.0.0')
)
libraryDependencies += "org.bremersee" % "bremersee-geojson" % "2.0.0"
[org.bremersee/bremersee-geojson "2.0.0"]

Dependencies

compile (3)

Group / Artifact Type Version
org.bremersee : common-model jar 1.1.0
org.locationtech.jts : jts-core jar 1.16.0
org.projectlombok : lombok Optional jar

test (1)

Group / Artifact Type Version
junit : junit jar

Project Modules

There are no modules declared in this project.

Bremersee GeoJSON

codecov

This project contains modules for reading and writing GeoJSON. The GeoJSON format is specified in rfc7946.

Maven Site

Usage

GeoJSON can be read or written with adding the GeoJsonObjectMapperModule to the ObjectMapper or without.

Without adding the GeoJsonObjectMapperModule to the ObjectMapper

If you do not add the GeoJsonObjectMapperModule to the ObjectMapper, you'll have to use the GeometryWrapper:

public class Example {
  
  public static void main(String[] args) {
    ObjectMapper om = new ObjectMapper();
    Point p = GeometryUtils.createPoint(10.2, 52.4);
    GeometryWrapper gw = new GeometryWrapper(p);
    String json = om.writeValueAsString(gw);
    System.out.println(json);
  }
}

GeoJsonFeature and GeoJsonFeatureCollection can be used without adding the module to the object mapper, too.

public class Example {
  
  public static void main(String[] args) {
    ObjectMapper om = new ObjectMapper();
    Point p = GeometryUtils.createPoint(10.2, 52.4);
    GeoJsonFeature f = new GeoJsonFeature("id", p, false, null);
    String json = om.writeValueAsString(f);
    System.out.println(json);
  }
}
With adding the GeoJsonObjectMapperModule to the ObjectMapper

If you add the GeoJsonObjectMapperModule to the ObjectMapper, you'll be able to process the geometry object directly:

public class Example {
  
  public static void main(String[] args) {
    ObjectMapper om = new ObjectMapper();
    om.registerModule(new GeoJsonObjectMapperModule());
    Point p = GeometryUtils.createPoint(10.2, 52.4);
    String json = om.writeValueAsString(p);
    System.out.println(json);
  }
}

Spring Data MongoDB Support

If you want to persist the JTS geometry objects to a MongoDB with Spring Data you'll have to register these converters:

@Configuration
public class PersistenceConfiguration {

  @Primary
  @Bean
  public MongoCustomConversions customConversions() {
    final List<Object> converters = new ArrayList<>(
        GeoJsonConverters.getConvertersToRegister(null));
    // add more custom converters
    return new MongoCustomConversions(converters);
  }
}

An entity may look like this:

@Document(collection = "feature")
@TypeAlias("Route")
public class RouteEntity {

  @Id
  private String id;

  @GeoSpatialIndexed(type = GeoSpatialIndexType.GEO_2DSPHERE)
  private MultiLineString geometry; // this is org.locationtech.jts.geom.MultiLineString

  private double[] bbox;

  private RouteProperties properties;

  // getter and setter
}

Versions

Version
2.0.0
1.1.3
1.1.2
1.1.1
1.1.0