]> gerrit.simantics Code Review - simantics/3d.git/blobdiff - org.simantics.plant3d/src/org/simantics/plant3d/editor/Plant3DEditor.java
Using SWT thread with Plant3d
[simantics/3d.git] / org.simantics.plant3d / src / org / simantics / plant3d / editor / Plant3DEditor.java
index 9d0c3b820a289e912a3be846b5c55fa748ab0897..b1bb5000995c394503504c3a3aa54a68bea3ab25 100644 (file)
@@ -1,6 +1,5 @@
 package org.simantics.plant3d.editor;
 
-import java.awt.Component;
 import java.util.HashSet;
 import java.util.List;
 import java.util.Set;
@@ -11,12 +10,10 @@ import org.eclipse.jface.action.MenuManager;
 import org.eclipse.jface.viewers.ISelectionChangedListener;
 import org.eclipse.jface.viewers.ISelectionProvider;
 import org.eclipse.jface.viewers.SelectionChangedEvent;
-import org.eclipse.swt.SWT;
 import org.eclipse.swt.events.DisposeEvent;
 import org.eclipse.swt.events.DisposeListener;
 import org.eclipse.swt.layout.FillLayout;
 import org.eclipse.swt.widgets.Composite;
-import org.eclipse.swt.widgets.Display;
 import org.eclipse.swt.widgets.Menu;
 import org.eclipse.ui.views.contentoutline.IContentOutlinePage;
 import org.simantics.db.ReadGraph;
@@ -28,15 +25,17 @@ import org.simantics.g3d.scenegraph.IG3DNode;
 import org.simantics.g3d.scenegraph.NodeMap;
 import org.simantics.g3d.scenegraph.base.INode;
 import org.simantics.g3d.vtk.action.RemoveAction;
-import org.simantics.g3d.vtk.action.RotateAction;
-import org.simantics.g3d.vtk.action.TranslateAction;
-import org.simantics.g3d.vtk.action.vtkCameraAndSelectorAction;
 import org.simantics.g3d.vtk.common.HoverHighlighter;
-import org.simantics.g3d.vtk.common.InteractiveVtkPanel;
 import org.simantics.g3d.vtk.common.NodeSelectionProvider2;
 import org.simantics.g3d.vtk.common.SelectionHighlighter;
+import org.simantics.g3d.vtk.common.VtkView;
 import org.simantics.g3d.vtk.shape.vtkShape;
-import org.simantics.g3d.vtk.utils.vtkPanelUtil;
+import org.simantics.g3d.vtk.swt.ContextMenuListener;
+import org.simantics.g3d.vtk.swt.InteractiveVtkComposite;
+import org.simantics.g3d.vtk.swt.RotateAction;
+import org.simantics.g3d.vtk.swt.TranslateAction;
+import org.simantics.g3d.vtk.swt.vtkCameraAndSelectorAction;
+import org.simantics.g3d.vtk.utils.AxesDisplay;
 import org.simantics.objmap.graph.IMapping;
 import org.simantics.objmap.graph.Mappings;
 import org.simantics.objmap.graph.schema.IMappingSchema;
@@ -44,6 +43,7 @@ import org.simantics.plant3d.actions.AddComponentAction;
 import org.simantics.plant3d.actions.AddEquipmentAction;
 import org.simantics.plant3d.actions.AddNozzleAction;
 import org.simantics.plant3d.actions.RoutePipeAction;
+import org.simantics.plant3d.actions.TranslateInlineAction;
 import org.simantics.plant3d.scenegraph.EndComponent;
 import org.simantics.plant3d.scenegraph.Equipment;
 import org.simantics.plant3d.scenegraph.IP3DNode;
@@ -64,17 +64,13 @@ import org.simantics.selectionview.StandardPropertyPage;
 import org.simantics.ui.workbench.IPropertyPage;
 import org.simantics.ui.workbench.IResourceEditorInput;
 import org.simantics.ui.workbench.ResourceEditorPart;
-import org.simantics.utils.threads.AWTThread;
 import org.simantics.utils.threads.ThreadUtils;
 import org.simantics.utils.ui.ExceptionUtils;
-import org.simantics.utils.ui.SWTAWTComponent;
 
 import vtk.vtkActor;
-import vtk.vtkAxesActor;
 import vtk.vtkCameraPass;
 import vtk.vtkDefaultPass;
 import vtk.vtkLightsPass;
-import vtk.vtkOrientationMarkerWidget;
 import vtk.vtkRenderPassCollection;
 import vtk.vtkRenderer;
 import vtk.vtkSequencePass;
