本文整理汇总了Java中org.citygml4j.xml.io.CityGMLInputFactory类的典型用法代码示例。如果您正苦于以下问题:Java CityGMLInputFactory类的具体用法?Java CityGMLInputFactory怎么用?Java CityGMLInputFactory使用的例子?那么恭喜您, 这里精选的类代码示例或许可以为您提供帮助。
CityGMLInputFactory类属于org.citygml4j.xml.io包,在下文中一共展示了CityGMLInputFactory类的15个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的Java代码示例。
示例1: getProperty
import org.citygml4j.xml.io.CityGMLInputFactory; //导入依赖的package包/类
public Object getProperty(String name) {
Objects.requireNonNull("property name may not be null.");
if (name.equals(CityGMLInputFactory.FEATURE_READ_MODE))
return featureReadMode;
if (name.equals(CityGMLInputFactory.KEEP_INLINE_APPEARANCE))
return keepInlineAppearance;
if (name.equals(CityGMLInputFactory.PARSE_SCHEMA))
return parseSchema;
if (name.equals(CityGMLInputFactory.USE_VALIDATION))
return useValidation;
if (name.equals(CityGMLInputFactory.EXCLUDE_FROM_SPLITTING))
return excludes;
if (name.equals(CityGMLInputFactory.SPLIT_AT_FEATURE_PROPERTY))
return splitAtFeatureProperties;
if (name.equals(CityGMLInputFactory.FAIL_ON_MISSING_ADE_SCHEMA))
return failOnMissingADESchema;
if (name.equals(CityGMLInputFactory.SUPPORT_CITYGML_VERSION_0_4_0))
return supportCityGML040;
throw new IllegalArgumentException("the property '" + name + "' is not supported.");
}
示例2: readCityGMLFile
import org.citygml4j.xml.io.CityGMLInputFactory; //导入依赖的package包/类
/**
* Returns a list for BuildingCallable read by CityGML file
*
* @param pathtocitygmlfile
* @param options
* @return List<BuildingCallable>
* @throws Exception
*/
public List<BuildingCallable> readCityGMLFile(String pathtocitygmlfile, Options options) throws Exception {
this.options = options;
List<BuildingCallable> buildings = new ArrayList<BuildingCallable>();
CityGMLContext ctx = new CityGMLContext();
CityGMLBuilder builder = ctx.createCityGMLBuilder();
CityGMLInputFactory in = builder.createCityGMLInputFactory();
CityGMLReader reader = in.createCityGMLReader(new File(pathtocitygmlfile));
while (reader.hasNext()) {
CityGML citygml = reader.nextFeature();
if (citygml.getCityGMLClass() == CityGMLClass.CITY_MODEL) {
CityModel cityModel = (CityModel)citygml;
for (CityObjectMember cityObjectMember : cityModel.getCityObjectMember()) {
AbstractCityObject cityObject = cityObjectMember.getCityObject();
if (cityObject.getCityGMLClass() == CityGMLClass.BUILDING){
Building building = (Building)cityObject;
String buildingID = building.getId();
BuildingCallable buildingcallable = new BuildingCallable();
buildingcallable.setBsp(building.getBoundedBySurface());
buildingcallable.setBuildingId(buildingID);
buildingcallable.setOptions(options);
buildings.add(buildingcallable);
}
}
}
}
reader.close();
return buildings;
}
示例3: AbstractJAXBReader
import org.citygml4j.xml.io.CityGMLInputFactory; //导入依赖的package包/类
@SuppressWarnings("unchecked")
public AbstractJAXBReader(XMLStreamReader reader, InputStream in, JAXBInputFactory factory, URI baseURI) throws CityGMLReadException {
if ((Boolean)factory.getProperty(CityGMLInputFactory.SUPPORT_CITYGML_VERSION_0_4_0))
reader = new CityGMLNamespaceMapper(reader);
this.reader = reader;
this.in = in;
this.factory = factory;
this.baseURI = baseURI;
transformerChainFactory = factory.getTransformerChainFactory();
parseSchema = (Boolean)factory.getProperty(CityGMLInputFactory.PARSE_SCHEMA);
useValidation = (Boolean)factory.getProperty(CityGMLInputFactory.USE_VALIDATION);
failOnMissingADESchema = (Boolean)factory.getProperty(CityGMLInputFactory.FAIL_ON_MISSING_ADE_SCHEMA);
schemaHandler = factory.getSchemaHandler();
jaxbUnmarshaller = factory.builder.createJAXBUnmarshaller(schemaHandler);
jaxbUnmarshaller.setThrowMissingADESchema(failOnMissingADESchema);
elementChecker = new XMLElementChecker(schemaHandler,
(FeatureReadMode)factory.getProperty(CityGMLInputFactory.FEATURE_READ_MODE),
(Boolean)factory.getProperty(CityGMLInputFactory.KEEP_INLINE_APPEARANCE),
parseSchema,
failOnMissingADESchema,
(List<QName>)factory.getProperty(CityGMLInputFactory.EXCLUDE_FROM_SPLITTING),
(List<QName>)factory.getProperty(CityGMLInputFactory.SPLIT_AT_FEATURE_PROPERTY));
if (useValidation) {
validationSchemaHandler = new ValidationSchemaHandler(schemaHandler);
validationEventHandler = factory.getValidationEventHandler();
}
}
示例4: main
import org.citygml4j.xml.io.CityGMLInputFactory; //导入依赖的package包/类
public static void main(String[] args) throws Exception {
SimpleDateFormat df = new SimpleDateFormat("[HH:mm:ss] ");
System.out.println(df.format(new Date()) + "setting up citygml4j context and CityGML builder");
CityGMLContext ctx = CityGMLContext.getInstance();
CityGMLBuilder builder = ctx.createCityGMLBuilder();
System.out.println(df.format(new Date()) + "reading only roads from CityGML file LOD2_CityObjectGroup_v100.gml");
CityGMLInputFactory in = builder.createCityGMLInputFactory();
in.setProperty(CityGMLInputFactory.FEATURE_READ_MODE, FeatureReadMode.SPLIT_PER_FEATURE);
CityGMLReader reader = in.createCityGMLReader(new File("datasets/LOD2_CityObjectGroup_v100.gml"));
reader = in.createFilteredCityGMLReader(reader, new CityGMLInputFilter() {
// return true if you want to consume the CityGML feature
// of the given qualified XML name, false otherwise
public boolean accept(QName name) {
return Modules.isModuleNamespace(name.getNamespaceURI(), CityGMLModuleType.TRANSPORTATION)
&& name.getLocalPart().equals("Road");
}
});
System.out.println(df.format(new Date()) + "printing road features");
while (reader.hasNext()) {
Road road = (Road)reader.nextFeature();
System.out.println(df.format(new Date()) + "found Road with gml:id " + road.getId());
System.out.println(df.format(new Date()) + "\t" + road.getTrafficArea().size() + " traffic area(s)");
System.out.println(df.format(new Date()) + "\t" + road.getAuxiliaryTrafficArea().size() + " auxiliary traffic area(s)");
}
reader.close();
System.out.println(df.format(new Date()) + "sample citygml4j application successfully finished");
}
示例5: main
import org.citygml4j.xml.io.CityGMLInputFactory; //导入依赖的package包/类
public static void main(String[] args) throws Exception {
SimpleDateFormat df = new SimpleDateFormat("[HH:mm:ss] ");
System.out.println(df.format(new Date()) + "setting up citygml4j context and CityGML builder");
CityGMLContext ctx = CityGMLContext.getInstance();
CityGMLBuilder builder = ctx.createCityGMLBuilder();
System.out.println(df.format(new Date()) + "reading CityGML file LOD2_Buildings_v100.gml completely into main memory");
CityGMLInputFactory in = builder.createCityGMLInputFactory();
CityGMLReader reader = in.createCityGMLReader(new File("datasets/LOD2_Buildings_v100.gml"));
while (reader.hasNext()) {
CityGML citygml = reader.nextFeature();
if (citygml.getCityGMLClass() == CityGMLClass.CITY_MODEL) {
CityModel cityModel = (CityModel)citygml;
System.out.println(df.format(new Date()) + "Found " + citygml.getCityGMLClass() + " version " + cityModel.getCityGMLModule().getVersion());
System.out.println(df.format(new Date()) + "going through city model and counting building instances");
int count = 0;
for (CityObjectMember cityObjectMember : cityModel.getCityObjectMember()) {
AbstractCityObject cityObject = cityObjectMember.getCityObject();
if (cityObject.getCityGMLClass() == CityGMLClass.BUILDING)
count++;
}
System.out.println(df.format(new Date()) + "The city model contains " + count + " building features");
}
}
reader.close();
System.out.println(df.format(new Date()) + "sample citygml4j application successfully finished");
}
示例6: main
import org.citygml4j.xml.io.CityGMLInputFactory; //导入依赖的package包/类
public static void main(String[] args) throws Exception {
SimpleDateFormat df = new SimpleDateFormat("[HH:mm:ss] ");
System.out.println(df.format(new Date()) + "setting up citygml4j context and CityGML builder");
CityGMLContext ctx = CityGMLContext.getInstance();
CityGMLBuilder builder = ctx.createCityGMLBuilder();
System.out.println(df.format(new Date()) + "reading CityGML file LOD3_Building_v200.gml feature by feature");
CityGMLInputFactory in = builder.createCityGMLInputFactory();
in.setProperty(CityGMLInputFactory.FEATURE_READ_MODE, FeatureReadMode.SPLIT_PER_FEATURE);
in.setProperty(CityGMLInputFactory.EXCLUDE_FROM_SPLITTING, new QName[]{new QName("Door"), new QName("Address")});
// see difference when setting to true
in.setProperty(CityGMLInputFactory.KEEP_INLINE_APPEARANCE, false);
CityGMLReader reader = in.createCityGMLReader(new File("datasets/LOD3_Building_v200.gml"));
System.out.println(df.format(new Date()) + "printing feature currently read and its (transitive) parents");
while (reader.hasNext()) {
CityGML chunk = reader.nextFeature();
System.out.println("found: " + chunk.getCityGMLClass());
if (reader.isSetParentInfo()) {
ParentInfo parentInfo = reader.getParentInfo();
System.out.println(" --parent: " + parentInfo.getCityGMLClass());
while ((parentInfo = parentInfo.getParentInfo()) != null)
System.out.println(" --transitive parent: " + parentInfo.getCityGMLClass());
}
}
reader.close();
System.out.println(df.format(new Date()) + "sample citygml4j application successfully finished");
}
示例7: main
import org.citygml4j.xml.io.CityGMLInputFactory; //导入依赖的package包/类
public static void main(String[] args) throws Exception {
SimpleDateFormat df = new SimpleDateFormat("[HH:mm:ss] ");
System.out.println(df.format(new Date()) + "setting up citygml4j context and CityGML builder");
CityGMLContext ctx = CityGMLContext.getInstance();
CityGMLBuilder builder = ctx.createCityGMLBuilder();
System.out.println(df.format(new Date()) + "reading ADE-enriched CityGML file LOD2_SubsurfaceStructureADE_invalid_v100.gml");
System.out.println(df.format(new Date()) + "ADE schema file is read from xsi:schemaLocation attribute on root XML element");
CityGMLInputFactory in = builder.createCityGMLInputFactory();
in.setProperty(CityGMLInputFactory.FEATURE_READ_MODE, FeatureReadMode.NO_SPLIT);
in.parseSchema(new File("datasets/schemas/CityGML-SubsurfaceADE-0_9_0.xsd"));
in.setProperty(CityGMLInputFactory.USE_VALIDATION, true);
in.setValidationEventHandler(event -> {
System.out.print("[" + event.getLocator().getLineNumber() + "," + event.getLocator().getColumnNumber() + "] ");
System.out.println(event.getMessage());
return true;
});
System.out.println(df.format(new Date()) + "validating ADE-enriched CityGML document whilst reading");
CityGMLReader reader = in.createCityGMLReader(new File("datasets/LOD2_SubsurfaceStructureADE_invalid_v100.gml"));
reader.nextFeature();
reader.close();
System.out.println(df.format(new Date()) + "sample citygml4j application successfully finished");
}
示例8: main
import org.citygml4j.xml.io.CityGMLInputFactory; //导入依赖的package包/类
public static void main(String[] args) throws Exception {
SimpleDateFormat df = new SimpleDateFormat("[HH:mm:ss] ");
System.out.println(df.format(new Date()) + "setting up citygml4j context and CityGML builder");
CityGMLContext ctx = CityGMLContext.getInstance();
CityGMLBuilder builder = ctx.createCityGMLBuilder();
System.out.println(df.format(new Date()) + "reading ADE-enriched CityGML file LOD2_SubsurfaceStructureADE_invalid_v100.gml feature by feature");
System.out.println(df.format(new Date()) + "ADE schema file is read from xsi:schemaLocation attribute on root XML element");
CityGMLInputFactory in = builder.createCityGMLInputFactory();
in.setProperty(CityGMLInputFactory.FEATURE_READ_MODE, FeatureReadMode.SPLIT_PER_FEATURE);
in.setProperty(CityGMLInputFactory.USE_VALIDATION, true);
in.registerSchemaLocation("http://www.citygml.org/ade/sub/0.9.0", new File("datasets/schemas/CityGML-SubsurfaceADE-0_9_0.xsd"));
ValidationEventHandlerImpl validationEventHandler = new ValidationEventHandlerImpl();
in.setValidationEventHandler(validationEventHandler);
CityGMLReader reader = in.createCityGMLReader(new File("datasets/LOD2_SubsurfaceStructureADE_invalid_v100.gml"));
System.out.println(df.format(new Date()) + "validating features whilst reading from file");
while (reader.hasNext()) {
CityGML chunk = reader.nextFeature();
String type;
if (chunk instanceof ADEGenericElement){
Element element = ((ADEGenericElement)chunk).getContent();
type = element.getPrefix() + ':' + element.getLocalName();
} else
type = chunk.getCityGMLClass().toString();
System.out.print(type + ": ");
System.out.println(validationEventHandler.isValid ? "valid" : "invalid (see error messages above)");
validationEventHandler.isValid = true;
}
reader.close();
System.out.println(df.format(new Date()) + "sample citygml4j application successfully finished");
}
示例9: main
import org.citygml4j.xml.io.CityGMLInputFactory; //导入依赖的package包/类
public static void main(String[] args) throws Exception {
SimpleDateFormat df = new SimpleDateFormat("[HH:mm:ss] ");
System.out.println(df.format(new Date()) + "setting up citygml4j context and CityGML builder");
CityGMLContext ctx = CityGMLContext.getInstance();
CityGMLBuilder builder = ctx.createCityGMLBuilder();
System.out.println(df.format(new Date()) + "setting up schema handler");
SchemaHandler schemaHandler = SchemaHandler.newInstance();
schemaHandler.setSchemaEntityResolver(new SchemaEntityResolver());
schemaHandler.setErrorHandler(new SchemaParseErrorHandler());
System.out.println(df.format(new Date()) + "reading ADE-enriched CityGML file LOD0_Railway_NoiseADE_missing_ADE_reference_v200.gml");
System.out.println(df.format(new Date()) + "note: the input document is lacking a reference to the ADE schema document");
CityGMLInputFactory in = builder.createCityGMLInputFactory(schemaHandler);
in.setProperty(CityGMLInputFactory.FEATURE_READ_MODE, FeatureReadMode.SPLIT_PER_FEATURE);
CityGMLReader reader = in.createCityGMLReader(new File("datasets/LOD0_Railway_NoiseADE_missing_ADE_reference_v200.gml"));
while (reader.hasNext()) {
CityGML citygml = reader.nextFeature();
if (citygml instanceof AbstractFeature)
System.out.println("Found CityGML: " + citygml.getCityGMLClass());
else if (citygml instanceof ADEGenericElement)
System.out.println("Found ADE: " + ((ADEGenericElement)citygml).getContent().getLocalName());
}
reader.close();
System.out.println(df.format(new Date()) + "sample citygml4j application successfully finished");
}
示例10: main
import org.citygml4j.xml.io.CityGMLInputFactory; //导入依赖的package包/类
public static void main(String[] args) throws Exception {
SimpleDateFormat df = new SimpleDateFormat("[HH:mm:ss] ");
System.out.println(df.format(new Date()) + "setting up citygml4j context and CityGML builder");
CityGMLContext ctx = CityGMLContext.getInstance();
CityGMLBuilder builder = ctx.createCityGMLBuilder();
System.out.println(df.format(new Date()) + "setting up schema handler");
SchemaHandler schemaHandler = SchemaHandler.newInstance();
schemaHandler.setSchemaEntityResolver(new SchemaEntityResolver());
schemaHandler.setErrorHandler(new SchemaParseErrorHandler());
// register false schema location in order to provoke a schema parse error
schemaHandler.registerSchemaLocation("http://www.citygml.org/ade/noise_de/2.0",
new File("/nowhere/nofile.xsd"));
System.out.println(df.format(new Date()) + "reading ADE-enriched CityGML file LOD0_Railway_NoiseADE_v200.gml");
CityGMLInputFactory in = builder.createCityGMLInputFactory(schemaHandler);
in.setProperty(CityGMLInputFactory.FEATURE_READ_MODE, FeatureReadMode.SPLIT_PER_FEATURE);
CityGMLReader reader = in.createCityGMLReader(new File("datasets/LOD0_Railway_NoiseADE_v200.gml"));
while (reader.hasNext()) {
CityGML citygml = reader.nextFeature();
if (citygml instanceof AbstractFeature)
System.out.println("Found CityGML: " + citygml.getCityGMLClass());
else if (citygml instanceof ADEGenericElement)
System.out.println("Found ADE: " + ((ADEGenericElement)citygml).getContent().getLocalName());
}
reader.close();
System.out.println(df.format(new Date()) + "sample citygml4j application successfully finished");
}
示例11: main
import org.citygml4j.xml.io.CityGMLInputFactory; //导入依赖的package包/类
public static void main(String[] args) throws Exception {
SimpleDateFormat df = new SimpleDateFormat("[HH:mm:ss] ");
System.out.println(df.format(new Date()) + "setting up citygml4j context and CityGML builder");
CityGMLContext ctx = CityGMLContext.getInstance();
CityGMLBuilder builder = ctx.createCityGMLBuilder();
System.out.println(df.format(new Date()) + "reading ADE-enriched CityGML file LOD0_Railway_NoiseADE_v200.gml");
System.out.println(df.format(new Date()) + "ADE schema file is read from xsi:schemaLocation attribute on root XML element");
CityGMLInputFactory in = builder.createCityGMLInputFactory();
CityGMLReader reader = in.createCityGMLReader(new File("datasets/LOD0_Railway_NoiseADE_v200.gml"));
CityGML citygml = reader.nextFeature();
reader.close();
System.out.println(df.format(new Date()) + "exploring ADE content of Railway element");
CityModel cityModel = (CityModel)citygml;
Railway railway = (Railway)cityModel.getCityObjectMember().get(0).getCityObject();
if (railway.isSetGenericApplicationPropertyOfRailway()) {
System.out.println("Found ADE content for Railway instance:\n");
List<ADEComponent> ades = railway.getGenericApplicationPropertyOfRailway();
for (ADEComponent ade : ades) {
if (ade.getADEClass() == ADEClass.GENERIC_ELEMENT)
checkADE(in.getSchemaHandler(), ((ADEGenericElement)ade).getContent(), null, 0);
}
}
System.out.println(df.format(new Date()) + "sample citygml4j application successfully finished");
}
示例12: main
import org.citygml4j.xml.io.CityGMLInputFactory; //导入依赖的package包/类
public static void main(String[] args) throws Exception {
SimpleDateFormat df = new SimpleDateFormat("[HH:mm:ss] ");
System.out.println(df.format(new Date()) + "setting up citygml4j context and CityGML builder");
CityGMLContext ctx = CityGMLContext.getInstance();
CityGMLBuilder builder = ctx.createCityGMLBuilder();
System.out.println(df.format(new Date()) + "reading ADE-enriched CityGML file LOD0_Railway_NoiseADE_from_Web_v200.gml");
System.out.println(df.format(new Date()) + "remote ADE schema file is read from xsi:schemaLocation attribute on root XML element");
CityGMLInputFactory in = builder.createCityGMLInputFactory();
CityGMLReader reader = in.createCityGMLReader(new File("datasets/LOD0_Railway_NoiseADE_from_Web_v200.gml"));
CityGML citygml = reader.nextFeature();
reader.close();
System.out.println(df.format(new Date()) + "exploring ADE content of Railway element");
CityModel cityModel = (CityModel)citygml;
Railway railway = (Railway)cityModel.getCityObjectMember().get(0).getCityObject();
if (railway.isSetGenericApplicationPropertyOfRailway()) {
System.out.println("Found ADE content for Railway instance:\n");
List<ADEComponent> ades = railway.getGenericApplicationPropertyOfRailway();
for (ADEComponent ade : ades) {
if (ade.getADEClass() == ADEClass.GENERIC_ELEMENT)
checkADE(in.getSchemaHandler(), ((ADEGenericElement)ade).getContent(), null, 0);
}
}
System.out.println(df.format(new Date()) + "sample citygml4j application successfully finished");
}
示例13: createCityGMLInputFactory
import org.citygml4j.xml.io.CityGMLInputFactory; //导入依赖的package包/类
public CityGMLInputFactory createCityGMLInputFactory() throws CityGMLBuilderException {
return new JAXBInputFactory(this);
}
示例14: main
import org.citygml4j.xml.io.CityGMLInputFactory; //导入依赖的package包/类
public static void main(String[] args) throws Exception {
SimpleDateFormat df = new SimpleDateFormat("[HH:mm:ss] ");
System.out.println(df.format(new Date()) + "setting up citygml4j context and CityGML builder");
CityGMLContext ctx = CityGMLContext.getInstance();
CityGMLBuilder builder = ctx.createCityGMLBuilder();
// create a fixed thread pool
int nThreads = Runtime.getRuntime().availableProcessors() * 2;
System.out.println(df.format(new Date()) + "setting up thread pool with " + nThreads + " threads");
ExecutorService service = Executors.newFixedThreadPool(nThreads);
System.out.println(df.format(new Date()) + "reading LOD3_Railway_v200.gml in a multithreaded fashion");
// create a validating reader that chunks the input file on a per feature level
CityGMLInputFactory in = builder.createCityGMLInputFactory();
in.setProperty(CityGMLInputFactory.FEATURE_READ_MODE, FeatureReadMode.SPLIT_PER_FEATURE);
in.setProperty(CityGMLInputFactory.USE_VALIDATION, true);
CityGMLReader reader = in.createCityGMLReader(new File("datasets/LOD3_Railway_v200.gml"));
while (reader.hasNext()) {
// whereas the nextFeature() method of a CityGML reader completely unmarshals the
// XML chunk to an instance of the citygml4j object model and optionally validates
// it before returning, the nextChunk() method returns faster but only provides a
// set of SAX events.
final XMLChunk chunk = reader.nextChunk();
// we forward every XML chunk to a separate thread of the thread pool
// for unmarshalling and validation
service.execute(() -> {
try {
chunk.unmarshal();
} catch (UnmarshalException | MissingADESchemaException e) {
//
}
// invoking the hasPassedXMLValidation() method prior to unmarshal()
// or when using a non-validating CityGML reader will always yield false.
boolean isValid = chunk.hasPassedXMLValidation();
System.out.println("Thread '" + Thread.currentThread().getName() + "' unmarshalled " + chunk.getCityGMLClass() + "; valid: " + isValid);
});
}
System.out.println(df.format(new Date()) + "shutting down threadpool");
service.shutdown();
service.awaitTermination(120, TimeUnit.SECONDS);
reader.close();
System.out.println(df.format(new Date()) + "sample citygml4j application successfully finished");
}
示例15: main
import org.citygml4j.xml.io.CityGMLInputFactory; //导入依赖的package包/类
public static void main(String[] args) throws Exception {
SimpleDateFormat df = new SimpleDateFormat("[HH:mm:ss] ");
System.out.println(df.format(new Date()) + "setting up citygml4j context and CityGML builder");
CityGMLContext ctx = CityGMLContext.getInstance();
CityGMLBuilder builder = ctx.createCityGMLBuilder();
System.out.println(df.format(new Date()) + "reading CityGML file LOD2_Building_v100.gml");
CityGMLInputFactory in = builder.createCityGMLInputFactory();
CityGMLReader reader = in.createCityGMLReader(new File("datasets/LOD2_Building_v100.gml"));
CityModel cityModel = (CityModel)reader.nextFeature();
reader.close();
System.out.println(df.format(new Date()) + "retrieving object with gml:id UUID_08371879-bde6-4ba6-9fc6-088ee2ce1913");
XLinkResolver resolver = new XLinkResolver();
AbstractGeometry geometry = resolver.getGeometry("UUID_08371879-bde6-4ba6-9fc6-088ee2ce1913", cityModel);
System.out.println("gml:id 'UUID_08371879-bde6-4ba6-9fc6-088ee2ce1913' belongs to: " + geometry.getGMLClass());
System.out.println(df.format(new Date()) + "retrieving direct and transitive parents");
ChildInfo info = new ChildInfo();
System.out.println("Direct parent XML element: " + ((GML)geometry.getParent()).getGMLClass());
AbstractGeometry parentGeometry = info.getParentGeometry(geometry);
System.out.println("Direct parent geometry: " + parentGeometry.getGMLClass()
+ ", gml:id='" + parentGeometry.getId() + "'");
AbstractCityObject parentCityObject = info.getParentCityObject(geometry);
System.out.println("Direct parent CityObject: " + parentCityObject.getCityGMLClass()
+ ", gml:id='" + parentCityObject.getId() + "'");
Building parentCityObjectByType = info.getParentCityObject(geometry, Building.class);
System.out.println("Transitive parent CityObject of type Building: " + parentCityObjectByType.getCityGMLClass()
+ ", gml:id='" + parentCityObjectByType.getId() + "'");
LandUse noParent = info.getParentCityObject(geometry, LandUse.class);
System.out.println("Transitive parent CityObject of type LandUse: " + noParent);
AbstractCityObject rootCityObject = info.getRootCityObject(geometry);
System.out.println("Root CityObject: " + rootCityObject.getCityGMLClass()
+ ", gml:id='" + rootCityObject.getId() + "'");
CityGML rootFeature = info.getRootCityGML(geometry);
System.out.println("Root CityGML instance: " + rootFeature.getCityGMLClass());
System.out.println(df.format(new Date()) + "sample citygml4j application successfully finished");
}