X-Git-Url: https://gerrit.simantics.org/r/gitweb?p=simantics%2Fplatform.git;a=blobdiff_plain;f=bundles%2Forg.simantics.modeling.template2d.ui%2Fsrc%2Forg%2Fsimantics%2Fmodeling%2Ftemplate2d%2Fui%2Factions%2FNewMonitor.java;fp=bundles%2Forg.simantics.modeling.template2d.ui%2Fsrc%2Forg%2Fsimantics%2Fmodeling%2Ftemplate2d%2Fui%2Factions%2FNewMonitor.java;h=a189a6b4961921b23d026ec3559a8bdcc53c3c19;hp=0000000000000000000000000000000000000000;hb=969bd23cab98a79ca9101af33334000879fb60c5;hpb=866dba5cd5a3929bbeae85991796acb212338a08 diff --git a/bundles/org.simantics.modeling.template2d.ui/src/org/simantics/modeling/template2d/ui/actions/NewMonitor.java b/bundles/org.simantics.modeling.template2d.ui/src/org/simantics/modeling/template2d/ui/actions/NewMonitor.java new file mode 100644 index 000000000..a189a6b49 --- /dev/null +++ b/bundles/org.simantics.modeling.template2d.ui/src/org/simantics/modeling/template2d/ui/actions/NewMonitor.java @@ -0,0 +1,86 @@ +/******************************************************************************* + * Copyright (c) 2012 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.template2d.ui.actions; + +import java.util.Arrays; + +import org.simantics.databoard.Bindings; +import org.simantics.datatypes.DatatypeResource; +import org.simantics.datatypes.literal.Font; +import org.simantics.datatypes.literal.RGB; +import org.simantics.db.Resource; +import org.simantics.db.WriteGraph; +import org.simantics.db.common.CommentMetadata; +import org.simantics.db.common.request.WriteRequest; +import org.simantics.db.common.utils.ListUtils; +import org.simantics.db.common.utils.NameUtils; +import org.simantics.db.exception.DatabaseException; +import org.simantics.db.layer0.adapter.ActionFactory; +import org.simantics.diagram.stubs.DiagramResource; +import org.simantics.diagram.stubs.G2DResource; +import org.simantics.layer0.Layer0; +import org.simantics.scenegraph.ontology.ScenegraphResources; +import org.simantics.ui.SimanticsUI; + +public class NewMonitor implements ActionFactory { + + @Override + public Runnable create(Object target) { + if(!(target instanceof Resource)) + return null; + final Resource parent = (Resource)target; + + return new Runnable() { + @Override + public void run() { + SimanticsUI.getSession().asyncRequest(new WriteRequest() { + @Override + public void perform(WriteGraph g) throws DatabaseException { + g.markUndoPoint(); + createNewMonitor(g, parent); + } + }); + } + }; + } + + public static Resource createNewMonitor(WriteGraph g, Resource parent) throws DatabaseException { + + Layer0 L0 = Layer0.getInstance(g); + DiagramResource DIA = DiagramResource.getInstance(g); + DatatypeResource DATA = DatatypeResource.getInstance(g); + G2DResource G2D = G2DResource.getInstance(g); + ScenegraphResources SG = ScenegraphResources.getInstance(g); + + Resource monitor = g.newResource(); + g.claim(monitor, L0.InstanceOf, null, DIA.Scenegraph_Monitor); + String name = NameUtils.findFreshName(g, "Monitor", parent, L0.ConsistsOf); + g.addLiteral(monitor, L0.HasName, L0.NameOf, L0.String, name, Bindings.STRING); + g.addLiteral(monitor, DIA.Scenegraph_Monitor_reference, DIA.Scenegraph_Monitor_reference_Inverse, "#HasLabel", Bindings.STRING); + g.addLiteral(monitor, DIA.Scenegraph_AbstractText_width, DIA.Scenegraph_AbstractText_width_Inverse, 0.0f, Bindings.FLOAT); + g.addLiteral(monitor, DIA.Scenegraph_AbstractText_horizontalAlignment, DIA.Scenegraph_AbstractText_horizontalAlignment_Inverse, L0.Byte, (byte) 0, Bindings.BYTE); + g.addLiteral(monitor, DIA.Scenegraph_AbstractText_verticalAlignment, DIA.Scenegraph_AbstractText_verticalAlignment_Inverse, L0.Byte, (byte) 0, Bindings.BYTE); + //g.claim(monitor, DIA.Scenegraph_AbstractText_horizontalAlignment, DIA.Scenegraph_AbstractText_horizontalAlignment_Inverse, DIA.Scenegraph_AbstractText_HAlignment_Left); + g.addLiteral(monitor, DIA.Scenegraph_AbstractText_color, DIA.Scenegraph_AbstractText_color_Inverse, DATA.RGB_Integer, new RGB.Integer(0,0,0), Bindings.getBindingUnchecked(RGB.Integer.class)); + g.addLiteral(monitor, DIA.Scenegraph_AbstractText_font, DIA.Scenegraph_AbstractText_font_Inverse, DATA.Font, new Font("Arial", 7, "Normal"), Bindings.getBindingUnchecked(Font.class)); + g.addLiteral(monitor, DIA.Scenegraph_AbstractText_transform, DIA.Scenegraph_AbstractText_transform_Inverse, G2D.Transform, new Double[] { 1.0, 0.0, 0.0, 1.0, 0.0, 0.0 }, Bindings.getBindingUnchecked(Double[].class)); + g.claim(monitor, L0.PartOf, parent); + Resource list = g.getPossibleObject(parent, SG.Node_children); + if (list != null) + ListUtils.insertBack(g, list, Arrays.asList(monitor)); + + CommentMetadata cm = g.getMetadata(CommentMetadata.class); + g.addMetadata(cm.add("Create New Monitor.")); + + return monitor; + } +}