Removed stupid tree
[sw/motorsim] / gui / com / billkuker / rocketry / motorsim / visual / workbench / MotorWorkbench.java
index 9c58d6e1a0992022451c1751575089385b54d950..5e9652f1ed4f4e59a07ce53cddc8059fb8180297 100644 (file)
@@ -1,12 +1,9 @@
 package com.billkuker.rocketry.motorsim.visual.workbench;\r
 \r
 import java.awt.BorderLayout;\r
-import java.awt.Dimension;\r
 import java.awt.FileDialog;\r
 import java.awt.event.ActionEvent;\r
 import java.awt.event.ActionListener;\r
-import java.beans.PropertyChangeEvent;\r
-import java.beans.PropertyChangeListener;\r
 import java.io.File;\r
 import java.io.FileInputStream;\r
 import java.io.FileOutputStream;\r
@@ -22,48 +19,44 @@ import javax.swing.JOptionPane;
 import javax.swing.JPanel;\r
 import javax.swing.JRadioButtonMenuItem;\r
 import javax.swing.JSeparator;\r
-import javax.swing.JSplitPane;\r
 import javax.swing.JTabbedPane;\r
-import javax.swing.JTree;\r
 import javax.swing.WindowConstants;\r
-import javax.swing.event.TreeSelectionEvent;\r
-import javax.swing.event.TreeSelectionListener;\r
-import javax.swing.tree.DefaultMutableTreeNode;\r
-import javax.swing.tree.TreePath;\r
-import javax.swing.tree.TreeSelectionModel;\r
 \r
 import com.billkuker.rocketry.motorsim.Burn;\r
 import com.billkuker.rocketry.motorsim.Fuel;\r
 import com.billkuker.rocketry.motorsim.Motor;\r
 import com.billkuker.rocketry.motorsim.RocketScience.UnitPreference;\r
 import com.billkuker.rocketry.motorsim.fuel.FuelResolver;\r
-import com.billkuker.rocketry.motorsim.fuel.PiecewiseLinearFuel;\r
-import com.billkuker.rocketry.motorsim.fuel.SaintRobertFuel;\r
 import com.billkuker.rocketry.motorsim.io.ENGExporter;\r
 import com.billkuker.rocketry.motorsim.io.MotorIO;\r
-import com.billkuker.rocketry.motorsim.visual.FuelPanel;\r
-import com.billkuker.rocketry.motorsim.visual.workbench.AbstractFuelEditor.EditablePSRFuel;\r
-import com.billkuker.rocketry.motorsim.visual.workbench.WorkbenchTreeModel.FuelEditNode;\r
-import com.billkuker.rocketry.motorsim.visual.workbench.WorkbenchTreeModel.FuelNode;\r
 \r
