X-Git-Url: https://gerrit.simantics.org/r/gitweb?a=blobdiff_plain;f=org.simantics.district.network%2Fsrc%2Forg%2Fsimantics%2Fdistrict%2Fnetwork%2FDistrictNetworkUtil.java;h=519ad512404d8a961a29a998aaece538b9dd8641;hb=426a4ef58cf0b7e755a9111881800806f1374d59;hp=bac4707d87cc8fe627e0d24f2604503a2fc6d22d;hpb=af46ba24e2d2b6e68f62e5e215386166fa456d98;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 bac4707d..519ad512 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 @@ -25,6 +25,7 @@ import org.simantics.diagram.synchronization.graph.layer.IGraphLayerUtil; import org.simantics.district.network.ontology.DistrictNetworkResource; import org.simantics.layer0.Layer0; import org.simantics.modeling.ModelingResources; +import org.simantics.modeling.adapters.NewCompositeActionFactory; import org.simantics.operation.Layer0X; public class DistrictNetworkUtil { @@ -251,6 +252,24 @@ public class DistrictNetworkUtil { DistrictNetworkResource.getInstance(graph).Diagram_backgroundColor, Bindings.getBindingUnchecked(RGB.Integer.class)); } + + public static Resource createNetworkDiagram(WriteGraph graph, Resource target, Resource compositeType, String defaultName, Resource defaultEdgeMapping, Resource defaultVertexMapping, Resource rightClickVertexMapping, Resource leftClickVertexMapping, Resource crs) throws DatabaseException { + Resource composite = NewCompositeActionFactory.createComposite(graph, target, defaultName, compositeType); + + DistrictNetworkResource DN = DistrictNetworkResource.getInstance(graph); + Resource diagram = graph.getSingleObject(composite, ModelingResources.getInstance(graph).CompositeToDiagram); + graph.claim(diagram, DN.EdgeDefaultMapping, defaultEdgeMapping); + graph.claim(diagram, DN.VertexDefaultMapping, defaultVertexMapping); + graph.claim(diagram, DN.RightClickDefaultMapping, rightClickVertexMapping); + graph.claim(diagram, DN.LeftClickDefaultMapping, leftClickVertexMapping); + graph.claim(diagram, DN.HasSpatialRefSystem, crs); + + // Generated name prefix from composite name + String compositeName = graph.getRelatedValue2(composite, Layer0.getInstance(graph).HasName, Bindings.STRING); + graph.claimLiteral(diagram, Layer0X.getInstance(graph).HasGeneratedNamePrefix, "N" + compositeName.substring(compositeName.length() - 1, compositeName.length())); + + return composite; + } public static final class MappedComponentRequest extends ResourceRead { public MappedComponentRequest(Resource element) { @@ -263,4 +282,16 @@ public class DistrictNetworkUtil { } } + public static class ResourceVertex { + + public final boolean isConsumer; + public final Resource vertex; + public final double[] coords; + + public ResourceVertex(Resource vertex, double[] coords, boolean isConsumer) { + this.vertex = vertex; + this.coords = coords; + this.isConsumer = isConsumer; + } + } }