Commit b75c2602 authored by Riegel's avatar Riegel
Browse files

Merge branch 'refs/heads/dev' into dev_zip_files

# Conflicts:
#	CityDoctorParent/CityDoctorModel/src/main/java/de/hft/stuttgart/citydoctor2/datastructure/LibraryObject.java
#	CityDoctorParent/CityDoctorModel/src/main/java/de/hft/stuttgart/citydoctor2/mapper/citygml3/Citygml3FeatureMapper.java
#	CityDoctorParent/CityDoctorValidation/src/main/java/de/hft/stuttgart/citydoctor2/check/Checker.java
#	CityDoctorParent/Extensions/CityDoctorGUI/pom.xml
#	CityDoctorParent/Extensions/CityDoctorGUI/src/main/resources/de/hft/stuttgart/citydoctor2/gui/MainToolBar.fxml
#	CityDoctorParent/Extensions/CityDoctorHealer/pom.xml
#	CityDoctorParent/pom.xml
2 merge requests!28Version 3.17.0 Release,!26Add ZIP-archive support
Pipeline #10991 passed with stage
in 1 minute and 24 seconds
Showing with 1274 additions and 1226 deletions
+1274 -1226
<?xml version="1.0" encoding="utf-8"?> <?xml version="1.0" encoding="utf-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"> <project xmlns="http://maven.apache.org/POM/4.0.0"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion> <modelVersion>4.0.0</modelVersion>
<parent> <parent>
<groupId>de.hft.stuttgart</groupId> <groupId>de.hft.stuttgart</groupId>
......
<?xml version="1.0" encoding="utf-8"?> <?xml version="1.0" encoding="utf-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"> <project xmlns="http://maven.apache.org/POM/4.0.0"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion> <modelVersion>4.0.0</modelVersion>
<parent> <parent>
<groupId>de.hft.stuttgart</groupId> <groupId>de.hft.stuttgart</groupId>
......
...@@ -29,7 +29,6 @@ public class Vector2d { ...@@ -29,7 +29,6 @@ public class Vector2d {
this.y = y; this.y = y;
} }
@SuppressWarnings("SuspiciousNameCombination")
public Vector2d getPerpendicularVector() { public Vector2d getPerpendicularVector() {
return new Vector2d(y, -x); return new Vector2d(y, -x);
} }
......
<?xml version="1.0" encoding="utf-8"?> <?xml version="1.0" encoding="utf-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"> <project xmlns="http://maven.apache.org/POM/4.0.0"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion> <modelVersion>4.0.0</modelVersion>
<parent> <parent>
<groupId>de.hft.stuttgart</groupId> <groupId>de.hft.stuttgart</groupId>
...@@ -102,7 +104,8 @@ ...@@ -102,7 +104,8 @@
<prefix>git</prefix> <prefix>git</prefix>
<verbose>false</verbose> <verbose>false</verbose>
<generateGitPropertiesFile>true</generateGitPropertiesFile> <generateGitPropertiesFile>true</generateGitPropertiesFile>
<generateGitPropertiesFilename>${project.build.outputDirectory}/git.properties</generateGitPropertiesFilename> <generateGitPropertiesFilename>
${project.build.outputDirectory}/git.properties</generateGitPropertiesFilename>
<gitDescribe> <gitDescribe>
<skip>false</skip> <skip>false</skip>
<always>false</always> <always>false</always>
......
...@@ -60,10 +60,8 @@ import de.hft.stuttgart.citydoctor2.check.error.UnknownCheckError; ...@@ -60,10 +60,8 @@ import de.hft.stuttgart.citydoctor2.check.error.UnknownCheckError;
* @author Matthias Betz * @author Matthias Betz
* *
*/ */
@SuppressWarnings("unused")
public interface HealingMethod { public interface HealingMethod {
public HealingID getID(); public HealingID getID();
default boolean visit(CheckError e, ModificationListener l) { default boolean visit(CheckError e, ModificationListener l) {
......
...@@ -129,7 +129,10 @@ public abstract class AbstractFurniture extends CityObject { ...@@ -129,7 +129,10 @@ public abstract class AbstractFurniture extends CityObject {
public void setParent(CityObject co) { public void setParent(CityObject co) {
parent = co; parent = co;
} }
public CityObject getParent() {
return parent;
}
@Override @Override
public void unsetGmlGeometries() { public void unsetGmlGeometries() {
......
package de.hft.stuttgart.citydoctor2.datastructure; package de.hft.stuttgart.citydoctor2.datastructure;
import java.io.Serial;
import java.util.List;
import org.citygml4j.core.model.core.ImplicitGeometry;
import de.hft.stuttgart.citydoctor2.check.Check; import de.hft.stuttgart.citydoctor2.check.Check;
import de.hft.stuttgart.citydoctor2.check.CheckError; import de.hft.stuttgart.citydoctor2.check.CheckError;
import de.hft.stuttgart.citydoctor2.check.CheckId; import de.hft.stuttgart.citydoctor2.check.CheckId;
import de.hft.stuttgart.citydoctor2.math.TransformationMatrix; import de.hft.stuttgart.citydoctor2.math.TransformationMatrix;
import org.apache.logging.log4j.LogManager;
import org.apache.logging.log4j.Logger;
import org.citygml4j.core.model.core.ImplicitGeometry;
import java.io.Serial;
import java.util.List;
/** /**
* Datastructure for representation and resolving of implicit geometries * Datastructure for representation and resolving of implicit geometries
...@@ -18,7 +17,6 @@ import java.util.List; ...@@ -18,7 +17,6 @@ import java.util.List;
*/ */
public class ImplicitGeometryHolder extends Geometry { public class ImplicitGeometryHolder extends Geometry {
private static final Logger logger = LogManager.getLogger(ImplicitGeometryHolder.class);
@Serial @Serial
private static final long serialVersionUID = -8938931081577196349L; private static final long serialVersionUID = -8938931081577196349L;
......
...@@ -16,16 +16,18 @@ import java.util.Map; ...@@ -16,16 +16,18 @@ import java.util.Map;
import java.util.concurrent.ConcurrentHashMap; import java.util.concurrent.ConcurrentHashMap;
/** /**
* Reference object for handling of implicit geometries with a library object contained in an external file * Reference object for handling of implicit geometries with a library object
* contained in an external file
* *
* @author Riegel * @author Riegel
*/ */
public class LibraryObject extends Geometry { public class LibraryObject extends Geometry {
private static final Logger logger = LogManager.getLogger(LibraryObject.class); private static final Logger logger = LogManager.getLogger(LibraryObject.class);
@Serial @Serial
private static final long serialVersionUID = -50293435187454911L; private static final long serialVersionUID = -50293435187454911L;
private static Map<String, LibraryObject> libraryObjects = new ConcurrentHashMap<>();
private static Map<String, LibraryObject> libraryObjects = new ConcurrentHashMap<>();
public static LibraryObject of(Path path, ParserConfiguration config) { public static LibraryObject of(Path path, ParserConfiguration config) {
if (libraryObjects.containsKey(path.toString())) { if (libraryObjects.containsKey(path.toString())) {
......
package de.hft.stuttgart.citydoctor2.datastructure; package de.hft.stuttgart.citydoctor2.datastructure;
import org.apache.logging.log4j.LogManager;
import org.apache.logging.log4j.Logger;
import java.io.Serial; import java.io.Serial;
import java.util.Map; import java.util.Map;
import java.util.concurrent.ConcurrentHashMap; import java.util.concurrent.ConcurrentHashMap;
...@@ -15,27 +11,23 @@ import java.util.concurrent.ConcurrentHashMap; ...@@ -15,27 +11,23 @@ import java.util.concurrent.ConcurrentHashMap;
*/ */
public class RelativeGeometry extends Geometry { public class RelativeGeometry extends Geometry {
private static final Logger logger = LogManager.getLogger(RelativeGeometry.class); @Serial
@Serial private static final long serialVersionUID = -686112245455298977L;
private static final long serialVersionUID = -686112245455298977L;
private static Map<Geometry, RelativeGeometry> relativeGeometries = new ConcurrentHashMap<>();
private static Map<Geometry, RelativeGeometry> relativeGeometries = new ConcurrentHashMap<>();
public static RelativeGeometry of(Geometry geom) {
public static RelativeGeometry of(Geometry geom) { if (relativeGeometries.containsKey(geom)) {
if (relativeGeometries.containsKey(geom)) { return relativeGeometries.get(geom);
return relativeGeometries.get(geom); }
} RelativeGeometry relGeo = new RelativeGeometry(geom.getType(), geom.getLod());
RelativeGeometry relGeo = new RelativeGeometry(geom.getType(), geom.getLod()); geom.getPolygons().forEach(relGeo::addPolygon);
geom.getPolygons().forEach(relGeo::addPolygon); relGeo.updateEdgesAndVertices();
relGeo.updateEdgesAndVertices(); relativeGeometries.put(geom, relGeo);
relativeGeometries.put(geom, relGeo); return relGeo;
return relGeo; }
}
private RelativeGeometry(GeometryType type, Lod lod) {
super(type, lod);
private RelativeGeometry(GeometryType type, Lod lod) { }
super(type, lod);
}
} }
...@@ -68,6 +68,8 @@ public class TunnelConstructiveElement extends CityObject { ...@@ -68,6 +68,8 @@ public class TunnelConstructiveElement extends CityObject {
MultiSurface ms = CityGmlUtils.createMultiSurface(geom, factory, config); MultiSurface ms = CityGmlUtils.createMultiSurface(geom, factory, config);
setMultiSurfaceAccordingToLod(geom, ms); setMultiSurfaceAccordingToLod(geom, ms);
break; break;
case COMPOSITE_SURFACE:
throw new IllegalStateException("Tunnel constructive element cannot have a composite surface geometry");
} }
} }
for (BoundarySurface bs : boundarySurfaceList) { for (BoundarySurface bs : boundarySurfaceList) {
......
...@@ -72,17 +72,17 @@ import java.util.Map; ...@@ -72,17 +72,17 @@ import java.util.Map;
public class Citygml3FeatureMapper extends ObjectWalker { public class Citygml3FeatureMapper extends ObjectWalker {
private static final Logger logger = LogManager.getLogger(Citygml3FeatureMapper.class); private static final Logger logger = LogManager.getLogger(Citygml3FeatureMapper.class);
private final CityDoctorModel model; private final CityDoctorModel model;
private final ParserConfiguration config; private final ParserConfiguration config;
private final Path directory; private final Path directory;
private final CityGmlZipEntry zipEntry; private final CityGmlZipEntry zipEntry;
private final double neighborDistance; private final double neighborDistance;
private Map<String, ConcretePolygon> polygonMap = new HashMap<>(); private Map<String, ConcretePolygon> polygonMap = new HashMap<>();
private Map<String, CompositeCollection> compositeMap = new HashMap<>(); private Map<String, CompositeCollection> compositeMap = new HashMap<>();
private List<ResolvableReference> references = new ArrayList<>(); private List<ResolvableReference> references = new ArrayList<>();
private Map<Vertex, Vertex> vertexMap = new HashMap<>(); private Map<Vertex, Vertex> vertexMap = new HashMap<>();
public Citygml3FeatureMapper(ParserConfiguration config, Path path) { public Citygml3FeatureMapper(ParserConfiguration config, Path path) {
this.config = config; this.config = config;
...@@ -100,687 +100,709 @@ public class Citygml3FeatureMapper extends ObjectWalker { ...@@ -100,687 +100,709 @@ public class Citygml3FeatureMapper extends ObjectWalker {
neighborDistance = 1.8d / Math.pow(10, config.getNumberOfRoundingPlaces()); neighborDistance = 1.8d / Math.pow(10, config.getNumberOfRoundingPlaces());
} }
public static void parseId(AbstractGML gml, GmlElement gmlElement) { public static void parseId(AbstractGML gml, GmlElement gmlElement) {
String id = gml.getId(); String id = gml.getId();
if (id != null) { if (id != null) {
gmlElement.setGmlId(new GmlId(id)); gmlElement.setGmlId(new GmlId(id));
} }
} }
@Override @Override
public void visit(AbstractSpace space) { public void visit(AbstractSpace space) {
// if we are here, an AbstractSpace thing was read that is not handled in the // if we are here, an AbstractSpace thing was read that is not handled in the
// other methods // other methods
} }
@Override @Override
public void visit(org.citygml4j.core.model.cityfurniture.CityFurniture gmlCityFurniture) { public void visit(org.citygml4j.core.model.cityfurniture.CityFurniture gmlCityFurniture) {
CityFurniture cf = new CityFurniture(); CityFurniture cf = new CityFurniture();
cf.setGmlObject(gmlCityFurniture); cf.setGmlObject(gmlCityFurniture);
mapAbstractOccupiedSpace(gmlCityFurniture, cf); mapAbstractOccupiedSpace(gmlCityFurniture, cf);
resolveAndClearReferences(); resolveAndClearReferences();
cf.unsetGmlGeometries(); cf.unsetGmlGeometries();
updateEdgesAndVertices(cf); updateEdgesAndVertices(cf);
model.addCityFurniture(cf); model.addCityFurniture(cf);
} }
@Override @Override
public void visit(org.citygml4j.core.model.generics.GenericOccupiedSpace gos) { public void visit(org.citygml4j.core.model.generics.GenericOccupiedSpace gos) {
GenericCityObject gco = new GenericCityObject(); GenericCityObject gco = new GenericCityObject();
gco.setGmlObject(gos); gco.setGmlObject(gos);
GeometryProperty<?> agLod1 = gos.getDeprecatedProperties().getLod1Geometry(); GeometryProperty<?> agLod1 = gos.getDeprecatedProperties().getLod1Geometry();
GeometryProperty<?> agLod4 = gos.getDeprecatedProperties().getLod4Geometry(); GeometryProperty<?> agLod4 = gos.getDeprecatedProperties().getLod4Geometry();
if (agLod1 != null && agLod1.getObject() != null && if (agLod1 != null && agLod1.getObject() != null && agLod1.getObject() instanceof MultiSurface ms) {
agLod1.getObject() instanceof MultiSurface ms) { gco.addGeometry(parseMultiSurface(ms, Lod.LOD1));
gco.addGeometry(parseMultiSurface(ms, Lod.LOD1)); }
} if (agLod4 != null && agLod4.getObject() != null) {
if (agLod4 != null && agLod4.getObject() != null) { if (agLod4.getObject() instanceof MultiSurface ms) {
if (agLod4.getObject() instanceof MultiSurface ms) { gco.addGeometry(parseMultiSurface(ms, Lod.LOD4));
gco.addGeometry(parseMultiSurface(ms, Lod.LOD4)); } else if (agLod4.getObject() instanceof AbstractSolid solid) {
} else if (agLod4.getObject() instanceof AbstractSolid solid) { gco.addGeometry(parseSolid(solid, Lod.LOD4));
gco.addGeometry(parseSolid(solid, Lod.LOD4)); }
} }
} mapAbstractOccupiedSpace(gos, gco);
mapAbstractOccupiedSpace(gos, gco); resolveAndClearReferences();
resolveAndClearReferences(); gco.unsetGmlGeometries();
gco.unsetGmlGeometries(); updateEdgesAndVertices(gco);
updateEdgesAndVertices(gco); model.addGenericCityObject(gco);
model.addGenericCityObject(gco); }
}
@Override
@Override public void visit(org.citygml4j.core.model.building.Building gmlBuilding) {
public void visit(org.citygml4j.core.model.building.Building gmlBuilding) { Building cdBuilding = new Building();
Building cdBuilding = new Building(); readAbstractBuilding(gmlBuilding, cdBuilding);
readAbstractBuilding(gmlBuilding, cdBuilding); for (BuildingPartProperty bpProp : gmlBuilding.getBuildingParts()) {
for (BuildingPartProperty bpProp : gmlBuilding.getBuildingParts()) { if (!bpProp.isSetObject()) {
if (!bpProp.isSetObject()) { continue;
continue; }
} BuildingPart part = new BuildingPart(cdBuilding);
BuildingPart part = new BuildingPart(cdBuilding); readAbstractBuilding(bpProp.getObject(), part);
readAbstractBuilding(bpProp.getObject(), part); }
} model.addBuilding(cdBuilding);
model.addBuilding(cdBuilding); }
}
@Override
@Override public void visit(WaterBody waterBody) {
public void visit(WaterBody waterBody) { WaterObject wo = new WaterObject();
WaterObject wo = new WaterObject(); wo.setGmlObject(waterBody);
wo.setGmlObject(waterBody); mapAbstractOccupiedSpace(waterBody, wo);
mapAbstractOccupiedSpace(waterBody, wo); parseAndAddMultiSurface(waterBody.getDeprecatedProperties().getLod1MultiSurface(), Lod.LOD1, wo);
parseAndAddMultiSurface(waterBody.getDeprecatedProperties().getLod1MultiSurface(), Lod.LOD1, wo); parseAndAddSolid(waterBody.getDeprecatedProperties().getLod4Solid(), Lod.LOD4, wo);
parseAndAddSolid(waterBody.getDeprecatedProperties().getLod4Solid(), Lod.LOD4, wo);
SurfaceMapper surfaceMapper = new SurfaceMapper(polygonMap, references, compositeMap, vertexMap, config);
SurfaceMapper surfaceMapper = new SurfaceMapper(polygonMap, references, compositeMap, vertexMap, config); for (AbstractSpaceBoundaryProperty surfaceProp : waterBody.getBoundaries()) {
for (AbstractSpaceBoundaryProperty surfaceProp : waterBody.getBoundaries()) { if (!surfaceProp.isSetObject()) {
if (!surfaceProp.isSetObject()) { continue;
continue; }
} AbstractSpaceBoundary surface = surfaceProp.getObject();
AbstractSpaceBoundary surface = surfaceProp.getObject(); surface.accept(surfaceMapper);
surface.accept(surfaceMapper); }
} for (BoundarySurface bs : surfaceMapper.getSurfaces()) {
for (BoundarySurface bs : surfaceMapper.getSurfaces()) { wo.addBoundarySurface(bs);
wo.addBoundarySurface(bs); }
}
resolveAndClearReferences();
resolveAndClearReferences(); wo.unsetGmlGeometries();
wo.unsetGmlGeometries(); updateEdgesAndVertices(wo);
updateEdgesAndVertices(wo); for (BoundarySurface bs : surfaceMapper.getSurfaces()) {
for (BoundarySurface bs : surfaceMapper.getSurfaces()) { updateEdgesAndVertices(bs);
updateEdgesAndVertices(bs); }
} model.addWater(wo);
model.addWater(wo); }
}
@Override
@Override public void visit(LandUse landUse) {
public void visit(LandUse landUse) { LandObject lo = new LandObject(landUse);
LandObject lo = new LandObject(landUse);
mapAbstractThematicSurface(landUse, lo);
mapAbstractThematicSurface(landUse, lo);
finishCityObjectConstruction(lo);
finishCityObjectConstruction(lo); model.addLand(lo);
model.addLand(lo); }
}
@Override
@Override public void visit(PlantCover plantCover) {
public void visit(PlantCover plantCover) { Vegetation veg = new Vegetation(VegetationType.PLANT_COVER);
Vegetation veg = new Vegetation(VegetationType.PLANT_COVER); veg.setGmlObject(plantCover);
veg.setGmlObject(plantCover); mapAbstractVegetationObject(plantCover, veg);
mapAbstractVegetationObject(plantCover, veg);
parseAndAddMultiSurface(plantCover.getDeprecatedProperties().getLod1MultiSurface(), Lod.LOD1, veg);
parseAndAddMultiSurface(plantCover.getDeprecatedProperties().getLod1MultiSurface(), Lod.LOD1, veg); parseAndAddMultiSurface(plantCover.getDeprecatedProperties().getLod4MultiSurface(), Lod.LOD4, veg);
parseAndAddMultiSurface(plantCover.getDeprecatedProperties().getLod4MultiSurface(), Lod.LOD4, veg);
finishCityObjectConstruction(veg);
finishCityObjectConstruction(veg); model.addVegetation(veg);
model.addVegetation(veg); }
}
@Override
@Override public void visit(SolitaryVegetationObject solitaryVegetationObject) {
public void visit(SolitaryVegetationObject solitaryVegetationObject) { Vegetation veg = new Vegetation(VegetationType.SOLITARY_VEGETATION_OBJECT);
Vegetation veg = new Vegetation(VegetationType.SOLITARY_VEGETATION_OBJECT); veg.setGmlObject(solitaryVegetationObject);
veg.setGmlObject(solitaryVegetationObject); mapAbstractVegetationObject(solitaryVegetationObject, veg);
mapAbstractVegetationObject(solitaryVegetationObject, veg);
parseAndAddAbstractGeometry(solitaryVegetationObject.getDeprecatedProperties().getLod1Geometry(), Lod.LOD1,
parseAndAddAbstractGeometry(solitaryVegetationObject.getDeprecatedProperties().getLod1Geometry(), Lod.LOD1, veg); veg);
parseAndAddAbstractGeometry(solitaryVegetationObject.getDeprecatedProperties().getLod2Geometry(), Lod.LOD2, veg); parseAndAddAbstractGeometry(solitaryVegetationObject.getDeprecatedProperties().getLod2Geometry(), Lod.LOD2,
parseAndAddAbstractGeometry(solitaryVegetationObject.getDeprecatedProperties().getLod3Geometry(), Lod.LOD3, veg); veg);
parseAndAddAbstractGeometry(solitaryVegetationObject.getDeprecatedProperties().getLod4Geometry(), Lod.LOD4, veg); parseAndAddAbstractGeometry(solitaryVegetationObject.getDeprecatedProperties().getLod3Geometry(), Lod.LOD3,
veg);
finishCityObjectConstruction(veg); parseAndAddAbstractGeometry(solitaryVegetationObject.getDeprecatedProperties().getLod4Geometry(), Lod.LOD4,
model.addVegetation(veg); veg);
}
finishCityObjectConstruction(veg);
private void mapAbstractVegetationObject(AbstractVegetationObject avo, Vegetation veg) { model.addVegetation(veg);
mapAbstractOccupiedSpace(avo, veg); }
}
private void mapAbstractVegetationObject(AbstractVegetationObject avo, Vegetation veg) {
private void mapAbstractOccupiedSpace(AbstractOccupiedSpace aos, CityObject co) { mapAbstractOccupiedSpace(avo, veg);
mapAbstractPhysicalSpace(aos, co); }
parseImplicitGeometry(aos, co);
} private void mapAbstractOccupiedSpace(AbstractOccupiedSpace aos, CityObject co) {
mapAbstractPhysicalSpace(aos, co);
private void mapAbstractPhysicalSpace(AbstractPhysicalSpace aps, CityObject co) { parseImplicitGeometry(aos, co);
mapAbstractSpace(aps, co); }
}
private void mapAbstractPhysicalSpace(AbstractPhysicalSpace aps, CityObject co) {
private void mapAbstractSpace(AbstractSpace as, CityObject co) { mapAbstractSpace(aps, co);
mapAbstractFeature(as, co); }
parseAndAddMultiSurface(as.getLod0MultiSurface(), Lod.LOD0, co);
parseAndAddMultiSurface(as.getLod2MultiSurface(), Lod.LOD2, co); private void mapAbstractSpace(AbstractSpace as, CityObject co) {
parseAndAddMultiSurface(as.getLod3MultiSurface(), Lod.LOD3, co); mapAbstractFeature(as, co);
parseAndAddSolid(as.getLod1Solid(), Lod.LOD1, co); parseAndAddMultiSurface(as.getLod0MultiSurface(), Lod.LOD0, co);
parseAndAddSolid(as.getLod2Solid(), Lod.LOD2, co); parseAndAddMultiSurface(as.getLod2MultiSurface(), Lod.LOD2, co);
parseAndAddSolid(as.getLod3Solid(), Lod.LOD3, co); parseAndAddMultiSurface(as.getLod3MultiSurface(), Lod.LOD3, co);
parseAndAddGenericAttributes(as, co); parseAndAddSolid(as.getLod1Solid(), Lod.LOD1, co);
} parseAndAddSolid(as.getLod2Solid(), Lod.LOD2, co);
parseAndAddSolid(as.getLod3Solid(), Lod.LOD3, co);
private void parseAndAddGenericAttributes(AbstractSpace as, CityObject co) { parseAndAddGenericAttributes(as, co);
for (AbstractGenericAttributeProperty aga : as.getGenericAttributes()) { }
co.addGenericAttribute(new GenericAttribute(aga));
} private void parseAndAddGenericAttributes(AbstractSpace as, CityObject co) {
} for (AbstractGenericAttributeProperty aga : as.getGenericAttributes()) {
co.addGenericAttribute(new GenericAttribute(aga));
@Override }
public void visit(Bridge bridge) { }
BridgeObject bo = new BridgeObject(bridge);
@Override
public void visit(Bridge bridge) {
// parse deprecated geometries BridgeObject bo = new BridgeObject(bridge);
parseAndAddMultiSurface(bridge.getDeprecatedProperties().getLod1MultiSurface(), Lod.LOD1, bo);
parseAndAddMultiSurface(bridge.getDeprecatedProperties().getLod4MultiSurface(), Lod.LOD4, bo); // parse deprecated geometries
parseAndAddSolid(bridge.getDeprecatedProperties().getLod4Solid(), Lod.LOD4, bo); parseAndAddMultiSurface(bridge.getDeprecatedProperties().getLod1MultiSurface(), Lod.LOD1, bo);
parseAndAddMultiSurface(bridge.getDeprecatedProperties().getLod4MultiSurface(), Lod.LOD4, bo);
mapAbstractBridge(bridge, bo); parseAndAddSolid(bridge.getDeprecatedProperties().getLod4Solid(), Lod.LOD4, bo);
for (BridgePartProperty bPartProperty : bridge.getBridgeParts()) {
if (!bPartProperty.isSetObject()) { mapAbstractBridge(bridge, bo);
continue; for (BridgePartProperty bPartProperty : bridge.getBridgeParts()) {
} if (!bPartProperty.isSetObject()) {
BridgePart gmlBridgePart = bPartProperty.getObject(); continue;
BridgeObject bPart = new BridgeObject(gmlBridgePart, bo); }
mapAbstractBridge(gmlBridgePart, bPart); BridgePart gmlBridgePart = bPartProperty.getObject();
bo.addBridgePart(bPart); BridgeObject bPart = new BridgeObject(gmlBridgePart, bo);
} mapAbstractBridge(gmlBridgePart, bPart);
resolveAndClearReferences(); bo.addBridgePart(bPart);
updateEdgesAndVertices(bo); }
for (BridgeObject part : bo.getParts()) { resolveAndClearReferences();
updateEdgesAndVertices(part); updateEdgesAndVertices(bo);
} for (BridgeObject part : bo.getParts()) {
for (BridgeConstructiveElement ele : bo.getConstructiveElements()) { updateEdgesAndVertices(part);
updateEdgesAndVertices(ele); }
for (BoundarySurface bs : ele.getBoundarySurfaces()) { for (BridgeConstructiveElement ele : bo.getConstructiveElements()) {
updateEdgesAndVertices(bs); updateEdgesAndVertices(ele);
} for (BoundarySurface bs : ele.getBoundarySurfaces()) {
} updateEdgesAndVertices(bs);
for (Installation bi : bo.getBridgeInstallations()) { }
updateEdgesAndVertices(bi); }
for (BoundarySurface bs : bi.getBoundarySurfaces()) { for (Installation bi : bo.getBridgeInstallations()) {
updateEdgesAndVertices(bs); updateEdgesAndVertices(bi);
} for (BoundarySurface bs : bi.getBoundarySurfaces()) {
} updateEdgesAndVertices(bs);
model.addBridge(bo); }
} }
model.addBridge(bo);
private void mapAbstractBridge(AbstractBridge ab, BridgeObject bo) { }
mapAbstractConstruction(ab, bo);
for (BridgeConstructiveElementProperty eleProp : ab.getBridgeConstructiveElements()) { private void mapAbstractBridge(AbstractBridge ab, BridgeObject bo) {
if (!eleProp.isSetObject()) { mapAbstractConstruction(ab, bo);
continue; for (BridgeConstructiveElementProperty eleProp : ab.getBridgeConstructiveElements()) {
} if (!eleProp.isSetObject()) {
org.citygml4j.core.model.bridge.BridgeConstructiveElement constructiveElement = eleProp.getObject(); continue;
BridgeConstructiveElement cdEle = new BridgeConstructiveElement(constructiveElement); }
mapConstructiveElement(constructiveElement, cdEle); org.citygml4j.core.model.bridge.BridgeConstructiveElement constructiveElement = eleProp.getObject();
bo.addConstructiveElement(cdEle); BridgeConstructiveElement cdEle = new BridgeConstructiveElement(constructiveElement);
} mapConstructiveElement(constructiveElement, cdEle);
bo.addConstructiveElement(cdEle);
List<BridgeInstallationProperty> bridgeInstallations = ab.getBridgeInstallations(); }
for (BridgeInstallationProperty installationProp : bridgeInstallations) {
var gmlBi = installationProp.getObject(); List<BridgeInstallationProperty> bridgeInstallations = ab.getBridgeInstallations();
if (gmlBi == null) { for (BridgeInstallationProperty installationProp : bridgeInstallations) {
// ignore empty properties var gmlBi = installationProp.getObject();
continue; if (gmlBi == null) {
} // ignore empty properties
Installation bi = mapBridgeInstallation(gmlBi); continue;
bo.addBridgeInstallation(bi); }
} Installation bi = mapBridgeInstallation(gmlBi);
bo.addBridgeInstallation(bi);
SurfaceMapper surfaceMapper = new SurfaceMapper(polygonMap, references, compositeMap, vertexMap, config); }
for (AbstractSpaceBoundaryProperty surfaceProp : ab.getBoundaries()) {
if (!surfaceProp.isSetObject()) { SurfaceMapper surfaceMapper = new SurfaceMapper(polygonMap, references, compositeMap, vertexMap, config);
continue; for (AbstractSpaceBoundaryProperty surfaceProp : ab.getBoundaries()) {
} if (!surfaceProp.isSetObject()) {
AbstractSpaceBoundary surface = surfaceProp.getObject(); continue;
surface.accept(surfaceMapper); }
} AbstractSpaceBoundary surface = surfaceProp.getObject();
updatePartOfSurface(bo, surfaceMapper); surface.accept(surfaceMapper);
}
for (BoundarySurface bs : bo.getBoundarySurfaces()) { updatePartOfSurface(bo, surfaceMapper);
updateEdgesAndVertices(bs);
} for (BoundarySurface bs : bo.getBoundarySurfaces()) {
updateEdgesAndVertices(bs);
bo.unsetGmlGeometries(); }
}
bo.unsetGmlGeometries();
private Installation mapBridgeInstallation(BridgeInstallation gmlBi) { }
Installation bi = new Installation();
bi.setGmlObject(gmlBi); private Installation mapBridgeInstallation(BridgeInstallation gmlBi) {
mapAbstractOccupiedSpace(gmlBi, bi); Installation bi = new Installation();
GeometryProperty<?> lod2Prop = gmlBi.getDeprecatedProperties().getLod2Geometry(); bi.setGmlObject(gmlBi);
parseAndAddAbstractGeometry(lod2Prop, Lod.LOD2, bi); mapAbstractOccupiedSpace(gmlBi, bi);
GeometryProperty<?> lod3Prop = gmlBi.getDeprecatedProperties().getLod3Geometry(); GeometryProperty<?> lod2Prop = gmlBi.getDeprecatedProperties().getLod2Geometry();
parseAndAddAbstractGeometry(lod3Prop, Lod.LOD3, bi); parseAndAddAbstractGeometry(lod2Prop, Lod.LOD2, bi);
GeometryProperty<?> lod4Prop = gmlBi.getDeprecatedProperties().getLod4Geometry(); GeometryProperty<?> lod3Prop = gmlBi.getDeprecatedProperties().getLod3Geometry();
parseAndAddAbstractGeometry(lod4Prop, Lod.LOD4, bi); parseAndAddAbstractGeometry(lod3Prop, Lod.LOD3, bi);
bi.unsetGmlGeometries(); GeometryProperty<?> lod4Prop = gmlBi.getDeprecatedProperties().getLod4Geometry();
parseAndAddAbstractGeometry(lod4Prop, Lod.LOD4, bi);
SurfaceMapper surfaceMapper = new SurfaceMapper(polygonMap, references, compositeMap, vertexMap, config); bi.unsetGmlGeometries();
for (AbstractSpaceBoundaryProperty surfaceProp : gmlBi.getBoundaries()) {
if (!surfaceProp.isSetObject()) { SurfaceMapper surfaceMapper = new SurfaceMapper(polygonMap, references, compositeMap, vertexMap, config);
continue; for (AbstractSpaceBoundaryProperty surfaceProp : gmlBi.getBoundaries()) {
} if (!surfaceProp.isSetObject()) {
AbstractSpaceBoundary surface = surfaceProp.getObject(); continue;
surface.accept(surfaceMapper); }
} AbstractSpaceBoundary surface = surfaceProp.getObject();
for (BoundarySurface bs : surfaceMapper.getSurfaces()) { surface.accept(surfaceMapper);
bi.addBoundarySurface(bs); }
for (Geometry geom : bs.getGeometries()) { for (BoundarySurface bs : surfaceMapper.getSurfaces()) {
for (Polygon p : geom.getPolygons()) { bi.addBoundarySurface(bs);
p.setPartOfSurface(bs); for (Geometry geom : bs.getGeometries()) {
p.setPartOfInstallation(bi); for (Polygon p : geom.getPolygons()) {
} p.setPartOfSurface(bs);
} p.setPartOfInstallation(bi);
} }
for (Geometry geom : bi.getGeometries()) { }
for (Polygon p : geom.getPolygons()) { }
p.setPartOfInstallation(bi); for (Geometry geom : bi.getGeometries()) {
} for (Polygon p : geom.getPolygons()) {
} p.setPartOfInstallation(bi);
}
return bi; }
}
return bi;
@Override }
public void visit(Tunnel tunnel) {
de.hft.stuttgart.citydoctor2.datastructure.Tunnel tu = new de.hft.stuttgart.citydoctor2.datastructure.Tunnel(); @Override
for (TunnelPartProperty tPartProperty : tunnel.getTunnelParts()) { public void visit(Tunnel tunnel) {
if (!tPartProperty.isSetObject()) { de.hft.stuttgart.citydoctor2.datastructure.Tunnel tu = new de.hft.stuttgart.citydoctor2.datastructure.Tunnel();
continue; for (TunnelPartProperty tPartProperty : tunnel.getTunnelParts()) {
} if (!tPartProperty.isSetObject()) {
org.citygml4j.core.model.tunnel.TunnelPart gmlTunnelPart = tPartProperty.getObject(); continue;
TunnelPart tPart = new TunnelPart(tu); }
readAbstractTunnel(gmlTunnelPart, tPart); org.citygml4j.core.model.tunnel.TunnelPart gmlTunnelPart = tPartProperty.getObject();
tu.addTunnelPart(tPart); TunnelPart tPart = new TunnelPart(tu);
} readAbstractTunnel(gmlTunnelPart, tPart);
readAbstractTunnel(tunnel, tu); tu.addTunnelPart(tPart);
resolveAndClearReferences(); }
updateEdgesAndVertices(tu); readAbstractTunnel(tunnel, tu);
for (TunnelPart part : tu.getTunnelParts()) { resolveAndClearReferences();
updateEdgesAndVertices(part); updateEdgesAndVertices(tu);
} for (TunnelPart part : tu.getTunnelParts()) {
model.addTunnel(tu); updateEdgesAndVertices(part);
}
} model.addTunnel(tu);
private void readAbstractTunnel(org.citygml4j.core.model.tunnel.AbstractTunnel gmlTunnel, AbstractTunnel cdTunnel) { }
mapAbstractOccupiedSpace(gmlTunnel, cdTunnel);
cdTunnel.setGmlObject(gmlTunnel); private void readAbstractTunnel(org.citygml4j.core.model.tunnel.AbstractTunnel gmlTunnel, AbstractTunnel cdTunnel) {
mapAbstractOccupiedSpace(gmlTunnel, cdTunnel);
// parse deprecated geometries cdTunnel.setGmlObject(gmlTunnel);
parseAndAddMultiSurface(gmlTunnel.getDeprecatedProperties().getLod1MultiSurface(), Lod.LOD1, cdTunnel);
parseAndAddMultiSurface(gmlTunnel.getDeprecatedProperties().getLod4MultiSurface(), Lod.LOD4, cdTunnel); // parse deprecated geometries
parseAndAddSolid(gmlTunnel.getDeprecatedProperties().getLod4Solid(), Lod.LOD4, cdTunnel); parseAndAddMultiSurface(gmlTunnel.getDeprecatedProperties().getLod1MultiSurface(), Lod.LOD1, cdTunnel);
parseAndAddMultiSurface(gmlTunnel.getDeprecatedProperties().getLod4MultiSurface(), Lod.LOD4, cdTunnel);
for (TunnelInstallationProperty tiProp : gmlTunnel.getTunnelInstallations()) { parseAndAddSolid(gmlTunnel.getDeprecatedProperties().getLod4Solid(), Lod.LOD4, cdTunnel);
var gmlTi = tiProp.getObject();
if (gmlTi == null) { parseTunnelInstallations(gmlTunnel, cdTunnel);
// ignore empty properties parseHollowSpaces(gmlTunnel, cdTunnel);
continue; parseTunnelFurniture(gmlTunnel, cdTunnel);
} parseTunnelConstructiveElements(gmlTunnel, cdTunnel);
Installation ti = mapTunnelInstallation(gmlTi); parseTunnelBoundarySurfaces(gmlTunnel);
cdTunnel.addTunnelInstallation(ti); for (Installation ti : cdTunnel.getTunnelInstallations()) {
} updateEdgesAndVertices(ti);
for (BoundarySurface bs : ti.getBoundarySurfaces()) {
for (HollowSpaceProperty thProp : gmlTunnel.getHollowSpaces()) { updateEdgesAndVertices(bs);
var gmlTh = thProp.getObject(); for (Opening o : bs.getOpenings()) {
if (gmlTh == null) { updateEdgesAndVertices(o);
continue; }
} }
TunnelHollow br = mapTunnelHollow(gmlTh); }
cdTunnel.addTunnelHollow(br);
}
for (Installation ti : cdTunnel.getTunnelInstallations()) { cdTunnel.unsetGmlGeometries();
updateEdgesAndVertices(ti); resolveAndClearReferences();
for (BoundarySurface bs : ti.getBoundarySurfaces()) { updateEdgesAndVertices(cdTunnel);
updateEdgesAndVertices(bs); }
for (Opening o : bs.getOpenings()) {
updateEdgesAndVertices(o); private void parseTunnelBoundarySurfaces(org.citygml4j.core.model.tunnel.AbstractTunnel gmlTunnel) {
} SurfaceMapper surfaceMapper = new SurfaceMapper(polygonMap, references, compositeMap, vertexMap, config);
} for (AbstractSpaceBoundaryProperty surfaceProp : gmlTunnel.getBoundaries()) {
} if (!surfaceProp.isSetObject()) {
for (TunnelFurnitureProperty tfProp : gmlTunnel.getTunnelFurniture()) { continue;
var gmlTf = tfProp.getObject(); }
if (gmlTf == null) { AbstractSpaceBoundary surface = surfaceProp.getObject();
continue; surface.accept(surfaceMapper);
} }
TunnelFurniture tf = mapTunnelFurniture(gmlTf); for (BoundarySurface bs : surfaceMapper.getSurfaces()) {
cdTunnel.addTunnelFurniture(tf); updateEdgesAndVertices(bs);
} for (Opening o : bs.getOpenings()) {
updateEdgesAndVertices(o);
for (TunnelConstructiveElementProperty teProp : gmlTunnel.getTunnelConstructiveElements()) { }
var gmlTc = teProp.getObject(); }
if (gmlTc == null) { }
continue;
} private void parseTunnelConstructiveElements(org.citygml4j.core.model.tunnel.AbstractTunnel gmlTunnel, AbstractTunnel cdTunnel) {
TunnelConstructiveElement tc = mapTunnelConstructiveElement(gmlTc); for (TunnelConstructiveElementProperty teProp : gmlTunnel.getTunnelConstructiveElements()) {
cdTunnel.addTunnelConstructiveElement(tc); var gmlTc = teProp.getObject();
} if (gmlTc == null) {
continue;
SurfaceMapper surfaceMapper = new SurfaceMapper(polygonMap, references, compositeMap, vertexMap, config); }
for (AbstractSpaceBoundaryProperty surfaceProp : gmlTunnel.getBoundaries()) { TunnelConstructiveElement tc = mapTunnelConstructiveElement(gmlTc);
if (!surfaceProp.isSetObject()) { cdTunnel.addTunnelConstructiveElement(tc);
continue; }
} }
AbstractSpaceBoundary surface = surfaceProp.getObject();
surface.accept(surfaceMapper); private void parseTunnelFurniture(org.citygml4j.core.model.tunnel.AbstractTunnel gmlTunnel, AbstractTunnel cdTunnel) {
} for (TunnelFurnitureProperty tfProp : gmlTunnel.getTunnelFurniture()) {
for (BoundarySurface bs : surfaceMapper.getSurfaces()) { var gmlTf = tfProp.getObject();
updateEdgesAndVertices(bs); if (gmlTf == null) {
for (Opening o : bs.getOpenings()) { continue;
updateEdgesAndVertices(o); }
} TunnelFurniture tf = mapTunnelFurniture(gmlTf);
} cdTunnel.addTunnelFurniture(tf);
}
}
cdTunnel.unsetGmlGeometries();
resolveAndClearReferences(); private void parseHollowSpaces(org.citygml4j.core.model.tunnel.AbstractTunnel gmlTunnel, AbstractTunnel cdTunnel) {
updateEdgesAndVertices(cdTunnel); for (HollowSpaceProperty thProp : gmlTunnel.getHollowSpaces()) {
} var gmlTh = thProp.getObject();
if (gmlTh == null) {
private Installation mapTunnelInstallation(TunnelInstallation gmlTi) { continue;
Installation ti = new Installation(); }
ti.setGmlObject(gmlTi); TunnelHollow br = mapTunnelHollow(gmlTh);
mapAbstractOccupiedSpace(gmlTi, ti); cdTunnel.addTunnelHollow(br);
GeometryProperty<?> lod2Prop = gmlTi.getDeprecatedProperties().getLod2Geometry(); }
parseAndAddAbstractGeometry(lod2Prop, Lod.LOD2, ti); }
GeometryProperty<?> lod3Prop = gmlTi.getDeprecatedProperties().getLod3Geometry();
parseAndAddAbstractGeometry(lod3Prop, Lod.LOD3, ti); private void parseTunnelInstallations(org.citygml4j.core.model.tunnel.AbstractTunnel gmlTunnel, AbstractTunnel cdTunnel) {
GeometryProperty<?> lod4Prop = gmlTi.getDeprecatedProperties().getLod4Geometry(); for (TunnelInstallationProperty tiProp : gmlTunnel.getTunnelInstallations()) {
parseAndAddAbstractGeometry(lod4Prop, Lod.LOD4, ti); var gmlTi = tiProp.getObject();
ti.unsetGmlGeometries(); if (gmlTi == null) {
// ignore empty properties
SurfaceMapper surfaceMapper = new SurfaceMapper(polygonMap, references, compositeMap, vertexMap, config); continue;
for (AbstractSpaceBoundaryProperty surfaceProp : gmlTi.getBoundaries()) { }
if (!surfaceProp.isSetObject()) { Installation ti = mapTunnelInstallation(gmlTi);
continue; cdTunnel.addTunnelInstallation(ti);
} }
AbstractSpaceBoundary surface = surfaceProp.getObject(); }
surface.accept(surfaceMapper);
} private Installation mapTunnelInstallation(TunnelInstallation gmlTi) {
for (BoundarySurface bs : surfaceMapper.getSurfaces()) { Installation ti = new Installation();
ti.addBoundarySurface(bs); ti.setGmlObject(gmlTi);
for (Geometry geom : bs.getGeometries()) { mapAbstractOccupiedSpace(gmlTi, ti);
for (Polygon p : geom.getPolygons()) { GeometryProperty<?> lod2Prop = gmlTi.getDeprecatedProperties().getLod2Geometry();
p.setPartOfSurface(bs); parseAndAddAbstractGeometry(lod2Prop, Lod.LOD2, ti);
p.setPartOfInstallation(ti); GeometryProperty<?> lod3Prop = gmlTi.getDeprecatedProperties().getLod3Geometry();
} parseAndAddAbstractGeometry(lod3Prop, Lod.LOD3, ti);
} GeometryProperty<?> lod4Prop = gmlTi.getDeprecatedProperties().getLod4Geometry();
} parseAndAddAbstractGeometry(lod4Prop, Lod.LOD4, ti);
for (Geometry geom : ti.getGeometries()) { ti.unsetGmlGeometries();
for (Polygon p : geom.getPolygons()) {
p.setPartOfInstallation(ti); SurfaceMapper surfaceMapper = new SurfaceMapper(polygonMap, references, compositeMap, vertexMap, config);
} for (AbstractSpaceBoundaryProperty surfaceProp : gmlTi.getBoundaries()) {
} if (!surfaceProp.isSetObject()) {
continue;
return ti; }
} AbstractSpaceBoundary surface = surfaceProp.getObject();
surface.accept(surfaceMapper);
private TunnelHollow mapTunnelHollow(HollowSpace gmlHo) { }
TunnelHollow tHollow = new TunnelHollow(); for (BoundarySurface bs : surfaceMapper.getSurfaces()) {
tHollow.setGmlObject(gmlHo); ti.addBoundarySurface(bs);
mapAbstractUnoccupiedSpace(gmlHo, tHollow); for (Geometry geom : bs.getGeometries()) {
for (Polygon p : geom.getPolygons()) {
SurfaceMapper surfaceMapper = new SurfaceMapper(polygonMap, references, compositeMap, vertexMap, config); p.setPartOfSurface(bs);
for (AbstractSpaceBoundaryProperty surfaceProp : gmlHo.getBoundaries()) { p.setPartOfInstallation(ti);
if (!surfaceProp.isSetObject()) { }
continue; }
} }
AbstractSpaceBoundary surface = surfaceProp.getObject(); for (Geometry geom : ti.getGeometries()) {
surface.accept(surfaceMapper); for (Polygon p : geom.getPolygons()) {
} p.setPartOfInstallation(ti);
for (BoundarySurface bs : surfaceMapper.getSurfaces()) { }
tHollow.addBoundarySurface(bs); }
for (Geometry geom : bs.getGeometries()) {
for (Polygon p : geom.getPolygons()) { return ti;
p.setPartOfSurface(bs); }
}
} private TunnelHollow mapTunnelHollow(HollowSpace gmlHo) {
} TunnelHollow tHollow = new TunnelHollow();
for (TunnelInstallationProperty tiProp : gmlHo.getTunnelInstallations()) { tHollow.setGmlObject(gmlHo);
var gmlTi = tiProp.getObject(); mapAbstractUnoccupiedSpace(gmlHo, tHollow);
if (gmlTi == null) {
// ignore empty properties SurfaceMapper surfaceMapper = new SurfaceMapper(polygonMap, references, compositeMap, vertexMap, config);
continue; for (AbstractSpaceBoundaryProperty surfaceProp : gmlHo.getBoundaries()) {
} if (!surfaceProp.isSetObject()) {
Installation bi = mapTunnelInstallation(gmlTi); continue;
tHollow.addRoomInstallation(bi); }
} AbstractSpaceBoundary surface = surfaceProp.getObject();
for (TunnelFurnitureProperty tfProp : gmlHo.getTunnelFurniture()) { surface.accept(surfaceMapper);
var gmlHref = tfProp.getHref(); }
if (gmlHref == null) { for (BoundarySurface bs : surfaceMapper.getSurfaces()) {
continue; tHollow.addBoundarySurface(bs);
} for (Geometry geom : bs.getGeometries()) {
tHollow.addFurnitureRef(tfProp); for (Polygon p : geom.getPolygons()) {
} p.setPartOfSurface(bs);
return tHollow; }
} }
}
private TunnelFurniture mapTunnelFurniture(org.citygml4j.core.model.tunnel.TunnelFurniture gmlTf) { for (TunnelInstallationProperty tiProp : gmlHo.getTunnelInstallations()) {
TunnelFurniture tf = new TunnelFurniture(); var gmlTi = tiProp.getObject();
tf.setGmlObject(gmlTf); if (gmlTi == null) {
mapAbstractOccupiedSpace(gmlTf, tf); // ignore empty properties
tf.unsetGmlGeometries(); continue;
SurfaceMapper surfaceMapper = new SurfaceMapper(polygonMap, references, compositeMap, vertexMap, config); }
for (AbstractSpaceBoundaryProperty surfaceProp : gmlTf.getBoundaries()) { Installation bi = mapTunnelInstallation(gmlTi);
if (!surfaceProp.isSetObject()) { tHollow.addRoomInstallation(bi);
continue; }
} for (TunnelFurnitureProperty tfProp : gmlHo.getTunnelFurniture()) {
AbstractSpaceBoundary surface = surfaceProp.getObject(); var gmlHref = tfProp.getHref();
surface.accept(surfaceMapper); if (gmlHref == null) {
} continue;
for (BoundarySurface bs : surfaceMapper.getSurfaces()) { }
tf.addBoundarySurface(bs); tHollow.addFurnitureRef(tfProp);
for (Geometry geom : bs.getGeometries()) { }
for (Polygon p : geom.getPolygons()) { return tHollow;
p.setPartOfSurface(bs); }
}
} private TunnelFurniture mapTunnelFurniture(org.citygml4j.core.model.tunnel.TunnelFurniture gmlTf) {
} TunnelFurniture tf = new TunnelFurniture();
return tf; tf.setGmlObject(gmlTf);
} mapAbstractOccupiedSpace(gmlTf, tf);
tf.unsetGmlGeometries();
private TunnelConstructiveElement mapTunnelConstructiveElement(org.citygml4j.core.model.tunnel.TunnelConstructiveElement gmlTe) { SurfaceMapper surfaceMapper = new SurfaceMapper(polygonMap, references, compositeMap, vertexMap, config);
TunnelConstructiveElement te = new TunnelConstructiveElement(gmlTe); for (AbstractSpaceBoundaryProperty surfaceProp : gmlTf.getBoundaries()) {
mapAbstractOccupiedSpace(gmlTe, te); if (!surfaceProp.isSetObject()) {
te.unsetGmlGeometries(); continue;
SurfaceMapper surfaceMapper = new SurfaceMapper(polygonMap, references, compositeMap, vertexMap, config); }
for (AbstractSpaceBoundaryProperty surfaceProp : gmlTe.getBoundaries()) { AbstractSpaceBoundary surface = surfaceProp.getObject();
if (!surfaceProp.isSetObject()) { surface.accept(surfaceMapper);
continue; }
} for (BoundarySurface bs : surfaceMapper.getSurfaces()) {
AbstractSpaceBoundary surface = surfaceProp.getObject(); tf.addBoundarySurface(bs);
surface.accept(surfaceMapper); for (Geometry geom : bs.getGeometries()) {
} for (Polygon p : geom.getPolygons()) {
for (BoundarySurface bs : surfaceMapper.getSurfaces()) { p.setPartOfSurface(bs);
te.addBoundarySurface(bs); }
for (Geometry geom : bs.getGeometries()) { }
for (Polygon p : geom.getPolygons()) { }
p.setPartOfSurface(bs); return tf;
} }
}
} private TunnelConstructiveElement mapTunnelConstructiveElement(
return te; org.citygml4j.core.model.tunnel.TunnelConstructiveElement gmlTe) {
} TunnelConstructiveElement te = new TunnelConstructiveElement(gmlTe);
mapAbstractOccupiedSpace(gmlTe, te);
private void updatePartOfSurface(BridgeObject bo, SurfaceMapper surfaceMapper) { te.unsetGmlGeometries();
for (BoundarySurface bs : surfaceMapper.getSurfaces()) { SurfaceMapper surfaceMapper = new SurfaceMapper(polygonMap, references, compositeMap, vertexMap, config);
bo.addBoundarySurface(bs); for (AbstractSpaceBoundaryProperty surfaceProp : gmlTe.getBoundaries()) {
for (Geometry geom : bs.getGeometries()) { if (!surfaceProp.isSetObject()) {
for (Polygon p : geom.getPolygons()) { continue;
p.setPartOfSurface(bs); }
} AbstractSpaceBoundary surface = surfaceProp.getObject();
} surface.accept(surfaceMapper);
} }
} for (BoundarySurface bs : surfaceMapper.getSurfaces()) {
te.addBoundarySurface(bs);
private void mapConstructiveElement(org.citygml4j.core.model.bridge.BridgeConstructiveElement ele, BridgeConstructiveElement bce) { for (Geometry geom : bs.getGeometries()) {
mapAbstractConstructiveElement(ele, bce); for (Polygon p : geom.getPolygons()) {
p.setPartOfSurface(bs);
SurfaceMapper surfaceMapper = new SurfaceMapper(polygonMap, references, compositeMap, vertexMap, config); }
for (AbstractSpaceBoundaryProperty surfaceProp : ele.getBoundaries()) { }
if (!surfaceProp.isSetObject()) { }
continue; return te;
} }
AbstractSpaceBoundary surface = surfaceProp.getObject();
surface.accept(surfaceMapper); private void updatePartOfSurface(BridgeObject bo, SurfaceMapper surfaceMapper) {
} for (BoundarySurface bs : surfaceMapper.getSurfaces()) {
for (BoundarySurface bs : surfaceMapper.getSurfaces()) { bo.addBoundarySurface(bs);
bce.addBoundarySurface(bs); for (Geometry geom : bs.getGeometries()) {
} for (Polygon p : geom.getPolygons()) {
} p.setPartOfSurface(bs);
}
private void mapAbstractConstructiveElement(org.citygml4j.core.model.bridge.BridgeConstructiveElement ele, BridgeConstructiveElement bce) { }
mapAbstractOccupiedSpace(ele, bce); }
} }
private void mapAbstractConstruction(AbstractConstruction ac, BridgeObject bo) { private void mapConstructiveElement(org.citygml4j.core.model.bridge.BridgeConstructiveElement ele,
mapAbstractOccupiedSpace(ac, bo); BridgeConstructiveElement bce) {
} mapAbstractConstructiveElement(ele, bce);
@Override SurfaceMapper surfaceMapper = new SurfaceMapper(polygonMap, references, compositeMap, vertexMap, config);
public void visit(AuxiliaryTrafficArea ata) { for (AbstractSpaceBoundaryProperty surfaceProp : ele.getBoundaries()) {
TransportationObject to = new TransportationObject(TransportationType.AUXILLIARY_TRAFFIC_AREA); if (!surfaceProp.isSetObject()) {
mapAbstractThematicSurface(ata, to); continue;
finishTransportationMapping(to); }
} AbstractSpaceBoundary surface = surfaceProp.getObject();
surface.accept(surfaceMapper);
@Override }
public void visit(TrafficArea ta) { for (BoundarySurface bs : surfaceMapper.getSurfaces()) {
TransportationObject to = new TransportationObject(TransportationType.TRAFFIC_AREA); bce.addBoundarySurface(bs);
mapAbstractThematicSurface(ta, to); }
finishTransportationMapping(to); }
}
private void mapAbstractConstructiveElement(org.citygml4j.core.model.bridge.BridgeConstructiveElement ele,
@Override BridgeConstructiveElement bce) {
public void visit(Road road) { mapAbstractOccupiedSpace(ele, bce);
TransportationObject to = new TransportationObject(TransportationType.ROAD); }
mapAbstractTransportationSpace(road, to);
finishTransportationMapping(to); private void mapAbstractConstruction(AbstractConstruction ac, BridgeObject bo) {
} mapAbstractOccupiedSpace(ac, bo);
}
private void mapAbstractThematicSurface(AbstractThematicSurface ats, CityObject co) {
mapAbstractSpaceBoundary(ats, co); @Override
parseAndAddMultiSurface(ats.getLod0MultiSurface(), Lod.LOD0, co); public void visit(AuxiliaryTrafficArea ata) {
parseAndAddMultiSurface(ats.getLod1MultiSurface(), Lod.LOD1, co); TransportationObject to = new TransportationObject(TransportationType.AUXILLIARY_TRAFFIC_AREA);
parseAndAddMultiSurface(ats.getLod2MultiSurface(), Lod.LOD2, co); mapAbstractThematicSurface(ata, to);
parseAndAddMultiSurface(ats.getLod3MultiSurface(), Lod.LOD3, co); finishTransportationMapping(to);
parseAndAddMultiSurface(ats.getDeprecatedProperties().getLod4MultiSurface(), Lod.LOD4, co); }
}
@Override
private void mapAbstractSpaceBoundary(AbstractSpaceBoundary asb, CityObject co) { public void visit(TrafficArea ta) {
mapAbstractCityObject(asb, co); TransportationObject to = new TransportationObject(TransportationType.TRAFFIC_AREA);
} mapAbstractThematicSurface(ta, to);
finishTransportationMapping(to);
private void mapAbstractCityObject(AbstractCityObject aco, CityObject to) { }
mapAbstractFeatureWithLifespan(aco, to);
} @Override
public void visit(Road road) {
private void mapAbstractFeatureWithLifespan(AbstractFeatureWithLifespan afwl, CityObject to) { TransportationObject to = new TransportationObject(TransportationType.ROAD);
mapAbstractFeature(afwl, to); mapAbstractTransportationSpace(road, to);
} finishTransportationMapping(to);
}
private void mapAbstractFeature(AbstractFeature af, CityObject to) {
mapAbstractGML(af, to); private void mapAbstractThematicSurface(AbstractThematicSurface ats, CityObject co) {
} mapAbstractSpaceBoundary(ats, co);
parseAndAddMultiSurface(ats.getLod0MultiSurface(), Lod.LOD0, co);
private void mapAbstractGML(AbstractGML ag, CityObject to) { parseAndAddMultiSurface(ats.getLod1MultiSurface(), Lod.LOD1, co);
parseId(ag, to); parseAndAddMultiSurface(ats.getLod2MultiSurface(), Lod.LOD2, co);
} parseAndAddMultiSurface(ats.getLod3MultiSurface(), Lod.LOD3, co);
parseAndAddMultiSurface(ats.getDeprecatedProperties().getLod4MultiSurface(), Lod.LOD4, co);
@Override }
public void visit(Railway railway) {
TransportationObject to = new TransportationObject(TransportationType.RAILWAY); private void mapAbstractSpaceBoundary(AbstractSpaceBoundary asb, CityObject co) {
mapAbstractTransportationSpace(railway, to); mapAbstractCityObject(asb, co);
finishTransportationMapping(to); }
}
private void mapAbstractCityObject(AbstractCityObject aco, CityObject to) {
@Override mapAbstractFeatureWithLifespan(aco, to);
public void visit(Square square) { }
TransportationObject to = new TransportationObject(TransportationType.SQUARE);
mapAbstractTransportationSpace(square, to); private void mapAbstractFeatureWithLifespan(AbstractFeatureWithLifespan afwl, CityObject to) {
finishTransportationMapping(to); mapAbstractFeature(afwl, to);
} }
@Override private void mapAbstractFeature(AbstractFeature af, CityObject to) {
public void visit(Track track) { mapAbstractGML(af, to);
TransportationObject to = new TransportationObject(TransportationType.TRACK); }
mapAbstractTransportationSpace(track, to);
finishTransportationMapping(to); private void mapAbstractGML(AbstractGML ag, CityObject to) {
} parseId(ag, to);
}
@Override
public void visit(TransportationComplex transportationComplex) { @Override
TransportationObject to = new TransportationObject(TransportationType.TRANSPORTATION_COMPLEX); public void visit(Railway railway) {
mapAbstractTransportationSpace(transportationComplex, to); TransportationObject to = new TransportationObject(TransportationType.RAILWAY);
finishTransportationMapping(to); mapAbstractTransportationSpace(railway, to);
} finishTransportationMapping(to);
}
private void finishTransportationMapping(TransportationObject to) {
finishCityObjectConstruction(to); @Override
model.addTransportation(to); public void visit(Square square) {
} TransportationObject to = new TransportationObject(TransportationType.SQUARE);
mapAbstractTransportationSpace(square, to);
private void finishCityObjectConstruction(CityObject co) { finishTransportationMapping(to);
co.unsetGmlGeometries(); }
resolveAndClearReferences();
updateEdgesAndVertices(co); @Override
} public void visit(Track track) {
TransportationObject to = new TransportationObject(TransportationType.TRACK);
private void mapAbstractTransportationSpace(AbstractTransportationSpace ats, TransportationObject to) { mapAbstractTransportationSpace(track, to);
to.setGmlObject(ats); finishTransportationMapping(to);
parseAbstractTransportationSpaceGeometries(ats, to); }
for (TrafficSpaceProperty tsp : ats.getTrafficSpaces()) {
if (tsp.isSetObject()) { @Override
TransportationObject trafficSpace = new TransportationObject(TransportationType.TRAFFIC_SPACE); public void visit(TransportationComplex transportationComplex) {
mapTrafficSpace(tsp.getObject(), trafficSpace); TransportationObject to = new TransportationObject(TransportationType.TRANSPORTATION_COMPLEX);
finishTransportationMapping(trafficSpace); mapAbstractTransportationSpace(transportationComplex, to);
to.getChildren().add(trafficSpace); finishTransportationMapping(to);
} }
}
for (AuxiliaryTrafficSpaceProperty auxTrafficProp : ats.getAuxiliaryTrafficSpaces()) { private void finishTransportationMapping(TransportationObject to) {
if (auxTrafficProp.isSetObject()) { finishCityObjectConstruction(to);
TransportationObject trafficSpace = parseAuxiliaryTrafficSpace(auxTrafficProp.getObject()); model.addTransportation(to);
finishTransportationMapping(trafficSpace); }
to.addChild(trafficSpace);
} private void finishCityObjectConstruction(CityObject co) {
} co.unsetGmlGeometries();
} resolveAndClearReferences();
updateEdgesAndVertices(co);
private void mapTrafficSpace(TrafficSpace ts, TransportationObject to) { }
mapAbstractUnoccupiedSpace(ts, to);
} private void mapAbstractTransportationSpace(AbstractTransportationSpace ats, TransportationObject to) {
to.setGmlObject(ats);
private void mapAbstractUnoccupiedSpace(AbstractUnoccupiedSpace aus, CityObject co) { parseAbstractTransportationSpaceGeometries(ats, to);
mapAbstractPhysicalSpace(aus, co); for (TrafficSpaceProperty tsp : ats.getTrafficSpaces()) {
} if (tsp.isSetObject()) {
TransportationObject trafficSpace = new TransportationObject(TransportationType.TRAFFIC_SPACE);
private TransportationObject parseAuxiliaryTrafficSpace(AuxiliaryTrafficSpace ats) { mapTrafficSpace(tsp.getObject(), trafficSpace);
TransportationObject to = new TransportationObject(TransportationType.AUXILLIARY_TRAFFIC_SPACE); finishTransportationMapping(trafficSpace);
parseAbstractSpaceGeometries(ats, to); to.getChildren().add(trafficSpace);
finishCityObjectConstruction(to); }
return to; }
} for (AuxiliaryTrafficSpaceProperty auxTrafficProp : ats.getAuxiliaryTrafficSpaces()) {
if (auxTrafficProp.isSetObject()) {
private void parseAbstractTransportationSpaceGeometries(AbstractTransportationSpace space, CityObject co) { TransportationObject trafficSpace = parseAuxiliaryTrafficSpace(auxTrafficProp.getObject());
parseAndAddMultiSurface(space.getDeprecatedProperties().getLod1MultiSurface(), Lod.LOD1, co); finishTransportationMapping(trafficSpace);
parseAndAddMultiSurface(space.getDeprecatedProperties().getLod4MultiSurface(), Lod.LOD4, co); to.addChild(trafficSpace);
} }
}
private void parseAbstractSpaceGeometries(AbstractSpace as, CityObject co) { }
parseAndAddMultiSurface(as.getLod0MultiSurface(), Lod.LOD0, co);
parseAndAddMultiSurface(as.getLod2MultiSurface(), Lod.LOD2, co); private void mapTrafficSpace(TrafficSpace ts, TransportationObject to) {
parseAndAddMultiSurface(as.getLod3MultiSurface(), Lod.LOD3, co); mapAbstractUnoccupiedSpace(ts, to);
parseAndAddSolid(as.getLod1Solid(), Lod.LOD1, co); }
parseAndAddSolid(as.getLod2Solid(), Lod.LOD2, co);
parseAndAddSolid(as.getLod3Solid(), Lod.LOD3, co); private void mapAbstractUnoccupiedSpace(AbstractUnoccupiedSpace aus, CityObject co) {
mapAbstractPhysicalSpace(aus, co);
} }
private void parseAndAddMultiSurface(MultiSurfaceProperty msp, Lod lod, CityObject co) { private TransportationObject parseAuxiliaryTrafficSpace(AuxiliaryTrafficSpace ats) {
if (msp == null || msp.getObject() == null) { TransportationObject to = new TransportationObject(TransportationType.AUXILLIARY_TRAFFIC_SPACE);
return; parseAbstractSpaceGeometries(ats, to);
} finishCityObjectConstruction(to);
Geometry geom = parseMultiSurface(msp.getObject(), lod); return to;
co.addGeometry(geom); }
}
private void parseAbstractTransportationSpaceGeometries(AbstractTransportationSpace space, CityObject co) {
parseAndAddMultiSurface(space.getDeprecatedProperties().getLod1MultiSurface(), Lod.LOD1, co);
parseAndAddMultiSurface(space.getDeprecatedProperties().getLod4MultiSurface(), Lod.LOD4, co);
}
private void parseAbstractSpaceGeometries(AbstractSpace as, CityObject co) {
parseAndAddMultiSurface(as.getLod0MultiSurface(), Lod.LOD0, co);
parseAndAddMultiSurface(as.getLod2MultiSurface(), Lod.LOD2, co);
parseAndAddMultiSurface(as.getLod3MultiSurface(), Lod.LOD3, co);
parseAndAddSolid(as.getLod1Solid(), Lod.LOD1, co);
parseAndAddSolid(as.getLod2Solid(), Lod.LOD2, co);
parseAndAddSolid(as.getLod3Solid(), Lod.LOD3, co);
}
private void parseAndAddMultiSurface(MultiSurfaceProperty msp, Lod lod, CityObject co) {
if (msp == null || msp.getObject() == null) {
return;
}
Geometry geom = parseMultiSurface(msp.getObject(), lod);
co.addGeometry(geom);
}
private void parseAndAddSolid(SolidProperty sp, Lod lod, CityObject co) { private void parseAndAddSolid(SolidProperty sp, Lod lod, CityObject co) {
if (sp == null || sp.getObject() == null) { if (sp == null || sp.getObject() == null) {
...@@ -792,32 +814,31 @@ public class Citygml3FeatureMapper extends ObjectWalker { ...@@ -792,32 +814,31 @@ public class Citygml3FeatureMapper extends ObjectWalker {
} }
} }
private void parseImplicitGeometry(AbstractOccupiedSpace aos, CityObject co) {
private void parseImplicitGeometry(AbstractOccupiedSpace aos, CityObject co) { for (int i = 1; i <= 3; i++) {
for (int i = 1; i <= 3; i++) { if (aos.getImplicitRepresentation(i) == null) {
if (aos.getImplicitRepresentation(i) == null) { continue;
continue; }
} if (aos.getImplicitRepresentation(i).getObject() != null) {
if (aos.getImplicitRepresentation(i).getObject() != null) { ImplicitGeometry impGeom = aos.getImplicitRepresentation(i).getObject();
ImplicitGeometry impGeom = aos.getImplicitRepresentation(i).getObject(); ImplicitGeometryHolder igh = resolveImplicitGeometry(impGeom, i);
ImplicitGeometryHolder igh = resolveImplicitGeometry(impGeom, i); if (igh != null) {
if (igh != null) { co.addGeometry(igh);
co.addGeometry(igh); }
} } else if (aos.getImplicitRepresentation(i).getHref() != null) {
} else if (aos.getImplicitRepresentation(i).getHref() != null) { // Hrefs of ImplicitGeometries point to its RelativeGeometry.
// Hrefs of ImplicitGeometries point to its RelativeGeometry. // Can be ignored for CD since the Href is only used for repeating the
// Can be ignored for CD since the Href is only used for repeating the RelativeGeometry at different LODs // RelativeGeometry at different LODs
} }
}
}
}
}
private ImplicitGeometryHolder resolveImplicitGeometry(ImplicitGeometry ig, int lodInt) {
private ImplicitGeometryHolder resolveImplicitGeometry(ImplicitGeometry ig, int lodInt) { ImplicitGeometryHolder igh = null;
ImplicitGeometryHolder igh = null; if (ig.getLibraryObject() != null) {
if (ig.getLibraryObject() != null) { LibraryObject libObj = null;
LibraryObject libObj = null;
if (directory != null){ if (directory != null){
Path libraryObjectPath = directory.resolve(ig.getLibraryObject()); Path libraryObjectPath = directory.resolve(ig.getLibraryObject());
libObj = LibraryObject.of(libraryObjectPath, config); libObj = LibraryObject.of(libraryObjectPath, config);
...@@ -827,435 +848,455 @@ public class Citygml3FeatureMapper extends ObjectWalker { ...@@ -827,435 +848,455 @@ public class Citygml3FeatureMapper extends ObjectWalker {
CityGmlZipEntry libEntry = zipEntry.getArchive().getEntry(loPath.toString()); CityGmlZipEntry libEntry = zipEntry.getArchive().getEntry(loPath.toString());
libObj = LibraryObject.of(libEntry, config); libObj = LibraryObject.of(libEntry, config);
} }
if (libObj != null) { if (libObj != null) {
igh = new ImplicitGeometryHolder(ig, libObj); igh = new ImplicitGeometryHolder(ig, libObj);
} }
} else if (ig.getRelativeGeometry() != null) { } else if (ig.getRelativeGeometry() != null) {
AbstractGeometry aGeom = ig.getRelativeGeometry().getObject(); AbstractGeometry aGeom = ig.getRelativeGeometry().getObject();
Geometry geom = null; Geometry geom = null;
Lod lod = Lod.values()[lodInt]; Lod lod = Lod.values()[lodInt];
RelativeGeometry relGeo = null; RelativeGeometry relGeo = null;
if (aGeom instanceof MultiSurface ms) { if (aGeom instanceof MultiSurface ms) {
geom = parseMultiSurface(ms, lod); geom = parseMultiSurface(ms, lod);
} else if (aGeom instanceof Solid s) { } else if (aGeom instanceof Solid s) {
geom = parseSolid(s, lod); geom = parseSolid(s, lod);
} else if (aGeom instanceof CompositeSurface cs) { } else if (aGeom instanceof CompositeSurface cs) {
geom = parseCompositeSurface(cs, lod); geom = parseCompositeSurface(cs, lod);
} }
if (geom != null) { if (geom != null) {
relGeo = RelativeGeometry.of(geom); relGeo = RelativeGeometry.of(geom);
igh = new ImplicitGeometryHolder(ig, relGeo); igh = new ImplicitGeometryHolder(ig, relGeo);
} }
} else { } else {
logger.error("Implicit geometry of GML-ID {} has no referenced geometry.", ig.getId()); logger.error("Implicit geometry of GML-ID {} has no referenced geometry.", ig.getId());
} }
return igh; return igh;
} }
private void resolveAndClearReferences() { private void resolveAndClearReferences() {
for (ResolvableReference ref : references) { for (ResolvableReference ref : references) {
String href = ref.href(); String href = ref.href();
if (href.startsWith("#")) { if (href.startsWith("#")) {
href = href.substring(1); href = href.substring(1);
} }
Geometry geom = ref.geometry(); Geometry geom = ref.geometry();
CompositeCollection comp = compositeMap.get(href); CompositeCollection comp = compositeMap.get(href);
if (comp != null) { if (comp != null) {
comp.getCompositeMembers().forEach(geom::addPolygon); // composite collection, add each containing polygon to the geometry
} else { comp.getCompositeMembers().forEach(geom::addPolygon);
ConcretePolygon concPoly = polygonMap.get(href); } else {
if (concPoly == null) { handlePolygonReference(href, geom);
if (logger.isWarnEnabled()) { }
logger.warn(Localization.getText("FeatureMapper.polygonUnreferenced"), href); }
}
} else { // clear storage for polygons and vertices
LinkedPolygon lPoly = new LinkedPolygon(concPoly, geom); references = new ArrayList<>();
if (geom.getParent() instanceof BoundarySurface bs) { vertexMap = new HashMap<>();
lPoly.setPartOfSurface(bs); polygonMap = new HashMap<>();
if (bs.getParent() instanceof Installation bi) { }
lPoly.setPartOfInstallation(bi);
} private void handlePolygonReference(String href, Geometry geom) {
} ConcretePolygon concPoly = polygonMap.get(href);
geom.addPolygon(lPoly); if (concPoly == null) {
} if (logger.isWarnEnabled()) {
} logger.warn(Localization.getText("FeatureMapper.polygonUnreferenced"), href);
} }
} else {
// clear storage for polygons and vertices LinkedPolygon lPoly = new LinkedPolygon(concPoly, geom);
// probably faster than .clear() ? if (geom.getParent() instanceof BoundarySurface bs) {
references = new ArrayList<>(); lPoly.setPartOfSurface(bs);
vertexMap = new HashMap<>(); if (bs.getParent() instanceof Installation bi) {
polygonMap = new HashMap<>(); lPoly.setPartOfInstallation(bi);
} }
}
private void readAbstractBuilding(org.citygml4j.core.model.building.AbstractBuilding gmlAb, geom.addPolygon(lPoly);
AbstractBuilding cdBuilding) { }
mapAbstractOccupiedSpace(gmlAb, cdBuilding); }
cdBuilding.setGmlObject(gmlAb);
private void readAbstractBuilding(org.citygml4j.core.model.building.AbstractBuilding gmlAb,
// parse deprecated geometries AbstractBuilding cdBuilding) {
parseAndAddMultiSurface(gmlAb.getDeprecatedProperties().getLod1MultiSurface(), Lod.LOD1, cdBuilding); mapAbstractOccupiedSpace(gmlAb, cdBuilding);
parseAndAddMultiSurface(gmlAb.getDeprecatedProperties().getLod4MultiSurface(), Lod.LOD4, cdBuilding); cdBuilding.setGmlObject(gmlAb);
parseAndAddSolid(gmlAb.getDeprecatedProperties().getLod4Solid(), Lod.LOD4, cdBuilding);
// parse deprecated geometries
for (BuildingInstallationProperty biProp : gmlAb.getBuildingInstallations()) { parseAndAddMultiSurface(gmlAb.getDeprecatedProperties().getLod1MultiSurface(), Lod.LOD1, cdBuilding);
var gmlBi = biProp.getObject(); parseAndAddMultiSurface(gmlAb.getDeprecatedProperties().getLod4MultiSurface(), Lod.LOD4, cdBuilding);
if (gmlBi == null) { parseAndAddSolid(gmlAb.getDeprecatedProperties().getLod4Solid(), Lod.LOD4, cdBuilding);
// ignore empty properties
continue; parseBuildingInstallations(gmlAb, cdBuilding);
} parseBuildingRooms(gmlAb, cdBuilding);
Installation bi = mapBuildingInstallation(gmlBi); parseBuildingSubdivisions(gmlAb, cdBuilding);
cdBuilding.addBuildingInstallation(bi); parseBoundarySurfaces(gmlAb, cdBuilding);
} parseBuildingFurniture(gmlAb, cdBuilding);
}
for (BuildingRoomProperty brProp : gmlAb.getBuildingRooms()) {
var gmlBr = brProp.getObject(); private void parseBuildingFurniture(org.citygml4j.core.model.building.AbstractBuilding gmlAb, AbstractBuilding cdBuilding) {
if (gmlBr == null) { for (BuildingFurnitureProperty bfProp : gmlAb.getBuildingFurniture()) {
continue; var gmlBf = bfProp.getObject();
} if (gmlBf == null) {
BuildingRoom br = mapBuildingRoom(gmlBr); continue;
cdBuilding.addBuildingRoom(br); }
} BuildingRoomFurniture bf = mapBuildingFurniture(gmlBf);
cdBuilding.addBuildingRoomFurniture(bf);
for (AbstractBuildingSubdivisionProperty abs : gmlAb.getBuildingSubdivisions()) { }
var gmlABS = abs.getObject(); }
if (gmlABS == null) {
continue; private void parseBoundarySurfaces(org.citygml4j.core.model.building.AbstractBuilding gmlAb, AbstractBuilding cdBuilding) {
} SurfaceMapper surfaceMapper = new SurfaceMapper(polygonMap, references, compositeMap, vertexMap, config);
if (gmlABS instanceof Storey gmlStorey) { for (AbstractSpaceBoundaryProperty surfaceProp : gmlAb.getBoundaries()) {
de.hft.stuttgart.citydoctor2.datastructure.Storey storey = mapBuildingStorey(gmlStorey); if (!surfaceProp.isSetObject()) {
cdBuilding.addStorey(storey); continue;
} else if (gmlABS instanceof BuildingUnit gmlBU) { }
de.hft.stuttgart.citydoctor2.datastructure.BuildingUnit bu = mapBuildingUnit(gmlBU); AbstractSpaceBoundary surface = surfaceProp.getObject();
cdBuilding.addBuildingUnit(bu); surface.accept(surfaceMapper);
} }
} updatePartOfSurface(cdBuilding, surfaceMapper);
SurfaceMapper surfaceMapper = new SurfaceMapper(polygonMap, references, compositeMap, vertexMap, config); cdBuilding.unsetGmlGeometries();
for (AbstractSpaceBoundaryProperty surfaceProp : gmlAb.getBoundaries()) { resolveAndClearReferences();
if (!surfaceProp.isSetObject()) { updateEdgesAndVertices(cdBuilding);
continue; for (BoundarySurface bs : surfaceMapper.getSurfaces()) {
} updateEdgesAndVertices(bs);
AbstractSpaceBoundary surface = surfaceProp.getObject(); for (Opening o : bs.getOpenings()) {
surface.accept(surfaceMapper); updateEdgesAndVertices(o);
} }
updatePartOfSurface(cdBuilding, surfaceMapper); }
}
cdBuilding.unsetGmlGeometries();
resolveAndClearReferences(); private void parseBuildingSubdivisions(org.citygml4j.core.model.building.AbstractBuilding gmlAb, AbstractBuilding cdBuilding) {
updateEdgesAndVertices(cdBuilding); for (AbstractBuildingSubdivisionProperty abs : gmlAb.getBuildingSubdivisions()) {
for (BoundarySurface bs : surfaceMapper.getSurfaces()) { var gmlABS = abs.getObject();
updateEdgesAndVertices(bs); if (gmlABS == null) {
for (Opening o : bs.getOpenings()) { continue;
updateEdgesAndVertices(o); }
} if (gmlABS instanceof Storey gmlStorey) {
} de.hft.stuttgart.citydoctor2.datastructure.Storey storey = mapBuildingStorey(gmlStorey);
for (Installation bi : cdBuilding.getBuildingInstallations()) { cdBuilding.addStorey(storey);
updateEdgesAndVertices(bi); } else if (gmlABS instanceof BuildingUnit gmlBU) {
for (BoundarySurface bs : bi.getBoundarySurfaces()) { de.hft.stuttgart.citydoctor2.datastructure.BuildingUnit bu = mapBuildingUnit(gmlBU);
updateEdgesAndVertices(bs); cdBuilding.addBuildingUnit(bu);
for (Opening o : bs.getOpenings()) { }
updateEdgesAndVertices(o); }
} }
}
} private void parseBuildingRooms(org.citygml4j.core.model.building.AbstractBuilding gmlAb, AbstractBuilding cdBuilding) {
for (BuildingFurnitureProperty bfProp : gmlAb.getBuildingFurniture()) { for (BuildingRoomProperty brProp : gmlAb.getBuildingRooms()) {
var gmlBf = bfProp.getObject(); var gmlBr = brProp.getObject();
if (gmlBf == null) { if (gmlBr == null) {
continue; continue;
} }
BuildingRoomFurniture bf = mapBuildingFurniture(gmlBf); BuildingRoom br = mapBuildingRoom(gmlBr);
cdBuilding.addBuildingRoomFurniture(bf); cdBuilding.addBuildingRoom(br);
} }
} }
private BuildingRoom mapBuildingRoom(org.citygml4j.core.model.building.BuildingRoom gmlBr) { private void parseBuildingInstallations(org.citygml4j.core.model.building.AbstractBuilding gmlAb, AbstractBuilding cdBuilding) {
for (BuildingInstallationProperty biProp : gmlAb.getBuildingInstallations()) {
BuildingRoom br = new BuildingRoom(); var gmlBi = biProp.getObject();
br.setGmlObject(gmlBr); if (gmlBi == null) {
mapAbstractUnoccupiedSpace(gmlBr, br); // ignore empty properties
continue;
SurfaceMapper surfaceMapper = new SurfaceMapper(polygonMap, references, compositeMap, vertexMap, config); }
for (AbstractSpaceBoundaryProperty surfaceProp : gmlBr.getBoundaries()) { Installation bi = mapBuildingInstallation(gmlBi);
if (!surfaceProp.isSetObject()) { cdBuilding.addBuildingInstallation(bi);
continue; }
} for (Installation bi : cdBuilding.getBuildingInstallations()) {
AbstractSpaceBoundary surface = surfaceProp.getObject(); updateEdgesAndVertices(bi);
surface.accept(surfaceMapper); for (BoundarySurface bs : bi.getBoundarySurfaces()) {
} updateEdgesAndVertices(bs);
for (BoundarySurface bs : surfaceMapper.getSurfaces()) { for (Opening o : bs.getOpenings()) {
br.addBoundarySurface(bs); updateEdgesAndVertices(o);
for (Geometry geom : bs.getGeometries()) { }
for (Polygon p : geom.getPolygons()) { }
p.setPartOfSurface(bs); }
} }
}
} private BuildingRoom mapBuildingRoom(org.citygml4j.core.model.building.BuildingRoom gmlBr) {
for (BuildingInstallationProperty biProp : gmlBr.getBuildingInstallations()) {
var gmlBi = biProp.getObject(); BuildingRoom br = new BuildingRoom();
if (gmlBi == null) { br.setGmlObject(gmlBr);
// ignore empty properties mapAbstractUnoccupiedSpace(gmlBr, br);
continue;
} SurfaceMapper surfaceMapper = new SurfaceMapper(polygonMap, references, compositeMap, vertexMap, config);
Installation bi = mapBuildingInstallation(gmlBi); for (AbstractSpaceBoundaryProperty surfaceProp : gmlBr.getBoundaries()) {
br.addRoomInstallation(bi); if (!surfaceProp.isSetObject()) {
} continue;
for (BuildingFurnitureProperty bfProp : gmlBr.getBuildingFurniture()) { }
var gmlHref = bfProp.getHref(); AbstractSpaceBoundary surface = surfaceProp.getObject();
if (gmlHref == null) { surface.accept(surfaceMapper);
continue; }
} for (BoundarySurface bs : surfaceMapper.getSurfaces()) {
br.addFurnitureRef(bfProp); br.addBoundarySurface(bs);
} for (Geometry geom : bs.getGeometries()) {
for (Polygon p : geom.getPolygons()) {
p.setPartOfSurface(bs);
return br; }
} }
}
private BuildingRoomFurniture mapBuildingFurniture(BuildingFurniture gmlAF) { for (BuildingInstallationProperty biProp : gmlBr.getBuildingInstallations()) {
BuildingRoomFurniture bf = new BuildingRoomFurniture(); var gmlBi = biProp.getObject();
bf.setGmlObject(gmlAF); if (gmlBi == null) {
mapAbstractOccupiedSpace(gmlAF, bf); // ignore empty properties
bf.unsetGmlGeometries(); continue;
SurfaceMapper surfaceMapper = new SurfaceMapper(polygonMap, references, compositeMap, vertexMap, config); }
for (AbstractSpaceBoundaryProperty surfaceProp : gmlAF.getBoundaries()) { Installation bi = mapBuildingInstallation(gmlBi);
if (!surfaceProp.isSetObject()) { br.addRoomInstallation(bi);
continue; }
} for (BuildingFurnitureProperty bfProp : gmlBr.getBuildingFurniture()) {
AbstractSpaceBoundary surface = surfaceProp.getObject(); var gmlHref = bfProp.getHref();
surface.accept(surfaceMapper); if (gmlHref == null) {
} continue;
for (BoundarySurface bs : surfaceMapper.getSurfaces()) { }
bf.addBoundarySurface(bs); br.addFurnitureRef(bfProp);
for (Geometry geom : bs.getGeometries()) { }
for (Polygon p : geom.getPolygons()) {
p.setPartOfSurface(bs); return br;
} }
}
} private BuildingRoomFurniture mapBuildingFurniture(BuildingFurniture gmlAF) {
return bf; BuildingRoomFurniture bf = new BuildingRoomFurniture();
bf.setGmlObject(gmlAF);
} mapAbstractOccupiedSpace(gmlAF, bf);
bf.unsetGmlGeometries();
private de.hft.stuttgart.citydoctor2.datastructure.Storey mapBuildingStorey(Storey gmlStorey) { SurfaceMapper surfaceMapper = new SurfaceMapper(polygonMap, references, compositeMap, vertexMap, config);
de.hft.stuttgart.citydoctor2.datastructure.Storey storey = new de.hft.stuttgart.citydoctor2.datastructure.Storey(); for (AbstractSpaceBoundaryProperty surfaceProp : gmlAF.getBoundaries()) {
storey.setGmlObject(gmlStorey); if (!surfaceProp.isSetObject()) {
mapAbstractSpace(gmlStorey, storey); continue;
storey.unsetGmlGeometries(); }
SurfaceMapper surfaceMapper = new SurfaceMapper(polygonMap, references, compositeMap, vertexMap, config); AbstractSpaceBoundary surface = surfaceProp.getObject();
for (AbstractSpaceBoundaryProperty surfaceProp : gmlStorey.getBoundaries()) { surface.accept(surfaceMapper);
if (!surfaceProp.isSetObject()) { }
continue; for (BoundarySurface bs : surfaceMapper.getSurfaces()) {
} bf.addBoundarySurface(bs);
AbstractSpaceBoundary surface = surfaceProp.getObject(); for (Geometry geom : bs.getGeometries()) {
surface.accept(surfaceMapper); for (Polygon p : geom.getPolygons()) {
} p.setPartOfSurface(bs);
for (BoundarySurface bs : surfaceMapper.getSurfaces()) { }
storey.addBoundarySurface(bs); }
for (Geometry geom : bs.getGeometries()) { }
for (Polygon p : geom.getPolygons()) { return bf;
p.setPartOfSurface(bs);
} }
}
} private de.hft.stuttgart.citydoctor2.datastructure.Storey mapBuildingStorey(Storey gmlStorey) {
return storey; de.hft.stuttgart.citydoctor2.datastructure.Storey storey = new de.hft.stuttgart.citydoctor2.datastructure.Storey();
} storey.setGmlObject(gmlStorey);
mapAbstractSpace(gmlStorey, storey);
private de.hft.stuttgart.citydoctor2.datastructure.BuildingUnit mapBuildingUnit(BuildingUnit gmlBU) { storey.unsetGmlGeometries();
de.hft.stuttgart.citydoctor2.datastructure.BuildingUnit bu = new de.hft.stuttgart.citydoctor2.datastructure.BuildingUnit(); SurfaceMapper surfaceMapper = new SurfaceMapper(polygonMap, references, compositeMap, vertexMap, config);
bu.setGmlObject(gmlBU); for (AbstractSpaceBoundaryProperty surfaceProp : gmlStorey.getBoundaries()) {
mapAbstractSpace(gmlBU, bu); if (!surfaceProp.isSetObject()) {
bu.unsetGmlGeometries(); continue;
SurfaceMapper surfaceMapper = new SurfaceMapper(polygonMap, references, compositeMap, vertexMap, config); }
for (AbstractSpaceBoundaryProperty surfaceProp : gmlBU.getBoundaries()) { AbstractSpaceBoundary surface = surfaceProp.getObject();
if (!surfaceProp.isSetObject()) { surface.accept(surfaceMapper);
continue; }
} for (BoundarySurface bs : surfaceMapper.getSurfaces()) {
AbstractSpaceBoundary surface = surfaceProp.getObject(); storey.addBoundarySurface(bs);
surface.accept(surfaceMapper); for (Geometry geom : bs.getGeometries()) {
} for (Polygon p : geom.getPolygons()) {
for (BoundarySurface bs : surfaceMapper.getSurfaces()) { p.setPartOfSurface(bs);
bu.addBoundarySurface(bs); }
for (Geometry geom : bs.getGeometries()) { }
for (Polygon p : geom.getPolygons()) { }
p.setPartOfSurface(bs); return storey;
} }
}
} private de.hft.stuttgart.citydoctor2.datastructure.BuildingUnit mapBuildingUnit(BuildingUnit gmlBU) {
return bu; de.hft.stuttgart.citydoctor2.datastructure.BuildingUnit bu = new de.hft.stuttgart.citydoctor2.datastructure.BuildingUnit();
} bu.setGmlObject(gmlBU);
mapAbstractSpace(gmlBU, bu);
private void updatePartOfSurface(AbstractBuilding cdBuilding, SurfaceMapper surfaceMapper) { bu.unsetGmlGeometries();
for (BoundarySurface bs : surfaceMapper.getSurfaces()) { SurfaceMapper surfaceMapper = new SurfaceMapper(polygonMap, references, compositeMap, vertexMap, config);
cdBuilding.addBoundarySurface(bs); for (AbstractSpaceBoundaryProperty surfaceProp : gmlBU.getBoundaries()) {
for (Geometry geom : bs.getGeometries()) { if (!surfaceProp.isSetObject()) {
for (Polygon p : geom.getPolygons()) { continue;
p.setPartOfSurface(bs); }
} AbstractSpaceBoundary surface = surfaceProp.getObject();
} surface.accept(surfaceMapper);
} }
} for (BoundarySurface bs : surfaceMapper.getSurfaces()) {
bu.addBoundarySurface(bs);
private Installation mapBuildingInstallation(org.citygml4j.core.model.building.BuildingInstallation gmlBi) { for (Geometry geom : bs.getGeometries()) {
Installation bi = new Installation(); for (Polygon p : geom.getPolygons()) {
bi.setGmlObject(gmlBi); p.setPartOfSurface(bs);
mapAbstractOccupiedSpace(gmlBi, bi); }
GeometryProperty<?> lod2Prop = gmlBi.getDeprecatedProperties().getLod2Geometry(); }
parseAndAddAbstractGeometry(lod2Prop, Lod.LOD2, bi); }
GeometryProperty<?> lod3Prop = gmlBi.getDeprecatedProperties().getLod3Geometry(); return bu;
parseAndAddAbstractGeometry(lod3Prop, Lod.LOD3, bi); }
GeometryProperty<?> lod4Prop = gmlBi.getDeprecatedProperties().getLod4Geometry();
parseAndAddAbstractGeometry(lod4Prop, Lod.LOD4, bi); private void updatePartOfSurface(AbstractBuilding cdBuilding, SurfaceMapper surfaceMapper) {
bi.unsetGmlGeometries(); for (BoundarySurface bs : surfaceMapper.getSurfaces()) {
cdBuilding.addBoundarySurface(bs);
SurfaceMapper surfaceMapper = new SurfaceMapper(polygonMap, references, compositeMap, vertexMap, config); for (Geometry geom : bs.getGeometries()) {
for (AbstractSpaceBoundaryProperty surfaceProp : gmlBi.getBoundaries()) { for (Polygon p : geom.getPolygons()) {
if (!surfaceProp.isSetObject()) { p.setPartOfSurface(bs);
continue; }
} }
AbstractSpaceBoundary surface = surfaceProp.getObject(); }
surface.accept(surfaceMapper); }
}
for (BoundarySurface bs : surfaceMapper.getSurfaces()) { private Installation mapBuildingInstallation(org.citygml4j.core.model.building.BuildingInstallation gmlBi) {
bi.addBoundarySurface(bs); Installation bi = new Installation();
for (Geometry geom : bs.getGeometries()) { bi.setGmlObject(gmlBi);
for (Polygon p : geom.getPolygons()) { mapAbstractOccupiedSpace(gmlBi, bi);
p.setPartOfSurface(bs); GeometryProperty<?> lod2Prop = gmlBi.getDeprecatedProperties().getLod2Geometry();
p.setPartOfInstallation(bi); parseAndAddAbstractGeometry(lod2Prop, Lod.LOD2, bi);
} GeometryProperty<?> lod3Prop = gmlBi.getDeprecatedProperties().getLod3Geometry();
} parseAndAddAbstractGeometry(lod3Prop, Lod.LOD3, bi);
} GeometryProperty<?> lod4Prop = gmlBi.getDeprecatedProperties().getLod4Geometry();
for (Geometry geom : bi.getGeometries()) { parseAndAddAbstractGeometry(lod4Prop, Lod.LOD4, bi);
for (Polygon p : geom.getPolygons()) { bi.unsetGmlGeometries();
p.setPartOfInstallation(bi);
} SurfaceMapper surfaceMapper = new SurfaceMapper(polygonMap, references, compositeMap, vertexMap, config);
} for (AbstractSpaceBoundaryProperty surfaceProp : gmlBi.getBoundaries()) {
if (!surfaceProp.isSetObject()) {
return bi; continue;
} }
AbstractSpaceBoundary surface = surfaceProp.getObject();
private void parseAndAddAbstractGeometry(GeometryProperty<?> geomProp, Lod lod, CityObject co) { surface.accept(surfaceMapper);
if (geomProp == null || geomProp.getObject() == null) { }
return; for (BoundarySurface bs : surfaceMapper.getSurfaces()) {
} bi.addBoundarySurface(bs);
AbstractGeometry abstractGeometry = geomProp.getObject(); for (Geometry geom : bs.getGeometries()) {
if (abstractGeometry instanceof MultiSurface ms) { for (Polygon p : geom.getPolygons()) {
Geometry geom = parseMultiSurface(ms, lod); p.setPartOfSurface(bs);
co.addGeometry(geom); p.setPartOfInstallation(bi);
} else if (abstractGeometry instanceof Solid solid) { }
Geometry geom = parseSolid(solid, lod); }
if (geom != null) { }
co.addGeometry(geom); for (Geometry geom : bi.getGeometries()) {
} for (Polygon p : geom.getPolygons()) {
} else { p.setPartOfInstallation(bi);
logger.warn("Cannot handle geometry type {}, ignoring", abstractGeometry.getClass().getSimpleName()); }
} }
}
return bi;
private Geometry parseSolid(AbstractSolid abstractSolid, Lod lod) { }
if (abstractSolid instanceof Solid s) {
return handleSolidGeometry(s, lod); private void parseAndAddAbstractGeometry(GeometryProperty<?> geomProp, Lod lod, CityObject co) {
} else { if (geomProp == null || geomProp.getObject() == null) {
logger.warn("Cannot handle solid class {}, can only process pure solids", return;
abstractSolid.getClass().getSimpleName()); }
return null; AbstractGeometry abstractGeometry = geomProp.getObject();
} if (abstractGeometry instanceof MultiSurface ms) {
} Geometry geom = parseMultiSurface(ms, lod);
co.addGeometry(geom);
private Geometry handleSolidGeometry(Solid solid, Lod lod) { } else if (abstractGeometry instanceof Solid solid) {
ShellProperty exteriorProperty = solid.getExterior(); Geometry geom = parseSolid(solid, lod);
if (exteriorProperty == null || exteriorProperty.getObject() == null) { if (geom != null) {
logger.warn("Found solid {} without exterior hull, ignoring", solid.getId()); co.addGeometry(geom);
return null; }
} } else {
Geometry geom = new Geometry(GeometryType.SOLID, lod); logger.warn("Cannot handle geometry type {}, ignoring", abstractGeometry.getClass().getSimpleName());
Shell exterior = solid.getExterior().getObject(); }
Citygml3GeometryMapper geometryMapper = new Citygml3GeometryMapper(config, vertexMap); }
readSurfaceMember(geom, geometryMapper, exterior.getSurfaceMembers());
return geom; private Geometry parseSolid(AbstractSolid abstractSolid, Lod lod) {
} if (abstractSolid instanceof Solid s) {
return handleSolidGeometry(s, lod);
private Geometry parseMultiSurface(MultiSurface ms, Lod lod) { } else {
Geometry geom = new Geometry(GeometryType.MULTI_SURFACE, lod); logger.warn("Cannot handle solid class {}, can only process pure solids",
Citygml3GeometryMapper geometryMapper = new Citygml3GeometryMapper(config, vertexMap); abstractSolid.getClass().getSimpleName());
readSurfaceMember(geom, geometryMapper, ms.getSurfaceMember()); return null;
return geom; }
} }
private void readSurfaceMember(Geometry geom, Citygml3GeometryMapper geometryMapper, private Geometry handleSolidGeometry(Solid solid, Lod lod) {
List<SurfaceProperty> surfaceMember) { ShellProperty exteriorProperty = solid.getExterior();
for (SurfaceProperty prop : surfaceMember) { if (exteriorProperty == null || exteriorProperty.getObject() == null) {
if (prop.getHref() != null) { logger.warn("Found solid {} without exterior hull, ignoring", solid.getId());
references.add(new ResolvableReference(prop.getHref(), geom)); return null;
continue; }
} Geometry geom = new Geometry(GeometryType.SOLID, lod);
if (prop.getObject() != null) { Shell exterior = solid.getExterior().getObject();
AbstractSurface as = prop.getObject(); Citygml3GeometryMapper geometryMapper = new Citygml3GeometryMapper(config, vertexMap);
as.accept(geometryMapper); readSurfaceMember(geom, geometryMapper, exterior.getSurfaceMembers());
} return geom;
} }
List<ConcretePolygon> polygons = geometryMapper.getPolygons(); private Geometry parseMultiSurface(MultiSurface ms, Lod lod) {
Geometry geom = new Geometry(GeometryType.MULTI_SURFACE, lod);
for (ConcretePolygon concretePoly : polygons) { Citygml3GeometryMapper geometryMapper = new Citygml3GeometryMapper(config, vertexMap);
geom.addPolygon(concretePoly); readSurfaceMember(geom, geometryMapper, ms.getSurfaceMember());
if (concretePoly.hasExistingGmlId()) { return geom;
polygonMap.put(concretePoly.getGmlId().getGmlString(), concretePoly); }
}
} private void readSurfaceMember(Geometry geom, Citygml3GeometryMapper geometryMapper,
} List<SurfaceProperty> surfaceMember) {
for (SurfaceProperty prop : surfaceMember) {
private Geometry parseCompositeSurface(CompositeSurface cs, Lod lod) { if (prop.getHref() != null) {
Geometry geom = new Geometry(GeometryType.COMPOSITE_SURFACE, lod); references.add(new ResolvableReference(prop.getHref(), geom));
Citygml3GeometryMapper geometryMapper = new Citygml3GeometryMapper(config, vertexMap); continue;
readSurfaceMember(geom, geometryMapper, cs.getSurfaceMembers()); }
return geom; if (prop.getObject() != null) {
} AbstractSurface as = prop.getObject();
as.accept(geometryMapper);
private void updateEdgesAndVertices(CityObject co) { }
// searching for neighboring vertices, replacing them with one single vertex to }
// avoid later problems with edges and manifold problems
for (Geometry geom : co.getGeometries()) { List<ConcretePolygon> polygons = geometryMapper.getPolygons();
KDTree tree = new KDTree();
for (Polygon poly : geom.getPolygons()) { for (ConcretePolygon concretePoly : polygons) {
LinearRing lr = poly.getExteriorRing(); geom.addPolygon(concretePoly);
updateRing(tree, lr); if (concretePoly.hasExistingGmlId()) {
for (LinearRing innerRing : poly.getInnerRings()) { polygonMap.put(concretePoly.getGmlId().getGmlString(), concretePoly);
updateRing(tree, innerRing); }
} }
} }
if (!config.useLowMemoryConsumption()) {
// no low memory consumption mode meaning create all meta information in private Geometry parseCompositeSurface(CompositeSurface cs, Lod lod) {
// geometry Geometry geom = new Geometry(GeometryType.COMPOSITE_SURFACE, lod);
geom.updateEdgesAndVertices(); Citygml3GeometryMapper geometryMapper = new Citygml3GeometryMapper(config, vertexMap);
} readSurfaceMember(geom, geometryMapper, cs.getSurfaceMembers());
} return geom;
} }
private void updateRing(KDTree tree, LinearRing lr) { private void updateEdgesAndVertices(CityObject co) {
for (int i = 0; i < lr.getVertices().size(); i++) { // searching for neighboring vertices, replacing them with one single vertex to
Vertex v = lr.getVertices().get(i); // avoid later problems with edges and manifold problems
List<Vertex> nodesInRange = tree.getNodesInRange(v, neighborDistance); for (Geometry geom : co.getGeometries()) {
if (nodesInRange.isEmpty()) { KDTree tree = new KDTree();
tree.add(v); for (Polygon poly : geom.getPolygons()) {
} else { LinearRing lr = poly.getExteriorRing();
// replace other vertex with any neighboring one updateRing(tree, lr);
Vertex original = nodesInRange.get(0); for (LinearRing innerRing : poly.getInnerRings()) {
lr.setVertex(i, original); updateRing(tree, innerRing);
} }
} }
} if (!config.useLowMemoryConsumption()) {
// no low memory consumption mode meaning create all meta information in
public void setCityModel(CityModel cModel) { // geometry
model.setCityModel(cModel); geom.updateEdgesAndVertices();
} }
}
public CityDoctorModel getModel() { }
return model;
} private void updateRing(KDTree tree, LinearRing lr) {
for (int i = 0; i < lr.getVertices().size(); i++) {
public void setCityGMLVersion(CityGMLVersion cityGMLVersion) { Vertex v = lr.getVertices().get(i);
model.setParsedCityGMLVersion(cityGMLVersion); List<Vertex> nodesInRange = tree.getNodesInRange(v, neighborDistance);
} if (nodesInRange.isEmpty()) {
tree.add(v);
} else {
// replace other vertex with any neighboring one
Vertex original = nodesInRange.get(0);
lr.setVertex(i, original);
}
}
}
public void setCityModel(CityModel cModel) {
model.setCityModel(cModel);
}
public CityDoctorModel getModel() {
return model;
}
public void setCityGMLVersion(CityGMLVersion cityGMLVersion) {
model.setParsedCityGMLVersion(cityGMLVersion);
}
} }
...@@ -59,7 +59,7 @@ public class Citygml3GeometryMapper extends GeometryWalker { ...@@ -59,7 +59,7 @@ public class Citygml3GeometryMapper extends GeometryWalker {
public void visit(Polygon polygon) { public void visit(Polygon polygon) {
parsePolygon(polygon.getId(), polygon.getExterior(), polygon.getInterior()); parsePolygon(polygon.getId(), polygon.getExterior(), polygon.getInterior());
if (polygon.getExterior() == null) { if (polygon.getExterior() == null) {
logger.warn(String.format("No exterior: %s", polygon.getId())); logger.warn("No exterior: {}", polygon.getId());
} }
} }
......
...@@ -34,7 +34,7 @@ import de.hft.stuttgart.citydoctor2.datastructure.Vertex; ...@@ -34,7 +34,7 @@ import de.hft.stuttgart.citydoctor2.datastructure.Vertex;
* *
*/ */
public class ProjectionAxis { public class ProjectionAxis {
private static final String DIVISOR_IS_0 = "Divisor is 0"; private static final String DIVISOR_IS_0 = "Divisor is 0";
private final int[] axis; private final int[] axis;
...@@ -87,20 +87,36 @@ public class ProjectionAxis { ...@@ -87,20 +87,36 @@ public class ProjectionAxis {
this.axis = axis; this.axis = axis;
} }
/**
* This will write the two coordinates determined in this projection axis into a
* given array at the startIndex location. The array has to have at least a
* length of startIndex + 1.
*
* @param v the vector from which the coordinates are taken.
* @param array the array that is written to.
* @param startIndex the start location in the array.
*/
public void writeCoordinatesOfVectorInArray(Vector3d v, double[] array, int startIndex) {
array[startIndex] = v.getCoordinate(axis[0]);
array[startIndex + 1] = v.getCoordinate(axis[1]);
}
public Vector2d project(Vector3d v) { public Vector2d project(Vector3d v) {
return new Vector2d(v.getCoordinate(axis[0]), v.getCoordinate(axis[1])); return new Vector2d(v.getCoordinate(axis[0]), v.getCoordinate(axis[1]));
} }
/** /**
* calculates the missing coordinate for 3d vector from the plane and this axis. * calculates the missing coordinate for 3d vector from the plane and this axis.
*
* @return the projected 3d point. * @return the projected 3d point.
*/ */
public Vector3d projectToPlane(Plane plane, Vector2d v) { public Vector3d projectToPlane(Plane plane, Vector2d v) {
return projectToPlane(plane, v.getX(), v.getY()); return projectToPlane(plane, v.getX(), v.getY());
} }
/** /**
* calculates the missing coordinate for 3d vector from the plane and this axis. * calculates the missing coordinate for 3d vector from the plane and this axis.
*
* @return the projected 3d point. * @return the projected 3d point.
*/ */
public Vector3d projectToPlane(Plane plane, double vectorX, double vectorY) { public Vector3d projectToPlane(Plane plane, double vectorX, double vectorY) {
......
...@@ -6,10 +6,8 @@ import java.util.List; ...@@ -6,10 +6,8 @@ import java.util.List;
import de.hft.stuttgart.citydoctor2.datastructure.LinearRing; import de.hft.stuttgart.citydoctor2.datastructure.LinearRing;
import de.hft.stuttgart.citydoctor2.datastructure.Polygon; import de.hft.stuttgart.citydoctor2.datastructure.Polygon;
import de.hft.stuttgart.citydoctor2.datastructure.Vertex; import de.hft.stuttgart.citydoctor2.datastructure.Vertex;
import de.hft.stuttgart.citydoctor2.math.Polygon2d; import de.hft.stuttgart.citydoctor2.math.ProjectionAxis;
import de.hft.stuttgart.citydoctor2.math.Ring2d;
import de.hft.stuttgart.citydoctor2.math.Triangle3d; import de.hft.stuttgart.citydoctor2.math.Triangle3d;
import de.hft.stuttgart.citydoctor2.math.Vector2d;
import earcut4j.Earcut; import earcut4j.Earcut;
/** /**
...@@ -35,8 +33,8 @@ public class EarcutTesselator { ...@@ -35,8 +33,8 @@ public class EarcutTesselator {
} }
} }
// collect vertices // collect vertices
// project polygon to 2D space as library is buggy for more than 2 dimensions // find most dominant projection axis for 2d projection
Polygon2d projectedPolygon = Polygon2d.withProjection(p); ProjectionAxis axis = ProjectionAxis.of(p);
double[] vertices = new double[nrOfVertices * 2]; double[] vertices = new double[nrOfVertices * 2];
List<Vertex> vertexObjects = new ArrayList<>(); List<Vertex> vertexObjects = new ArrayList<>();
...@@ -45,9 +43,10 @@ public class EarcutTesselator { ...@@ -45,9 +43,10 @@ public class EarcutTesselator {
addVerticesToList(innerRing, vertexObjects); addVerticesToList(innerRing, vertexObjects);
} }
int start = addRingToArray(projectedPolygon.getExterior(), vertices, 0); // write the vector data according to the projection axis into the array
for (Ring2d innerRing : projectedPolygon.getInteriorRings()) { int start = addRingToArray(p.getExteriorRing(), vertices, 0, axis);
start = addRingToArray(innerRing, vertices, start); for (LinearRing innerRing : p.getInnerRings()) {
start = addRingToArray(innerRing, vertices, start, axis);
} }
// triangulation // triangulation
...@@ -73,12 +72,12 @@ public class EarcutTesselator { ...@@ -73,12 +72,12 @@ public class EarcutTesselator {
} }
} }
private static int addRingToArray(Ring2d ring, double[] vertices, int start) { private static int addRingToArray(LinearRing ring, double[] vertices, int start, ProjectionAxis axis) {
List<Vector2d> ringVertices = ring.getVertices(); List<Vertex> ringVertices = ring.getVertices();
for (int i = 0; i < ringVertices.size() - 1; i++) { for (int i = 0; i < ringVertices.size() - 1; i++) {
Vector2d v = ringVertices.get(i); Vertex v = ringVertices.get(i);
vertices[start++] = v.getX(); axis.writeCoordinatesOfVectorInArray(v, vertices, start);
vertices[start++] = v.getY(); start = start + 2;
} }
return start; return start;
} }
......
...@@ -31,7 +31,6 @@ import java.util.concurrent.atomic.AtomicInteger; ...@@ -31,7 +31,6 @@ import java.util.concurrent.atomic.AtomicInteger;
import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.LogManager;
import org.apache.logging.log4j.Logger; import org.apache.logging.log4j.Logger;
import org.citygml4j.core.model.CityGMLVersion;
import org.citygml4j.core.model.core.AbstractCityObjectProperty; import org.citygml4j.core.model.core.AbstractCityObjectProperty;
import org.citygml4j.core.model.core.AbstractFeatureProperty; import org.citygml4j.core.model.core.AbstractFeatureProperty;
import org.citygml4j.core.model.core.CityModel; import org.citygml4j.core.model.core.CityModel;
......
<?xml version="1.0" encoding="utf-8"?> <?xml version="1.0" encoding="utf-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"> <project xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd" xmlns="http://maven.apache.org/POM/4.0.0">
<modelVersion>4.0.0</modelVersion> <modelVersion>4.0.0</modelVersion>
<parent> <parent>
<groupId>de.hft.stuttgart</groupId> <groupId>de.hft.stuttgart</groupId>
...@@ -65,11 +65,11 @@ ...@@ -65,11 +65,11 @@
<groupId>net.sf.saxon</groupId> <groupId>net.sf.saxon</groupId>
<artifactId>Saxon-HE</artifactId> <artifactId>Saxon-HE</artifactId>
</dependency> </dependency>
<dependency> <dependency>
<groupId>org.yaml</groupId> <groupId>org.yaml</groupId>
<artifactId>snakeyaml</artifactId> <artifactId>snakeyaml</artifactId>
</dependency> </dependency>
</dependencies> </dependencies>
<build> <build>
<resources> <resources>
<resource> <resource>
......
...@@ -426,6 +426,7 @@ public class Checker { ...@@ -426,6 +426,7 @@ public class Checker {
} }
} }
@SuppressWarnings("resource")
public static SvrlContentHandler executeSchematronValidationIfAvailable(ValidationConfiguration config, public static SvrlContentHandler executeSchematronValidationIfAvailable(ValidationConfiguration config,
InputStream in) { InputStream in) {
if (config.getSchematronFilePath() != null && !config.getSchematronFilePath().isEmpty()) { if (config.getSchematronFilePath() != null && !config.getSchematronFilePath().isEmpty()) {
......
...@@ -65,23 +65,19 @@ public class SvrlContentHandler implements ContentHandler { ...@@ -65,23 +65,19 @@ public class SvrlContentHandler implements ContentHandler {
public void setDocumentLocator(Locator locator) { public void setDocumentLocator(Locator locator) {
// not needed // not needed
} }
@SuppressWarnings("RedundantThrows")
@Override @Override
public void startDocument() throws SAXException { public void startDocument() throws SAXException {
// not needed // not needed
} }
@SuppressWarnings("RedundantThrows")
@Override @Override
public void endDocument() throws SAXException { public void endDocument() throws SAXException {
// not needed // not needed
} }
@SuppressWarnings("RedundantThrows")
@Override @Override
public void startPrefixMapping(String prefix, String uri) throws SAXException { public void startPrefixMapping(String prefix, String uri) throws SAXException {
// not needed // not needed
} }
@SuppressWarnings("RedundantThrows")
@Override @Override
public void endPrefixMapping(String prefix) throws SAXException { public void endPrefixMapping(String prefix) throws SAXException {
// not needed // not needed
...@@ -133,17 +129,14 @@ public class SvrlContentHandler implements ContentHandler { ...@@ -133,17 +129,14 @@ public class SvrlContentHandler implements ContentHandler {
buffer.append(ch, start, length); buffer.append(ch, start, length);
} }
} }
@SuppressWarnings("RedundantThrows")
@Override @Override
public void ignorableWhitespace(char[] ch, int start, int length) throws SAXException { public void ignorableWhitespace(char[] ch, int start, int length) throws SAXException {
// not needed // not needed
} }
@SuppressWarnings("RedundantThrows")
@Override @Override
public void processingInstruction(String target, String data) throws SAXException { public void processingInstruction(String target, String data) throws SAXException {
// not needed // not needed
} }
@SuppressWarnings("RedundantThrows")
@Override @Override
public void skippedEntity(String name) throws SAXException { public void skippedEntity(String name) throws SAXException {
// not needed // not needed
......
...@@ -76,7 +76,6 @@ public class SolidSelfIntCheck extends Check { ...@@ -76,7 +76,6 @@ public class SolidSelfIntCheck extends Check {
} }
CheckResult cr; CheckResult cr;
List<PolygonIntersection> intersections = SelfIntersectionUtil.calculateSolidSelfIntersection(g); List<PolygonIntersection> intersections = SelfIntersectionUtil.calculateSolidSelfIntersection(g);
// List<PolygonIntersection> intersections = SelfIntersectionUtil.doesSolidSelfIntersect2(g);
if (intersections.isEmpty()) { if (intersections.isEmpty()) {
cr = new CheckResult(this, ResultStatus.OK, null); cr = new CheckResult(this, ResultStatus.OK, null);
} else { } else {
......
...@@ -36,7 +36,6 @@ public class SolidSelfIntCheckFalsePositiveBigMeshTest { ...@@ -36,7 +36,6 @@ public class SolidSelfIntCheckFalsePositiveBigMeshTest {
Checker c = new Checker(config, m); Checker c = new Checker(config, m);
c.runChecks(); c.runChecks();
Building building = m.getBuildings().get(0); Building building = m.getBuildings().get(0);
System.out.println(building.containsAnyError());
/* /*
* The examples have no actual self-intersections, but can contain other actual model defects. * The examples have no actual self-intersections, but can contain other actual model defects.
* If an error is detected, it is thus required to check if the * If an error is detected, it is thus required to check if the
......
Supports Markdown
0% or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment