X-Git-Url: https://gerrit.simantics.org/r/gitweb?a=blobdiff_plain;ds=sidebyside;f=org.simantics.district.network%2Fsrc%2Forg%2Fsimantics%2Fdistrict%2Fnetwork%2FDistrictNetworkUtil.java;h=94799a97382e57a23a31b404f64e785f7d751245;hb=refs%2Fchanges%2F69%2F469%2F1;hp=f9e0439dc02656dfcd2f9ba711610bc91d3acf08;hpb=a2e0d3dfba1245a13dcc8aa23c0188926e2a03c5;p=simantics%2Fdistrict.git diff --git a/org.simantics.district.network/src/org/simantics/district/network/DistrictNetworkUtil.java b/org.simantics.district.network/src/org/simantics/district/network/DistrictNetworkUtil.java index f9e0439d..94799a97 100644 --- a/org.simantics.district.network/src/org/simantics/district/network/DistrictNetworkUtil.java +++ b/org.simantics.district.network/src/org/simantics/district/network/DistrictNetworkUtil.java @@ -1,37 +1,90 @@ -package org.simantics.district.network; - -import org.simantics.db.Resource; -import org.simantics.db.WriteGraph; -import org.simantics.db.common.utils.OrderedSetUtils; -import org.simantics.db.exception.DatabaseException; -import org.simantics.diagram.stubs.DiagramResource; -import org.simantics.district.network.ontology.DistrictNetworkResource; -import org.simantics.layer0.Layer0; - -public class DistrictNetworkUtil { - - public static Resource createEdge(WriteGraph graph, Resource composite) throws DatabaseException { - Layer0 L0 = Layer0.getInstance(graph); - DistrictNetworkResource DN = DistrictNetworkResource.getInstance(graph); - DiagramResource DIA = DiagramResource.getInstance(graph); - - Resource edge = graph.newResource(); - graph.claim(edge, L0.InstanceOf, DN.Edge); - OrderedSetUtils.addFirst(graph, composite, edge); - graph.claim(composite, L0.ConsistsOf, L0.PartOf, edge); - return edge; - } - - public static Resource createVertex(WriteGraph graph, Resource composite, double[] coords) throws DatabaseException { - Layer0 L0 = Layer0.getInstance(graph); - DistrictNetworkResource DN = DistrictNetworkResource.getInstance(graph); - DiagramResource DIA = DiagramResource.getInstance(graph); - Resource vertex = graph.newResource(); - graph.claim(vertex, L0.InstanceOf, DN.Vertex); - graph.claimLiteral(vertex, DIA.HasLocation, coords); - OrderedSetUtils.addFirst(graph, composite, vertex); - graph.claim(composite, L0.ConsistsOf, L0.PartOf, vertex); - - return vertex; - } -} +package org.simantics.district.network; + +import java.util.Collection; +import java.util.Iterator; + +import org.simantics.databoard.Bindings; +import org.simantics.db.ReadGraph; +import org.simantics.db.Resource; +import org.simantics.db.WriteGraph; +import org.simantics.db.common.utils.OrderedSetUtils; +import org.simantics.db.exception.DatabaseException; +import org.simantics.diagram.stubs.DiagramResource; +import org.simantics.district.network.ontology.DistrictNetworkResource; +import org.simantics.layer0.Layer0; + +public class DistrictNetworkUtil { + + public static Resource createEdge(WriteGraph graph, Resource composite) throws DatabaseException { + Layer0 L0 = Layer0.getInstance(graph); + DistrictNetworkResource DN = DistrictNetworkResource.getInstance(graph); + + Resource edge = graph.newResource(); + graph.claim(edge, L0.InstanceOf, DN.Edge); + + Resource defaultEdgeMapping = graph.getPossibleObject(composite, DN.EdgeDefaultMapping); + graph.claim(edge, DN.HasMapping, defaultEdgeMapping); + + OrderedSetUtils.add(graph, composite, edge); + graph.claim(composite, L0.ConsistsOf, L0.PartOf, edge); + return edge; + } + + public static Resource createVertex(WriteGraph graph, Resource composite, double[] coords) throws DatabaseException { + Layer0 L0 = Layer0.getInstance(graph); + DistrictNetworkResource DN = DistrictNetworkResource.getInstance(graph); + DiagramResource DIA = DiagramResource.getInstance(graph); + Resource vertex = graph.newResource(); + graph.claim(vertex, L0.InstanceOf, DN.Vertex); + graph.claimLiteral(vertex, DIA.HasLocation, coords); + + Resource defaultVertexMapping = graph.getPossibleObject(composite, DN.VertexDefaultMapping); + graph.claim(vertex, DN.HasMapping, defaultVertexMapping); + + OrderedSetUtils.add(graph, composite, vertex); + graph.claim(composite, L0.ConsistsOf, L0.PartOf, vertex); + + return vertex; + } + + public static Resource joinVertices(WriteGraph graph, Collection vertices) throws DatabaseException { + if (vertices.isEmpty()) + throw new IllegalArgumentException("vertices-collection should not be empty for joining vertices!"); + DistrictNetworkResource DN = DistrictNetworkResource.getInstance(graph); + Iterator verticeIterator = vertices.iterator(); + Resource master = verticeIterator.next(); + while (verticeIterator.hasNext()) { + Resource slave = verticeIterator.next(); + Resource composite = graph.getSingleObject(slave, Layer0.getInstance(graph).PartOf); + Collection startVertexEdges = graph.getObjects(slave, DN.HasStartVertex_Inverse); + for (Resource startVertexEdge : startVertexEdges) { + graph.deny(startVertexEdge, DN.HasStartVertex); + graph.claim(startVertexEdge, DN.HasStartVertex, master); + } + Collection endVertexEdges = graph.getObjects(slave, DN.HasEndVertex_Inverse); + for (Resource endVertexEdge : endVertexEdges) { + graph.deny(endVertexEdge, DN.HasEndVertex); + graph.claim(endVertexEdge, DN.HasEndVertex, master); + } + OrderedSetUtils.remove(graph, composite, slave); + } + return master; + } + + public static double calculateDistance(ReadGraph graph, Resource startVertex, Resource endVertex) throws DatabaseException { + Layer0 L0 = Layer0.getInstance(graph); + Resource startComposite = graph.getSingleObject(startVertex, L0.PartOf); + Resource endComposite = graph.getSingleObject(endVertex, L0.PartOf); + if (!startComposite.equalsResource(endComposite)) { + throw new DatabaseException("Can not calculate distance between vertices on different composites! " + startVertex + " -> " + endVertex); + } + Resource crs = graph.getSingleObject(startComposite, DistrictNetworkResource.getInstance(graph).HasSpatialRefSystem); + + CRS crsClass = graph.adapt(crs, CRS.class); + + double[] startCoords = graph.getRelatedValue2(startVertex, DiagramResource.getInstance(graph).HasLocation, Bindings.DOUBLE_ARRAY); + double[] endCoords = graph.getRelatedValue2(endVertex, DiagramResource.getInstance(graph).HasLocation, Bindings.DOUBLE_ARRAY); + + return crsClass.calculateDistance(startCoords, endCoords); + } +}