use of org.openstreetmap.osmosis.core.domain.v0_6.Node in project GeoGig by boundlessgeo.
the class EntityConverter method toEntity.
/**
* Converts a Feature to a OSM Entity
*
* @param feature the feature to convert
* @param replaceId. The changesetId to use in case the feature has a negative one indicating a
* temporary value
* @return
*/
public Entity toEntity(SimpleFeature feature, Long changesetId) {
Entity entity;
SimpleFeatureType type = feature.getFeatureType();
long id = Long.parseLong(feature.getID());
int version = ((Integer) feature.getAttribute("version")).intValue();
Long changeset = (Long) feature.getAttribute("changeset");
if (changesetId != null && changeset < 0) {
changeset = changesetId;
}
Long milis = (Long) feature.getAttribute("timestamp");
Date timestamp = new Date(milis);
String user = (String) feature.getAttribute("user");
String[] userTokens = user.split(":");
OsmUser osmuser;
try {
osmuser = new OsmUser(Integer.parseInt(userTokens[1]), userTokens[0]);
} catch (Exception e) {
osmuser = OsmUser.NONE;
}
String tagsString = (String) feature.getAttribute("tags");
Collection<Tag> tags = OSMUtils.buildTagsCollectionFromString(tagsString);
CommonEntityData entityData = new CommonEntityData(id, version, timestamp, osmuser, changeset, tags);
if (type.equals(OSMUtils.nodeType())) {
Point pt = (Point) feature.getDefaultGeometryProperty().getValue();
entity = new Node(entityData, pt.getY(), pt.getX());
} else {
List<WayNode> nodes = Lists.newArrayList();
String nodesString = (String) feature.getAttribute("nodes");
for (String s : nodesString.split(";")) {
nodes.add(new WayNode(Long.parseLong(s)));
}
entity = new Way(entityData, nodes);
}
return entity;
}
use of org.openstreetmap.osmosis.core.domain.v0_6.Node in project GeoGig by boundlessgeo.
the class EntityConverter method toFeature.
public SimpleFeature toFeature(Entity entity, Geometry geom) {
SimpleFeatureType ft = entity instanceof Node ? OSMUtils.nodeType() : OSMUtils.wayType();
SimpleFeatureBuilder builder = new SimpleFeatureBuilder(ft, FEATURE_FACTORY);
// TODO: Check this!
builder.set("visible", Boolean.TRUE);
builder.set("version", Integer.valueOf(entity.getVersion()));
builder.set("timestamp", Long.valueOf(entity.getTimestamp().getTime()));
builder.set("changeset", Long.valueOf(entity.getChangesetId()));
String tags = OSMUtils.buildTagsString(entity.getTags());
builder.set("tags", tags);
String user = entity.getUser().getName() + ":" + Integer.toString(entity.getUser().getId());
builder.set("user", user);
if (entity instanceof Node) {
builder.set("location", geom);
} else if (entity instanceof Way) {
builder.set("way", geom);
String nodes = buildNodesString(((Way) entity).getWayNodes());
builder.set("nodes", nodes);
} else {
throw new IllegalArgumentException();
}
String fid = String.valueOf(entity.getId());
SimpleFeature simpleFeature = builder.buildFeature(fid);
return simpleFeature;
}
use of org.openstreetmap.osmosis.core.domain.v0_6.Node in project bboxdb by jnidzwetzki.
the class OSMDataConverter method handleWay.
/**
* Handle a way
* @param entityContainer
*/
protected void handleWay(final Way way) {
try {
for (final OSMType osmType : filter.keySet()) {
final OSMTagEntityFilter entityFilter = filter.get(osmType);
if (entityFilter.match(way.getTags())) {
final Polygon geometricalStructure = new Polygon(way.getId());
for (final Tag tag : way.getTags()) {
geometricalStructure.addProperty(tag.getKey(), tag.getValue());
}
// Perform search async
for (final WayNode wayNode : way.getWayNodes()) {
final SerializableNode node = osmNodeStore.getNodeForId(wayNode.getNodeId());
geometricalStructure.addPoint(node.getLatitude(), node.getLongitude());
}
writePolygonToOutput(osmType, geometricalStructure);
}
}
} catch (Exception e) {
throw new RuntimeException(e);
}
}
use of org.openstreetmap.osmosis.core.domain.v0_6.Node in project bboxdb by jnidzwetzki.
the class OSMDataConverter method handleNode.
/**
* Handle a node
* @param entityContainer
*/
protected void handleNode(final Node node) {
try {
for (final OSMType osmType : filter.keySet()) {
final OSMTagEntityFilter entityFilter = filter.get(osmType);
if (entityFilter.match(node.getTags())) {
final Polygon geometricalStructure = new Polygon(node.getId());
geometricalStructure.addPoint(node.getLatitude(), node.getLongitude());
for (final Tag tag : node.getTags()) {
geometricalStructure.addProperty(tag.getKey(), tag.getValue());
}
writePolygonToOutput(osmType, geometricalStructure);
}
}
osmNodeStore.storeNode(node);
} catch (Exception e) {
throw new RuntimeException(e);
}
}
use of org.openstreetmap.osmosis.core.domain.v0_6.Node in project bboxdb by jnidzwetzki.
the class OSMDataConverter method start.
/**
* Start the converter
*/
public void start() {
try {
// Open file handles
for (final OSMType osmType : filter.keySet()) {
final BufferedWriter bw = new BufferedWriter(new FileWriter(new File(output + File.separator + osmType.toString())));
writerMap.put(osmType, bw);
}
System.out.format("Importing %s%n", filename);
final OsmosisReader reader = new OsmosisReader(new FileInputStream(filename));
reader.setSink(new Sink() {
@Override
public void close() {
}
@Override
public void complete() {
}
@Override
public void initialize(final Map<String, Object> metaData) {
}
@Override
public void process(final EntityContainer entityContainer) {
try {
if (entityContainer.getEntity() instanceof Node) {
// Nodes are cheap to handle, dispatching to another thread
// is more expensive
final Node node = (Node) entityContainer.getEntity();
handleNode(node);
statistics.incProcessedNodes();
} else if (entityContainer.getEntity() instanceof Way) {
// Ways are expensive to handle
final Way way = (Way) entityContainer.getEntity();
queue.put(way);
statistics.incProcessedWays();
}
} catch (InterruptedException e) {
return;
}
}
});
// The way consumer
for (int i = 0; i < CONSUMER_THREADS; i++) {
threadPool.submit(new Consumer());
}
reader.run();
} catch (IOException e) {
logger.error("Got an exception during import", e);
} finally {
shutdown();
}
}
Aggregations