@@ -84,8 +80,9 @@ public class Plant3DEditor extends ResourceEditorPart {
 
        private Composite parent;
        private Resource input;
-       private InteractiveVtkPanel panel;
-       private SWTAWTComponent component;
+//     private InteractiveVtkPanel panel;
+//     private SWTAWTComponent component;
+       private InteractiveVtkComposite panel;
        
        private P3DRootNode rootNode;
        private IMapping<Resource,Object> mapping;
@@ -94,6 +91,7 @@ public class Plant3DEditor extends ResourceEditorPart {
        
        private vtkCameraAndSelectorAction cameraAction;
        private TranslateAction translateAction;
+       private TranslateInlineAction translateInlineAction;
        private RotateAction rotateAction;
        private RemoveAction removeAction;
        private RoutePipeAction routePipeAction;
@@ -105,44 +103,35 @@ public class Plant3DEditor extends ResourceEditorPart {
        public void createPartControl(Composite parent) {
                this.parent = parent;
                parent.setLayout (new FillLayout ());
-               component = new SWTAWTComponent(parent,SWT.NONE) {
-                       
-                       @Override
-                       protected Component createSwingComponent() {
-                               if (panel == null) {
-                                       panel = new InteractiveVtkPanel();
-                                       vtkPanelUtil.registerPanel(panel);
-                                       createScene();
-                               }
-                               return panel;
-                       }
-               };
+//             component = new SWTAWTComponent(parent,SWT.NONE) {
+//                     
+//                     @Override
+//                     protected Component createSwingComponent() {
+//                             if (panel == null) {
+//                                     panel = new InteractiveVtkPanel();
+//                                     vtkPanelUtil.registerPanel(panel);
+//                                     createScene();
+//                             }
+//                             return panel;
+//                     }
+//             };
 
                IResourceEditorInput rei = (IResourceEditorInput)getEditorInput();
                input = rei.getResource();
                
+               panel = new InteractiveVtkComposite(parent);
+               
                
                //IActionBars actionBars = getEditorSite().getActionBars();
 
                hookContextMenu();
                
-               component.syncPopulate();
+               createScene();
+
+               //component.syncPopulate();
                
-               panel.addMouseListener(new java.awt.event.MouseAdapter() {
-                       @Override
-                       public void mouseClicked(final java.awt.event.MouseEvent e) {
-                               if (e.getButton() == java.awt.event.MouseEvent.BUTTON3) {
-                                       Display.getDefault().asyncExec(new Runnable() {
-                                               public void run() {
-                                                       contextMenu.setLocation(e.getXOnScreen(), e.getYOnScreen());
-                                                       contextMenu.setVisible(true);
-                                               }
-                                       });
-                               }
-                       }
-               });
+               new ContextMenuListener(panel, contextMenu);
                
-
                cameraAction = new vtkCameraAndSelectorAction(panel);   
                panel.setDefaultAction(cameraAction);
                panel.useDefaultAction();
@@ -232,20 +221,12 @@ public class Plant3DEditor extends ResourceEditorPart {
                                public void widgetDisposed(DisposeEvent e) {
                                        getSite().getPage().removePostSelectionListener(selectionProvider);
                                        
-                                       ThreadUtils.asyncExec(AWTThread.getThreadAccess(), new Runnable() {
-                                               
-                                               @Override
-                                               public void run() {
-                                                       PipingRules.setEnabled(false);
-                                                       nodeMap.delete();
-                                                       PipingRules.setEnabled(true);
-                                                       vtkPanelUtil.unregisterPanel(panel);
-
-                                               }
-                                       });
+                                       PipingRules.setEnabled(false);
+                                       nodeMap.delete();
+                                       PipingRules.setEnabled(true);
                                        mapping.dispose();
-                                       component.dispose();
-                                       
+//                                     component.dispose();
+                                       //panel.getComponent().dispose();
                                        
                                }
                        });
@@ -255,6 +236,7 @@ public class Plant3DEditor extends ResourceEditorPart {
                }
                
                translateAction = new TranslateAction(panel,nodeMap);
+               translateInlineAction = new TranslateInlineAction(panel, nodeMap);
                rotateAction = new RotateAction(panel,nodeMap);
                removeAction = new RemoveAction(nodeMap) {
                        public void setNode(IG3DNode node) {
@@ -269,7 +251,7 @@ public class Plant3DEditor extends ResourceEditorPart {
        }
        
        public void populate() {
-               ThreadUtils.asyncExec(AWTThread.getThreadAccess(), new Runnable() {
+               ThreadUtils.asyncExec(panel.getThreadQueue(), new Runnable() {
                        
                        @Override
                        public void run() {
@@ -284,17 +266,18 @@ public class Plant3DEditor extends ResourceEditorPart {
                return schema;
        }
        
-       protected P3DNodeMap createNodeMap(Session session, IMapping<Resource, Object> mapping, InteractiveVtkPanel panel, P3DRootNode rootNode) {
+       protected P3DNodeMap createNodeMap(Session session, IMapping<Resource, Object> mapping, VtkView panel, P3DRootNode rootNode) {
                 return new P3DNodeMap(session, mapping, panel,rootNode);
        }
        
        @Override
        public void setFocus() {
-               component.setFocus();
+               //component.setFocus();
+               panel.getComponent().setFocus();
        }
        
        private void createScene() {
-               vtkRenderer ren1 = panel.GetRenderer();
+               vtkRenderer ren1 = panel.getRenderer();
                
                boolean multiPass = false;
                if (multiPass) {
@@ -310,8 +293,6 @@ public class Plant3DEditor extends ResourceEditorPart {
                        vtkSequencePass seq = new vtkSequencePass();
                        seq.SetPasses(passes);
                        
-               
-                       
                        vtkCameraPass cameraPass = new vtkCameraPass();
                        cameraPass.SetDelegatePass(seq);
                        
@@ -335,34 +316,8 @@ public class Plant3DEditor extends ResourceEditorPart {
            ren1.AddActor(grid);
            panel.addDeletable(grid);
            
-           {
-                   vtkAxesActor axes = new vtkAxesActor();
-                   axes.GetXAxisCaptionActor2D().GetCaptionTextProperty().SetColor(0,0,0);
-                   axes.GetYAxisCaptionActor2D().GetCaptionTextProperty().SetColor(0,0,0);
-                   axes.GetZAxisCaptionActor2D().GetCaptionTextProperty().SetColor(0,0,0);
-                   axes.GetXAxisCaptionActor2D().GetCaptionTextProperty().SetShadow(0);
-                   axes.GetYAxisCaptionActor2D().GetCaptionTextProperty().SetShadow(0);
-                   axes.GetZAxisCaptionActor2D().GetCaptionTextProperty().SetShadow(0);
-                   axes.GetXAxisCaptionActor2D().GetCaptionTextProperty().ItalicOff();
-                   axes.GetYAxisCaptionActor2D().GetCaptionTextProperty().ItalicOff();
-                   axes.GetZAxisCaptionActor2D().GetCaptionTextProperty().ItalicOff();
-                   axes.GetXAxisCaptionActor2D().GetCaptionTextProperty().Delete();
-                   axes.GetYAxisCaptionActor2D().GetCaptionTextProperty().Delete();
-                   axes.GetZAxisCaptionActor2D().GetCaptionTextProperty().Delete();
-                   axes.GetXAxisCaptionActor2D().Delete();
-                   axes.GetYAxisCaptionActor2D().Delete();
-                   axes.GetZAxisCaptionActor2D().Delete();
-                   vtkOrientationMarkerWidget widget = new vtkOrientationMarkerWidget();
-                   widget.SetOutlineColor(0.9300, 0.5700, 0.1300 );
-                   widget.SetOrientationMarker(axes);
-                   widget.SetInteractor(panel.getRenderWindowInteractor());
-                   //widget.SetViewport(0.8, 0.0, 1.0, 0.2); // bottom right
-                   //widget.SetViewport(0.0, 0.0, 0.4, 0.4);
-                   widget.SetViewport(0.0, 0.0, 0.2, 0.2);  // bottom left
-                   widget.SetEnabled(1);
-                   widget.InteractiveOff();
-           }
-
+           AxesDisplay axesDisplay = new AxesDisplay(panel);
+           axesDisplay.show();
                
        }
        
@@ -421,6 +376,7 @@ public class Plant3DEditor extends ResourceEditorPart {
                                } else if (node instanceof InlineComponent) {
                                        //m.add(translateInlineAction);
                                        InlineComponent component = (InlineComponent)node;
+                                       m.add(translateInlineAction);
                                        m.add(routePipeAction);
                                        routePipeAction.setComponent(component);
                                        m.add(addComponentAction);
@@ -429,6 +385,7 @@ public class Plant3DEditor extends ResourceEditorPart {
                                
                                m.add(removeAction);
                                translateAction.setNode(node);
+                               translateInlineAction.setNode(node);
                                rotateAction.setNode(node);
                                removeAction.setNode(node);
                                
@@ -474,9 +431,11 @@ public class Plant3DEditor extends ResourceEditorPart {
                if (IMapping.class.equals(adapter)) {
                        return mapping;
                }
-               if (InteractiveVtkPanel.class.equals(adapter)) {
+//             if (InteractiveVtkPanel.class.equals(adapter)) {
+//                     return panel;
+//             }
+               if (VtkView.class.equals(adapter))
                        return panel;
-               }
                if (ISelectionProvider.class.equals(adapter))
                        return selectionProvider;
                return super.getAdapter(adapter);