X-Git-Url: https://gerrit.simantics.org/r/gitweb?a=blobdiff_plain;f=bundles%2Forg.simantics.diagram%2Fsrc%2Forg%2Fsimantics%2Fdiagram%2Fadapter%2FConstantStyle.java;fp=bundles%2Forg.simantics.diagram%2Fsrc%2Forg%2Fsimantics%2Fdiagram%2Fadapter%2FConstantStyle.java;h=a70eb45da11d7c276e5eac7affb8b3db1b5a2ad0;hb=969bd23cab98a79ca9101af33334000879fb60c5;hp=0000000000000000000000000000000000000000;hpb=866dba5cd5a3929bbeae85991796acb212338a08;p=simantics%2Fplatform.git diff --git a/bundles/org.simantics.diagram/src/org/simantics/diagram/adapter/ConstantStyle.java b/bundles/org.simantics.diagram/src/org/simantics/diagram/adapter/ConstantStyle.java new file mode 100644 index 000000000..a70eb45da --- /dev/null +++ b/bundles/org.simantics.diagram/src/org/simantics/diagram/adapter/ConstantStyle.java @@ -0,0 +1,137 @@ +/******************************************************************************* + * 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.diagram.adapter; + +import java.awt.AlphaComposite; +import java.awt.Color; +import java.util.HashMap; +import java.util.Map; + +import org.simantics.databoard.Bindings; +import org.simantics.db.ReadGraph; +import org.simantics.db.RequestProcessor; +import org.simantics.db.Resource; +import org.simantics.db.exception.DatabaseException; +import org.simantics.diagram.profile.ProfileKeys; +import org.simantics.diagram.stubs.DiagramResource; +import org.simantics.g2d.canvas.ICanvasContext; +import org.simantics.layer0.Layer0; +import org.simantics.scenegraph.INode; +import org.simantics.scenegraph.profile.DataNodeMap; +import org.simantics.scenegraph.profile.EvaluationContext; +import org.simantics.scenegraph.profile.Group; +import org.simantics.scenegraph.profile.Style; +import org.simantics.scenegraph.profile.common.ObserverGroupListener; +import org.simantics.scenegraph.profile.common.ProfileVariables; + +public class ConstantStyle implements Style { + + final String name; + final Map values = new HashMap(); + ObserverGroupListener listener = null; + + public ConstantStyle(ReadGraph graph, Resource style) throws DatabaseException { + Layer0 L0 = Layer0.getInstance(graph); + DiagramResource DIA = DiagramResource.getInstance(graph); + this.name = graph.getPossibleRelatedValue(style, L0.HasName, Bindings.STRING); + String[] values = graph.getPossibleRelatedValue(style, DIA.HasValues, Bindings.getBindingUnchecked(String[].class)); + for(int i=0;i value : values.entrySet()) { + + for(Object item : listener.getItems()) { + + final INode node = map.getNode(item); + +// final IElement element = map.getElement(diagram, item); + if(node == null) { + //observer.exception(new NullPointerException("ConstantStyle.apply: no element for " + item)); + evaluationContext.update(); + return; + } + + ProfileVariables.claimNodeProperty(node, value.getKey(), value.getValue(), evaluationContext); + +//// System.out.println("apply[" + element + "]: " + value.getKey() + " => " + value.getValue()); +// Variables.set(node, value.getKey(), value.getValue(), evaluationContext); +// +// PropertySetter setter = element.getElementClass().getAtMostOneItemOfClass(PropertySetter.class); +// if(setter != null) +// setter.syncPropertiesToNode(element); + + } + } + + } + + @Override + public String toString() { + return name; + } + +}