-public class MotorWorkbench extends JFrame implements TreeSelectionListener {\r
+import fuel.FuelsEditor;\r
+\r
+public class MotorWorkbench extends JFrame {\r
        private static final long serialVersionUID = 1L;\r
        \r
        private JPanel top;\r
-       private JSplitPane split;\r
-       private JTree tree;\r
        private JTabbedPane motors;\r
-       private JTabbedPane fuels;\r
-       private WorkbenchTreeModel tm;\r
        private MultiBurnChart mb;\r
        private JFrame allBurns;\r
+       \r
+       private JFrame fuelEditorFrame = new JFrame(){\r
+               private static final long serialVersionUID = 1L;\r
+               {\r
+                       setSize(1024, 768);\r
+                       add(fuelEditor = new FuelsEditor(this));\r
+                       JMenuBar b;\r
+                       setJMenuBar(b = new JMenuBar());\r
+                       b.add(fuelEditor.getMenu());\r
+                       setTitle("MotorSim - Fuel Editor");\r
+               }\r
+       };\r
+       private FuelsEditor fuelEditor;\r
 \r
        private HashMap<MotorEditor, File> e2f = new HashMap<MotorEditor, File>();\r
        private HashMap<File, MotorEditor> f2e = new HashMap<File, MotorEditor>();\r
 \r
        private HashMap<Motor, MotorEditor> m2e = new HashMap<Motor, MotorEditor>();\r
-\r
-       private static final int TREE_WIDTH = 200;\r
        \r
        public MotorWorkbench() {\r
                setTitle("MotorSim 1.0 RC1");\r
@@ -80,23 +73,8 @@ public class MotorWorkbench extends JFrame implements TreeSelectionListener {
                allBurns.add(mb);\r
 \r
                motors = new JTabbedPane();\r
-               fuels = new JTabbedPane();\r
-\r
-               tree = new JTree(tm = new WorkbenchTreeModel());\r
-               tree.setCellRenderer(new WorkbenchTreeCellRenderer());\r
-               tree.getSelectionModel().setSelectionMode(\r
-                               TreeSelectionModel.SINGLE_TREE_SELECTION);\r
-               tree.setMinimumSize(new Dimension(TREE_WIDTH, 100));\r
-\r
-               // Listen for when the selection changes.\r
-               tree.addTreeSelectionListener(this);\r
-\r
-               split = new JSplitPane(JSplitPane.HORIZONTAL_SPLIT, \r
-                               tree, motors);\r
-               split.setDividerLocation(TREE_WIDTH);\r
-               split.revalidate();\r
                \r
-               top.add(split, BorderLayout.CENTER);\r
+               top.add(motors, BorderLayout.CENTER);\r
                \r
                for ( Fuel f : FuelResolver.getFuelMap().values() ){\r
                        addFuel(f);\r
@@ -172,7 +150,6 @@ public class MotorWorkbench extends JFrame implements TreeSelectionListener {
                                                                        public void actionPerformed(ActionEvent ev) {\r
                                                                                MotorEditor e = (MotorEditor) motors\r
                                                                                                .getSelectedComponent();\r
-                                                                               tm.removeMotor(e.getMotor());\r
                                                                                motors.remove(e);\r
                                                                                f2e.remove(e2f.get(e));\r
                                                                                e2f.remove(e);\r
@@ -232,40 +209,6 @@ public class MotorWorkbench extends JFrame implements TreeSelectionListener {
                                                });\r
                                                \r
 \r
-                                               add(new JSeparator());\r
-                                               add(new JMenu("New Fuel"){\r
-                                                       private static final long serialVersionUID = 1L;\r
-                                                       {\r
-                                                               add(new JMenuItem("Saint-Robert") {\r
-                                                                       private static final long serialVersionUID = 1L;\r
-                                                                       {\r
-                                                                               addActionListener(new ActionListener() {\r
-                                                                                       @Override\r
-                                                                                       public void actionPerformed(ActionEvent arg0) {\r
-                                                                                               newFuel(new SRFuelEditor(new EditablePSRFuel(SaintRobertFuel.Type.SI)));\r
-                                                                                       }\r
-                                                                               });\r
-\r
-                                                                       }\r
-                                                               });\r
-                                                               add(new JMenuItem("Linear"){\r
-                                                                       private static final long serialVersionUID = 1L;\r
-                                                                       {\r
-                                                                               addActionListener(new ActionListener() {\r
-                                                                                       @Override\r
-                                                                                       public void actionPerformed(ActionEvent arg0) {\r
-                                                                                               newFuel(new LinearFuelEditor(new PiecewiseLinearFuel()));\r
-                                                                                       }\r
-                                                                               });\r
-\r
-                                                                       }\r
-                                                               });\r
-                                                       }\r
-                                               });\r
-\r
-                                               add(new JMenuItem("Save Fuel") {\r
-                                                       private static final long serialVersionUID = 1L;\r
-                                               });\r
                                                add(new JSeparator());\r
                                                add(new JMenuItem("Export .ENG"){\r
                                                        private static final long serialVersionUID = 1L;\r
@@ -326,7 +269,7 @@ public class MotorWorkbench extends JFrame implements TreeSelectionListener {
                                add(new JMenu("View") {\r
                                        private static final long serialVersionUID = 1L;\r
                                        {\r
-                                               add(new JMenuItem("Show All Motors Graph") {\r
+                                               add(new JMenuItem("All Motors Graph") {\r
                                                        private static final long serialVersionUID = 1L;\r
                                                        {\r
                                                                addActionListener(new ActionListener() {\r
@@ -338,6 +281,18 @@ public class MotorWorkbench extends JFrame implements TreeSelectionListener {
                                                                });\r
                                                        }\r
                                                });\r
+                                               add(new JMenuItem("Fuel Editor") {\r
+                                                       private static final long serialVersionUID = 1L;\r
+                                                       {\r
+                                                               addActionListener(new ActionListener() {\r
+                                                                       @Override\r
+                                                                       public void actionPerformed(ActionEvent arg0) {\r
+                                                                               fuelEditorFrame.setVisible(true);\r
+                                                                               fuelEditorFrame.toFront();\r
+                                                                       }\r
+                                                               });\r
+                                                       }\r
+                                               });\r
                                        }\r
                                });\r
                        }\r
@@ -347,33 +302,8 @@ public class MotorWorkbench extends JFrame implements TreeSelectionListener {
        private void addFuel(Fuel f){\r
                for ( MotorEditor e : m2e.values() )\r
                        e.addFuel(f);\r
-               FuelPanel fp = new FuelPanel(f);\r
-               FuelNode fn = tm.new FuelNode(fp, f);\r
-               tm.getFuels().add(fn);\r
-               tm.nodeStructureChanged(tm.getFuels());\r
-               fuels.addTab(f.getName(), fp);\r
        }\r
        \r
-       private void newFuel(final AbstractFuelEditor ed){\r
-               for ( MotorEditor e : m2e.values() )\r
-                       e.addFuel(ed.getFuel());\r
-               final FuelEditNode node = tm.new FuelEditNode(ed);\r
-               tm.getFuels().add(node);\r
-               tm.nodeStructureChanged(tm.getFuels());\r
-               fuels.addTab(ed.getFuel().getName(), ed);\r
-               ed.getFuel().addPropertyChangeListener(new PropertyChangeListener(){\r
-                       @Override\r
-                       public void propertyChange(PropertyChangeEvent evt) {\r
-                               if ( evt.getPropertyName().equals("Name")){\r
-                                       for ( int i = 0; i < fuels.getTabCount(); i++ ){\r
-                                               if ( fuels.getComponent(i) == ed ){\r
-                                                       fuels.setTitleAt(i, ed.getFuel().getName());\r
-                                                       tm.nodeChanged(node);\r
-                                               }\r
-                                       }\r
-                               }\r
-                       }});\r
-       }\r
 \r
        private void save(Motor m, File f) {\r
                try {\r
@@ -386,7 +316,6 @@ public class MotorWorkbench extends JFrame implements TreeSelectionListener {
        }\r
 \r
        public void addMotor(Motor m, File f) {\r
-               tm.addMotor(m);\r
                MotorEditor e = new MotorEditor(m, FuelResolver.getFuelMap().values());\r
                e.addBurnWatcher(mb);\r
                String title;\r
@@ -401,40 +330,5 @@ public class MotorWorkbench extends JFrame implements TreeSelectionListener {
                motors.addTab(title, e);\r
        }\r
 \r
-       @Override\r
-       public void valueChanged(TreeSelectionEvent e) {\r
-               if (e.getPath().getLastPathComponent() instanceof FuelNode) {\r
-                       FuelNode fen = ((FuelNode) e.getPath().getLastPathComponent());\r
-                       fuels.setSelectedComponent(fen.getUserObject());\r
-                       split.setRightComponent(fuels);\r
-                       split.setDividerLocation(TREE_WIDTH);\r
-                       split.revalidate();\r
-               }\r
-\r
-               Motor m = getMotor(e.getPath());\r
-\r
-               if (m == null)\r
-                       return;\r
-\r
-               split.setRightComponent(motors);\r
-               split.setDividerLocation(TREE_WIDTH);\r
-               split.revalidate();\r
-               motors.setSelectedComponent(m2e.get(m));\r
-\r
-               if (e.getPath().getLastPathComponent() instanceof DefaultMutableTreeNode) {\r
-                       Object o = ((DefaultMutableTreeNode) e.getPath()\r
-                                       .getLastPathComponent()).getUserObject();\r
-                       m2e.get(m).focusOnObject(o);\r
-               }\r
-\r
-       }\r
-\r
-       private Motor getMotor(TreePath p) {\r
-               if (p.getLastPathComponent() instanceof WorkbenchTreeModel.MotorNode) {\r
-                       return ((WorkbenchTreeModel.MotorNode) p.getLastPathComponent())\r
-                                       .getUserObject();\r
-               } else if (p.getPath().length > 1)\r
-                       return getMotor(p.getParentPath());\r
-               return null;\r
-       }\r
+       \r
 }\r