]> gerrit.simantics Code Review - simantics/platform.git/blobdiff - bundles/org.simantics.modeling.ui/src/org/simantics/modeling/ui/diagram/style/SymbolTerminalNameStyle.java
Fixed all line endings of the repository
[simantics/platform.git] / bundles / org.simantics.modeling.ui / src / org / simantics / modeling / ui / diagram / style / SymbolTerminalNameStyle.java
index f98e8299c32a5e375fd53a8524e6680ec3e78df5..57ae0b8c5433aca6038ad8f28db31f3d187cca44 100644 (file)
-/*******************************************************************************\r
- * Copyright (c) 2007, 2010 Association for Decentralized Information Management\r
- * in Industry THTH ry.\r
- * All rights reserved. This program and the accompanying materials\r
- * are made available under the terms of the Eclipse Public License v1.0\r
- * which accompanies this distribution, and is available at\r
- * http://www.eclipse.org/legal/epl-v10.html\r
- *\r
- * Contributors:\r
- *     VTT Technical Research Centre of Finland - initial API and implementation\r
- *******************************************************************************/\r
-package org.simantics.modeling.ui.diagram.style;\r
-\r
-import java.awt.Color;\r
-import java.awt.Font;\r
-import java.awt.geom.AffineTransform;\r
-\r
-import org.simantics.databoard.Bindings;\r
-import org.simantics.datatypes.literal.Vec2d;\r
-import org.simantics.db.ReadGraph;\r
-import org.simantics.db.Resource;\r
-import org.simantics.db.exception.DatabaseException;\r
-import org.simantics.db.layer0.variable.Variable;\r
-import org.simantics.diagram.elements.TextNode;\r
-import org.simantics.diagram.profile.StyleBase;\r
-import org.simantics.diagram.synchronization.graph.DiagramGraphUtil;\r
-import org.simantics.g2d.utils.Alignment;\r
-import org.simantics.layer0.Layer0;\r
-import org.simantics.modeling.ModelingResources;\r
-import org.simantics.scenegraph.INode;\r
-import org.simantics.scenegraph.g2d.IG2DNode;\r
-import org.simantics.scenegraph.g2d.nodes.SingleElementNode;\r
-import org.simantics.scenegraph.profile.EvaluationContext;\r
-import org.simantics.scenegraph.profile.common.ProfileVariables;\r
-import org.simantics.scenegraph.utils.NodeUtil;\r
-import org.simantics.utils.datastructures.map.Tuple;\r
-\r
-\r
-/**\r
- * @author Tuukka Lehtonen\r
- */\r
-public class SymbolTerminalNameStyle extends StyleBase<SymbolNameResult> {\r
-\r
-    static final Font FONT = Font.decode("Arial 6");\r
-\r
-    private static final String NODE_NAME = "terminalName";\r
-\r
-    /**\r
-     * Must override the StyleBase implementation because terminals do not\r
-     * depend on runtime variable. They need to be shown regardless of variable\r
-     * existence.\r
-     */\r
-    @Override\r
-    public SymbolNameResult calculateStyle(ReadGraph graph, Resource runtimeDiagram, Resource entry, Resource groupItem) throws DatabaseException {\r
-        return calculateStyle(graph, runtimeDiagram, entry, groupItem, null);\r
-    }\r
-\r
-    @Override\r
-    public SymbolNameResult calculateStyle(ReadGraph graph, Resource runtimeDiagram, Resource entry, Resource element, Variable configuration) throws DatabaseException {\r
-\r
-        AffineTransform transform = DiagramGraphUtil.getAffineTransform(graph, element);\r
-\r
-        Layer0 L0 = Layer0.getInstance(graph);\r
-        ModelingResources MOD = ModelingResources.getInstance(graph);\r
-\r
-        Resource binds = DiagramGraphUtil.getPossibleConnectionPointOfTerminal(graph, element);\r
-        if (binds == null)\r
-            return null;\r
-\r
-        Resource conn = graph.getPossibleObject(binds, MOD.DiagramConnectionRelationToConnectionRelation);\r
-        String name = graph.getPossibleRelatedValue(conn, L0.HasName, Bindings.STRING);\r
-        if (conn == null || name == null)\r
-            return null;\r
-\r
-        return new SymbolNameResult(name, transform);\r
-\r
-    }\r
-\r
-    private AffineTransform translateAndScaleIfNeeded(AffineTransform tr, Vec2d offset, double scale) {\r
-       if(!offset.isZero() || scale != 1.0) {\r
-               tr = new AffineTransform(tr);\r
-               tr.translate(offset.x, offset.y);\r
-               tr.scale(scale, scale);\r
-       }\r
-       return tr;\r
-    }\r
-    \r
-    private AffineTransform getSymbolTransform(INode node, Vec2d offset, double size) {\r
-       if(node instanceof SingleElementNode) {\r
-               SingleElementNode s = (SingleElementNode)node;\r
-               INode symbol = NodeUtil.findChildByPrefix(s, "composite_image"); \r
-               return translateAndScaleIfNeeded(symbol != null ? ((IG2DNode)symbol).getTransform() : new AffineTransform(), offset, size);\r
-       }\r
-       return null;\r
-    }\r
-    \r
-    @Override\r
-    public void applyStyleForNode(EvaluationContext observer, INode _node, SymbolNameResult result) {\r
-       \r
-        if (result == null) {\r
-            ProfileVariables.denyChild(_node, "", NODE_NAME);\r
-            return;\r
-        }\r
-\r
-        TextNode node = ProfileVariables.claimChild(_node, "", NODE_NAME, TextNode.class, observer);\r
-\r
-        node.setZIndex( Integer.MAX_VALUE );\r
-        node.setTransform( getSymbolTransform(_node, new Vec2d(0, -1), 0.08) ); \r
-        node.setText(result.getName());\r
-        node.setHorizontalAlignment((byte)Alignment.CENTER.ordinal());\r
-        node.setBackgroundColor(Color.WHITE);\r
-        node.setPadding(0.2, 0);\r
-        \r
-    }\r
-\r
-    @Override\r
-    protected void cleanupStyleForNode(INode node) {\r
-        ProfileVariables.denyChild(node, "", NODE_NAME);\r
-    }\r
-\r
-}\r
-\r
-/**\r
- * This is needed to keep the issue decoration up-to-date when its parent\r
- * element moves.\r
- */\r
-class SymbolNameResult extends Tuple {\r
-    public SymbolNameResult(String name, AffineTransform transform) {\r
-        super(name, transform);\r
-    }\r
-    public String getName() {\r
-        return (String) getField(0);\r
-    }\r
-}\r
+/*******************************************************************************
+ * Copyright (c) 2007, 2010 Association for Decentralized Information Management
+ * in Industry THTH ry.
+ * All rights reserved. This program and the accompanying materials
+ * are made available under the terms of the Eclipse Public License v1.0
+ * which accompanies this distribution, and is available at
+ * http://www.eclipse.org/legal/epl-v10.html
+ *
+ * Contributors:
+ *     VTT Technical Research Centre of Finland - initial API and implementation
+ *******************************************************************************/
+package org.simantics.modeling.ui.diagram.style;
+
+import java.awt.Color;
+import java.awt.Font;
+import java.awt.geom.AffineTransform;
+
+import org.simantics.databoard.Bindings;
+import org.simantics.datatypes.literal.Vec2d;
+import org.simantics.db.ReadGraph;
+import org.simantics.db.Resource;
+import org.simantics.db.exception.DatabaseException;
+import org.simantics.db.layer0.variable.Variable;
+import org.simantics.diagram.elements.TextNode;
+import org.simantics.diagram.profile.StyleBase;
+import org.simantics.diagram.synchronization.graph.DiagramGraphUtil;
+import org.simantics.g2d.utils.Alignment;
+import org.simantics.layer0.Layer0;
+import org.simantics.modeling.ModelingResources;
+import org.simantics.scenegraph.INode;
+import org.simantics.scenegraph.g2d.IG2DNode;
+import org.simantics.scenegraph.g2d.nodes.SingleElementNode;
+import org.simantics.scenegraph.profile.EvaluationContext;
+import org.simantics.scenegraph.profile.common.ProfileVariables;
+import org.simantics.scenegraph.utils.NodeUtil;
+import org.simantics.utils.datastructures.map.Tuple;
+
+
+/**
+ * @author Tuukka Lehtonen
+ */
+public class SymbolTerminalNameStyle extends StyleBase<SymbolNameResult> {
+
+    static final Font FONT = Font.decode("Arial 6");
+
+    private static final String NODE_NAME = "terminalName";
+
+    /**
+     * Must override the StyleBase implementation because terminals do not
+     * depend on runtime variable. They need to be shown regardless of variable
+     * existence.
+     */
+    @Override
+    public SymbolNameResult calculateStyle(ReadGraph graph, Resource runtimeDiagram, Resource entry, Resource groupItem) throws DatabaseException {
+        return calculateStyle(graph, runtimeDiagram, entry, groupItem, null);
+    }
+
+    @Override
+    public SymbolNameResult calculateStyle(ReadGraph graph, Resource runtimeDiagram, Resource entry, Resource element, Variable configuration) throws DatabaseException {
+
+        AffineTransform transform = DiagramGraphUtil.getAffineTransform(graph, element);
+
+        Layer0 L0 = Layer0.getInstance(graph);
+        ModelingResources MOD = ModelingResources.getInstance(graph);
+
+        Resource binds = DiagramGraphUtil.getPossibleConnectionPointOfTerminal(graph, element);
+        if (binds == null)
+            return null;
+
+        Resource conn = graph.getPossibleObject(binds, MOD.DiagramConnectionRelationToConnectionRelation);
+        String name = graph.getPossibleRelatedValue(conn, L0.HasName, Bindings.STRING);
+        if (conn == null || name == null)
+            return null;
+
+        return new SymbolNameResult(name, transform);
+
+    }
+
+    private AffineTransform translateAndScaleIfNeeded(AffineTransform tr, Vec2d offset, double scale) {
+       if(!offset.isZero() || scale != 1.0) {
+               tr = new AffineTransform(tr);
+               tr.translate(offset.x, offset.y);
+               tr.scale(scale, scale);
+       }
+       return tr;
+    }
+    
+    private AffineTransform getSymbolTransform(INode node, Vec2d offset, double size) {
+       if(node instanceof SingleElementNode) {
+               SingleElementNode s = (SingleElementNode)node;
+               INode symbol = NodeUtil.findChildByPrefix(s, "composite_image"); 
+               return translateAndScaleIfNeeded(symbol != null ? ((IG2DNode)symbol).getTransform() : new AffineTransform(), offset, size);
+       }
+       return null;
+    }
+    
+    @Override
+    public void applyStyleForNode(EvaluationContext observer, INode _node, SymbolNameResult result) {
+       
+        if (result == null) {
+            ProfileVariables.denyChild(_node, "", NODE_NAME);
+            return;
+        }
+
+        TextNode node = ProfileVariables.claimChild(_node, "", NODE_NAME, TextNode.class, observer);
+
+        node.setZIndex( Integer.MAX_VALUE );
+        node.setTransform( getSymbolTransform(_node, new Vec2d(0, -1), 0.08) ); 
+        node.setText(result.getName());
+        node.setHorizontalAlignment((byte)Alignment.CENTER.ordinal());
+        node.setBackgroundColor(Color.WHITE);
+        node.setPadding(0.2, 0);
+        
+    }
+
+    @Override
+    protected void cleanupStyleForNode(INode node) {
+        ProfileVariables.denyChild(node, "", NODE_NAME);
+    }
+
+}
+
+/**
+ * This is needed to keep the issue decoration up-to-date when its parent
+ * element moves.
+ */
+class SymbolNameResult extends Tuple {
+    public SymbolNameResult(String name, AffineTransform transform) {
+        super(name, transform);
+    }
+    public String getName() {
+        return (String) getField(0);
+    }
+}