Normand Briere
2019-06-27 f78dd18c66d607b693c0bf5937fc59181bf5a26b
ObjEditor.java
....@@ -4,6 +4,7 @@
44
55 import java.awt.*;
66 import java.awt.event.*;
7
+import java.awt.image.BufferedImage;
78 import javax.swing.*;
89 import javax.swing.event.*;
910 import javax.swing.text.*;
....@@ -13,6 +14,9 @@
1314 import javax.swing.plaf.metal.MetalLookAndFeel;
1415 //import javax.swing.plaf.ColorUIResource;
1516 //import javax.swing.plaf.metal.DefaultMetalTheme;
17
+
18
+import javax.swing.plaf.basic.BasicSplitPaneDivider;
19
+import javax.swing.plaf.basic.BasicSplitPaneUI;
1620
1721 //import javax.media.opengl.GLCanvas;
1822
....@@ -35,6 +39,67 @@
3539
3640 GroupEditor callee;
3741 JFrame frame;
42
+
43
+ static ObjEditor theFrame;
44
+
45
+ cButton GetButton(String name, boolean border)
46
+ {
47
+ try
48
+ {
49
+ ImageIcon icon = GetIcon(name);
50
+ return new cButton(icon, border);
51
+ }
52
+ catch (Exception e)
53
+ {
54
+ return new cButton(name, border);
55
+ }
56
+ }
57
+
58
+ cToggleButton GetToggleButton(String name, boolean border)
59
+ {
60
+ try
61
+ {
62
+ ImageIcon icon = GetIcon(name);
63
+ return new cToggleButton(icon, border);
64
+ }
65
+ catch (Exception e)
66
+ {
67
+ return new cToggleButton(name, border);
68
+ }
69
+ }
70
+
71
+ cCheckBox GetCheckBox(String name, boolean border)
72
+ {
73
+ try
74
+ {
75
+ ImageIcon icon = GetIcon(name);
76
+ return new cCheckBox(icon, border);
77
+ }
78
+ catch (Exception e)
79
+ {
80
+ return new cCheckBox(name, border);
81
+ }
82
+ }
83
+
84
+ private ImageIcon GetIcon(String name) throws IOException
85
+ {
86
+ BufferedImage image = javax.imageio.ImageIO.read(getClass().getClassLoader().getResourceAsStream(name));
87
+
88
+ if (image.getWidth() != 24 && image.getHeight() != 24)
89
+ {
90
+ BufferedImage resized = new BufferedImage(24, 24, image.getType());
91
+ Graphics2D g = resized.createGraphics();
92
+ g.setRenderingHint(RenderingHints.KEY_INTERPOLATION, RenderingHints.VALUE_INTERPOLATION_BILINEAR);
93
+ //g.setRenderingHint(RenderingHints.KEY_ANTIALIASING, RenderingHints.VALUE_ANTIALIAS_ON);
94
+ g.drawImage(image, 0, 0, 24, 24, 0, 0, image.getWidth(), image.getHeight(), null);
95
+ g.dispose();
96
+
97
+ image = resized;
98
+ }
99
+
100
+ javax.swing.ImageIcon icon = new javax.swing.ImageIcon(image);
101
+ return icon;
102
+ }
38103
39104 // SCRIPT
40105
....@@ -145,7 +210,7 @@
145210
146211 objEditor.ctrlPanel.remove(namePanel);
147212
148
- if (!GroupEditor.allparams)
213
+ if (!allparams)
149214 return;
150215
151216 // objEditor.ctrlPanel.remove(liveCB);
....@@ -168,7 +233,8 @@
168233 // objEditor.ctrlPanel.remove(remarkButton);
169234
170235 objEditor.ctrlPanel.remove(setupPanel);
171
- objEditor.ctrlPanel.remove(commandsPanel);
236
+ objEditor.ctrlPanel.remove(setupPanel2);
237
+ objEditor.ctrlPanel.remove(objectCommandsPanel);
172238 objEditor.ctrlPanel.remove(pushPanel);
173239 //objEditor.ctrlPanel.remove(fillPanel);
174240
....@@ -243,6 +309,7 @@
243309 //localCopy.parent = null;
244310
245311 frame = new JFrame();
312
+ frame.setUndecorated(true);
246313 objEditor = this;
247314 this.callee = callee;
248315
....@@ -273,12 +340,17 @@
273340 return frame.action(event, obj);
274341 }
275342
343
+ // Cannot work without static
344
+ static boolean allparams = true;
345
+
346
+ static java.util.Vector<Object3D> listUI = new java.util.Vector<Object3D>();
347
+
276348 void SetupMenu()
277349 {
278350 frame.setMenuBar(menuBar = new MenuBar());
279351 menuBar.add(fileMenu = new Menu("File"));
280352 fileMenu.add(newItem = new MenuItem("New"));
281
- fileMenu.add(loadItem = new MenuItem("Load..."));
353
+ fileMenu.add(loadItem = new MenuItem("Open..."));
282354
283355 //oe.menuBar.add(menu = new Menu("Include"));
284356 Menu menu = new Menu("Import");
....@@ -319,14 +391,52 @@
319391 closeItem.addActionListener(this);
320392
321393 objectPanel = new JTabbedPane();
394
+
395
+ ChangeListener changeListener = new ChangeListener()
396
+ {
397
+ public void stateChanged(ChangeEvent changeEvent)
398
+ {
399
+// if (objectPanel.getSelectedIndex() == objectPanel.indexOfTab("Material") && !materialFlushed)
400
+// {
401
+// if (latestObject != null)
402
+// {
403
+// refreshContents(true);
404
+// SetMaterial(latestObject);
405
+// }
406
+//
407
+// materialFlushed = true;
408
+// }
409
+// if (objectPanel.getSelectedIndex() == objectPanel.indexOfTab("Edit"))
410
+// {
411
+// if (listUI.size() == 0)
412
+// EditSelection(false);
413
+// }
414
+
415
+ refreshContents(false); // To refresh Info tab
416
+ }
417
+ };
418
+ objectPanel.addChangeListener(changeListener);
419
+
322420 toolbarPanel = new JPanel();
323421 toolbarPanel.setName("Toolbar");
324422 treePanel = new cGridBag();
325423 treePanel.setName("Tree");
424
+
425
+ editPanel = new cGridBag().setVertical(true);
426
+ editPanel.setName("Edit");
427
+
326428 ctrlPanel = new cGridBag().setVertical(false); // new GridBagLayout());
327
- ctrlPanel.setName("Edit");
429
+
430
+ editCommandsPanel = new cGridBag();
431
+ editPanel.add(editCommandsPanel);
432
+ editPanel.add(ctrlPanel);
433
+
434
+ toolboxPanel = new cGridBag().setVertical(false);
435
+ toolboxPanel.setName("Toolbox");
436
+
328437 materialPanel = new cGridBag().setVertical(true);
329438 materialPanel.setName("Material");
439
+
330440 /*JTextPane*/
331441 infoarea = createTextPane();
332442 doc = infoarea.getStyledDocument();
....@@ -351,7 +461,13 @@
351461 mainPanel.setDividerSize(9);
352462 mainPanel.setDividerLocation(0.5); //1.0);
353463 mainPanel.setResizeWeight(0.5);
354
-
464
+
465
+//mainPanel.setDividerSize((int) (mainPanel.getDividerSize() * 1.5));
466
+// BasicSplitPaneDivider divider = ( (BasicSplitPaneUI) mainPanel.getUI()).getDivider();
467
+// divider.setDividerSize(15);
468
+// divider.setBorder(BorderFactory.createTitledBorder(divider.getBorder(), "Custom border title -- gets rid of the one-touch arrows!"));
469
+
470
+
355471 //ctrlPanel.setLayout(new GridLayout(4, 1, 5, 5));
356472 //mainPanel.setLayout(new GridBagLayout());
357473 toolbarPanel.setLayout(new FlowLayout(FlowLayout.LEFT));
....@@ -419,10 +535,10 @@
419535 e.printStackTrace();
420536 }
421537
422
- String selection = infoarea.getText();
423
- java.awt.datatransfer.StringSelection data = new java.awt.datatransfer.StringSelection(selection);
424
- java.awt.datatransfer.Clipboard clipboard =
425
- Toolkit.getDefaultToolkit().getSystemClipboard();
538
+// String selection = infoarea.getText();
539
+// java.awt.datatransfer.StringSelection data = new java.awt.datatransfer.StringSelection(selection);
540
+// java.awt.datatransfer.Clipboard clipboard =
541
+// Toolkit.getDefaultToolkit().getSystemClipboard();
426542 //clipboard.setContents(data, data);
427543 }
428544
....@@ -582,20 +698,92 @@
582698 }
583699 }
584700
701
+static GraphicsDevice device = GraphicsEnvironment
702
+ .getLocalGraphicsEnvironment().getScreenDevices()[0];
703
+
704
+ Rectangle keeprect;
705
+ cRadio radio;
706
+
707
+cButton keepButton;
708
+ cButton twoButton; // Full 3D
709
+ cButton sixButton;
710
+ cButton threeButton;
711
+ cButton sevenButton;
712
+ cButton fourButton; // full panel
713
+ cButton oneButton; // full XYZ
714
+ //cButton currentLayout;
715
+
716
+ boolean maximized;
717
+
718
+ cButton fullscreenLayout;
719
+
720
+ void Minimize()
721
+ {
722
+ frame.setState(Frame.ICONIFIED);
723
+ }
724
+
725
+ void Maximize()
726
+ {
727
+ if (maximized)
728
+ {
729
+ frame.setBounds(keeprect.x, keeprect.y, keeprect.width, keeprect.height);
730
+ }
731
+ else
732
+ {
733
+ keeprect = frame.getBounds();
734
+ Rectangle rect = GraphicsEnvironment.getLocalGraphicsEnvironment().getMaximumWindowBounds();
735
+ Dimension rect2 = frame.getToolkit().getScreenSize();
736
+ frame.setBounds(0, rect2.height - rect.height, rect.width, rect.height);
737
+// frame.setState(Frame.MAXIMIZED_BOTH);
738
+ }
739
+
740
+ maximized ^= true;
741
+ }
742
+
585743 void ToggleFullScreen()
586744 {
587
- if (CameraPane.FULLSCREEN)
745
+ cameraView.ToggleFullScreen();
746
+
747
+ if (!CameraPane.FULLSCREEN)
588748 {
589
- frame.getContentPane().remove(/*"Center",*/bigThree);
590
- framePanel.add(bigThree);
591
- frame.getContentPane().add(/*"Center",*/framePanel);
749
+ device.setFullScreenWindow(null);
750
+ //frame.setVisible(false);
751
+// frame.removeNotify();
752
+// frame.setUndecorated(false);
753
+// frame.addNotify();
754
+ //frame.setBounds(keeprect.x, keeprect.y, keeprect.width, keeprect.height);
755
+
756
+// X frame.getContentPane().remove(/*"Center",*/bigThree);
757
+// X framePanel.add(bigThree);
758
+// X frame.getContentPane().add(/*"Center",*/framePanel);
759
+ framePanel.setDividerLocation(1);
760
+
761
+ //frame.setVisible(true);
762
+ radio.layout = keepButton;
763
+ //theFrame = null;
764
+ keepButton = null;
765
+ radio.layout.doClick();
766
+
592767 } else
593768 {
594
- frame.getContentPane().remove(/*"Center",*/framePanel);
595
- framePanel.remove(bigThree);
596
- frame.getContentPane().add(/*"Center",*/bigThree);
769
+ keepButton = radio.layout;
770
+ //keeprect = frame.getBounds();
771
+// frame.setBounds(0, 0, frame.getToolkit().getScreenSize().width,
772
+// frame.getToolkit().getScreenSize().height);
773
+ //frame.setVisible(false);
774
+ device.setFullScreenWindow(frame);
775
+// frame.removeNotify();
776
+// frame.setUndecorated(true);
777
+// frame.addNotify();
778
+// X frame.getContentPane().remove(/*"Center",*/framePanel);
779
+// X framePanel.remove(bigThree);
780
+// X frame.getContentPane().add(/*"Center",*/bigThree);
781
+ framePanel.setDividerLocation(0);
782
+
783
+ radio.layout = fullscreenLayout;
784
+ radio.layout.doClick();
785
+ //frame.setVisible(true);
597786 }
598
- cameraView.ToggleFullScreen();
599787 }
600788
601789 private JTextPane createTextPane()
....@@ -736,7 +924,12 @@
736924 JCheckBox speedupCB;
737925 JCheckBox rewindCB;
738926 JCheckBox flipVCB;
927
+
928
+ cCheckBox toggleTextureCB;
929
+ cCheckBox toggleSwitchCB;
930
+
739931 JComboBox texresMenu;
932
+
740933 JButton resetButton;
741934 JButton stepButton;
742935 JButton stepAllButton;
....@@ -745,9 +938,13 @@
745938 JButton fasterButton;
746939 JButton remarkButton;
747940
941
+ cGridBag editPanel;
942
+ cGridBag editCommandsPanel;
943
+
748944 cGridBag namePanel;
749945 cGridBag setupPanel;
750
- cGridBag commandsPanel;
946
+ cGridBag setupPanel2;
947
+ cGridBag objectCommandsPanel;
751948 cGridBag pushPanel;
752949 cGridBag fillPanel;
753950
....@@ -924,7 +1121,7 @@
9241121
9251122 oe.ctrlPanel.Return();
9261123
927
- if (!GroupEditor.allparams)
1124
+ if (!allparams)
9281125 return;
9291126
9301127 setupPanel = new cGridBag().setVertical(false);
....@@ -937,42 +1134,46 @@
9371134 hideCB = AddCheckBox(setupPanel, "Hide", copy.hide);
9381135 hideCB.setToolTipText("Hide object");
9391136 markCB = AddCheckBox(setupPanel, "Mark", copy.marked);
940
- markCB.setToolTipText("Set the animation target transform");
1137
+ markCB.setToolTipText("As animation target transform");
9411138
942
- rewindCB = AddCheckBox(setupPanel, "Rewind", copy.rewind);
1139
+ setupPanel2 = new cGridBag().setVertical(false);
1140
+
1141
+ rewindCB = AddCheckBox(setupPanel2, "Rewind", copy.rewind);
9431142 rewindCB.setToolTipText("Rewind animation");
9441143
945
- randomCB = AddCheckBox(setupPanel, "Random", copy.random);
946
- randomCB.setToolTipText("Option for switch node");
1144
+ randomCB = AddCheckBox(setupPanel2, "Rand", copy.random);
1145
+ randomCB.setToolTipText("Randomly Rewind (or Go back and forth)");
9471146
9481147 if (Globals.ADVANCED)
9491148 {
950
- link2masterCB = AddCheckBox(setupPanel, "Support", copy.link2master);
1149
+ link2masterCB = AddCheckBox(setupPanel2, "Supp", copy.link2master);
9511150 link2masterCB.setToolTipText("Attach to support");
952
- speedupCB = AddCheckBox(setupPanel, "Speed", copy.speedup);
1151
+ speedupCB = AddCheckBox(setupPanel2, "Speed", copy.speedup);
9531152 speedupCB.setToolTipText("Option motion capture");
9541153 }
9551154
9561155 oe.ctrlPanel.add(setupPanel);
9571156 oe.ctrlPanel.Return();
1157
+ oe.ctrlPanel.add(setupPanel2);
1158
+ oe.ctrlPanel.Return();
9581159
959
- commandsPanel = new cGridBag().setVertical(false);
1160
+ objectCommandsPanel = new cGridBag().setVertical(false);
9601161
961
- resetButton = AddButton(commandsPanel, "Reset");
1162
+ resetButton = AddButton(objectCommandsPanel, "Reset");
9621163 resetButton.setToolTipText("Jump to frame zero");
963
- stepButton = AddButton(commandsPanel, "Step");
1164
+ stepButton = AddButton(objectCommandsPanel, "Step");
9641165 stepButton.setToolTipText("Step one frame");
9651166 // resetAllButton = AddButton(oe, "Reset All");
9661167 // stepAllButton = AddButton(oe, "Step All");
9671168 // Return();
968
- slowerButton = AddButton(commandsPanel, "Slow");
1169
+ slowerButton = AddButton(objectCommandsPanel, "Slow");
9691170 slowerButton.setToolTipText("Decrease animation speed");
970
- fasterButton = AddButton(commandsPanel, "Fast");
1171
+ fasterButton = AddButton(objectCommandsPanel, "Fast");
9711172 fasterButton.setToolTipText("Increase animation speed");
972
- remarkButton = AddButton(commandsPanel, "Remark");
1173
+ remarkButton = AddButton(objectCommandsPanel, "Remark");
9731174 remarkButton.setToolTipText("Set the current transform as the target");
9741175
975
- oe.ctrlPanel.add(commandsPanel);
1176
+ oe.ctrlPanel.add(objectCommandsPanel);
9761177 oe.ctrlPanel.Return();
9771178
9781179 pushPanel = AddSlider(oe.ctrlPanel, "Push", -1, 1, copy.NORMALPUSH, 1.1); // To have the buttons
....@@ -1178,8 +1379,11 @@
11781379 //worldPanel.setName("World");
11791380 centralPanel = new cGridBag();
11801381 centralPanel.preferredWidth = 20;
1181
- timelinePanel = new JPanel(new BorderLayout());
1182
- timelineMenubar = new timeflow.app.TimeflowApp().TimeFlowWindow(timelinePanel);
1382
+
1383
+ if (Globals.ADVANCED)
1384
+ {
1385
+ timelinePanel = new JPanel(new BorderLayout());
1386
+ timelineMenubar = new timeflow.app.TimeflowApp().TimeFlowWindow(timelinePanel);
11831387
11841388 cameraPanel = new JSplitPane(JSplitPane.VERTICAL_SPLIT, cameraView, timelinePanel);
11851389 cameraPanel.setContinuousLayout(true);
....@@ -1188,7 +1392,10 @@
11881392 // cameraPanel.setDividerSize(9);
11891393 cameraPanel.setResizeWeight(1.0);
11901394
1395
+ }
1396
+
11911397 centralPanel.add(cameraView);
1398
+ centralPanel.setFocusable(true);
11921399 //frame.setJMenuBar(timelineMenubar);
11931400 //centralPanel.add(timelinePanel);
11941401
....@@ -1255,8 +1462,9 @@
12551462 // north.setName("Edit");
12561463 // north.add(ctrlPanel, BorderLayout.NORTH);
12571464 // objectPanel.add(north);
1258
- objectPanel.add(ctrlPanel);
1465
+ objectPanel.add(editPanel);
12591466 objectPanel.add(infoPanel);
1467
+ objectPanel.add(toolboxPanel);
12601468
12611469 /*
12621470 aConstraints.gridx = 0;
....@@ -1265,7 +1473,7 @@
12651473 aConstraints.gridy += 1;
12661474 aConstraints.gridwidth = 1;
12671475 mainPanel.add(objectPanel, aConstraints);
1268
- */
1476
+ */
12691477
12701478 scrollpane = new JScrollPane(mainPanel, ScrollPaneConstants.// VERTICAL_SCROLLBAR_ALWAYS,
12711479 VERTICAL_SCROLLBAR_AS_NEEDED,
....@@ -1282,9 +1490,7 @@
12821490 JTabbedPane tabbedPane = new JTabbedPane();
12831491 tabbedPane.add(scrollpane);
12841492
1285
- tabbedPane.add(FSPane = new cFileSystemPane(this));
1286
-
1287
- optionsPanel = new cGridBag().setVertical(true);
1493
+ optionsPanel = new cGridBag().setVertical(false);
12881494
12891495 optionsPanel.setName("Options");
12901496
....@@ -1292,6 +1498,8 @@
12921498
12931499 tabbedPane.add(optionsPanel);
12941500
1501
+ tabbedPane.add(FSPane = new cFileSystemPane(this));
1502
+
12951503 scenePanel.add(tabbedPane);
12961504
12971505 /*
....@@ -1384,8 +1592,12 @@
13841592 // aConstraints = gbc; // (GridBagConstraints) GrafreeD.clone(gbc);
13851593
13861594 frame.setSize(1280, 860);
1595
+
1596
+ frame.validate();
13871597 frame.setVisible(true);
13881598
1599
+ cameraView.requestFocusInWindow();
1600
+
13891601 gridPanel.setDividerLocation(1.0);
13901602
13911603 frame.setDefaultCloseOperation(WindowConstants.DO_NOTHING_ON_CLOSE);
....@@ -2072,19 +2284,19 @@
20722284
20732285 void LoadObjFile(String fullname)
20742286 {
2075
- /*
2287
+ System.out.println("Loading " + fullname);
2288
+ /**/
20762289 //lastFilename = fullname;
20772290 if(loadObjThread == null)
20782291 {
2079
- loadObjThread = new LoadOBJThread();
2080
- loadObjThread.start();
2292
+ loadObjThread = new LoadOBJThread();
2293
+ loadObjThread.start();
20812294 }
20822295
20832296 loadObjThread.add(fullname);
2084
- */
2297
+ /**/
20852298
2086
- System.out.println("Loading " + fullname);
2087
- makeSomething(new FileObject(fullname, true), true);
2299
+ //makeSomething(new FileObject(fullname, true), true);
20882300 }
20892301
20902302 void LoadGFDFile(String fullname)
....@@ -2701,6 +2913,8 @@
27012913
27022914 void SetMaterial(Object3D object)
27032915 {
2916
+ latestObject = object;
2917
+
27042918 cMaterial mat = object.material;
27052919
27062920 if (mat == null)
....@@ -2812,12 +3026,17 @@
28123026 // }
28133027
28143028 /**/
2815
- if (deselect)
3029
+ if (deselect || child == null)
28163030 {
28173031 //group.deselectAll();
28183032 //freeze = true;
28193033 GetTree().clearSelection();
28203034 //freeze = false;
3035
+
3036
+ if (child == null)
3037
+ {
3038
+ return;
3039
+ }
28213040 }
28223041
28233042 //group.addSelectee(child);
....@@ -2886,7 +3105,7 @@
28863105 cameraView.ToggleDL();
28873106 cameraView.repaint();
28883107 return;
2889
- } else if (event.getSource() == toggleTextureItem)
3108
+ } else if (event.getSource() == toggleTextureItem || event.getSource() == toggleTextureCB)
28903109 {
28913110 cameraView.ToggleTexture();
28923111 // june 2013 copy.HardTouch();
....@@ -2925,9 +3144,9 @@
29253144 frame.validate();
29263145
29273146 return;
2928
- } else if (event.getSource() == toggleSwitchItem)
3147
+ } else if (event.getSource() == toggleSwitchItem || event.getSource() == toggleSwitchCB)
29293148 {
2930
- cameraView.ToggleRandom();
3149
+ cameraView.ToggleSwitch();
29313150 cameraView.repaint();
29323151 return;
29333152 } else if (event.getSource() == toggleHandleItem)
....@@ -3214,6 +3433,53 @@
32143433 objEditor.refreshContents();
32153434 }
32163435
3436
+ static public byte[] Compress(Object3D o)
3437
+ {
3438
+ try
3439
+ {
3440
+ ByteArrayOutputStream baos = new ByteArrayOutputStream();
3441
+ java.util.zip.GZIPOutputStream zstream = new java.util.zip.GZIPOutputStream(baos);
3442
+ ObjectOutputStream out = new ObjectOutputStream(zstream);
3443
+
3444
+ Object3D parent = o.parent;
3445
+ o.parent = null;
3446
+
3447
+ out.writeObject(o);
3448
+
3449
+ o.parent = parent;
3450
+
3451
+ out.flush();
3452
+
3453
+ zstream.close();
3454
+ out.close();
3455
+
3456
+ return baos.toByteArray();
3457
+ } catch (Exception e)
3458
+ {
3459
+ System.err.println(e);
3460
+ return null;
3461
+ }
3462
+ }
3463
+
3464
+ static public Object Uncompress(byte[] bytes)
3465
+ {
3466
+ System.out.println("#bytes = " + bytes.length);
3467
+ try
3468
+ {
3469
+ ByteArrayInputStream bais = new ByteArrayInputStream(bytes);
3470
+ java.util.zip.GZIPInputStream istream = new java.util.zip.GZIPInputStream(bais);
3471
+ ObjectInputStream in = new ObjectInputStream(istream);
3472
+ Object obj = in.readObject();
3473
+ in.close();
3474
+
3475
+ return obj;
3476
+ } catch (Exception e)
3477
+ {
3478
+ System.err.println(e);
3479
+ return null;
3480
+ }
3481
+ }
3482
+
32173483 static public Object clone(Object o)
32183484 {
32193485 try
....@@ -3222,12 +3488,19 @@
32223488 ObjectOutputStream out = new ObjectOutputStream(baos);
32233489
32243490 out.writeObject(o);
3491
+
3492
+ out.flush();
3493
+ out.close();
3494
+
3495
+ byte[] bytes = baos.toByteArray();
3496
+
3497
+ System.out.println("clone = " + bytes.length);
32253498
3226
- ByteArrayInputStream bais = new ByteArrayInputStream(baos.toByteArray());
3499
+ ByteArrayInputStream bais = new ByteArrayInputStream(bytes);
32273500 ObjectInputStream in = new ObjectInputStream(bais);
32283501 Object obj = in.readObject();
32293502 in.close();
3230
- out.close();
3503
+
32313504 return obj;
32323505 } catch (Exception e)
32333506 {
....@@ -3242,7 +3515,7 @@
32423515 for (java.util.Enumeration e = buttonGroup.getElements(); e.hasMoreElements();)
32433516 {
32443517 ab = (cRadio)e.nextElement();
3245
- if(ab.GetObject() == client)
3518
+ if(ab.GetObject() == copy)
32463519 {
32473520 return ab;
32483521 }
....@@ -3251,18 +3524,35 @@
32513524 return null;
32523525 }
32533526
3527
+ java.util.Hashtable<java.util.UUID, Object3D> hashtable = new java.util.Hashtable<java.util.UUID, Object3D>();
3528
+
32543529 public void Save()
32553530 {
3531
+ System.err.println("Save");
3532
+
32563533 cRadio tab = GetCurrentTab();
32573534
3535
+ boolean temp = CameraPane.SWITCH;
3536
+ CameraPane.SWITCH = false;
3537
+
3538
+ copy.ExtractBigData(hashtable);
3539
+
32583540 //EditorFrame.m_MainFrame.requestFocusInWindow();
3259
- tab.graphs[tab.undoindex++] = (Object3D)clone(copy);
3541
+ tab.graphs[tab.undoindex++] = Compress(copy);
32603542
3543
+ copy.RestoreBigData(hashtable);
3544
+
3545
+ CameraPane.SWITCH = temp;
3546
+
3547
+ //assert(hashtable.isEmpty());
3548
+
32613549 for (int i = tab.undoindex; i < tab.graphs.length; i++)
32623550 {
32633551 tab.graphs[i] = null;
32643552 }
32653553
3554
+ SetUndoStates();
3555
+
32663556 // test save
32673557 if (false)
32683558 {
....@@ -3285,12 +3575,25 @@
32853575
32863576 void CopyChanged(Object3D obj)
32873577 {
3578
+ SetUndoStates();
3579
+
3580
+ boolean temp = CameraPane.SWITCH;
3581
+ CameraPane.SWITCH = false;
3582
+
3583
+ copy.ExtractBigData(hashtable);
3584
+
32883585 copy.clear();
32893586
32903587 for (int i=0; i<obj.Size(); i++)
32913588 {
32923589 copy.add(obj.get(i));
32933590 }
3591
+
3592
+ copy.RestoreBigData(hashtable);
3593
+
3594
+ CameraPane.SWITCH = temp;
3595
+
3596
+ //assert(hashtable.isEmpty());
32943597
32953598 copy.Touch();
32963599
....@@ -3313,8 +3616,21 @@
33133616 refreshContents();
33143617 }
33153618
3619
+ cButton undoButton;
3620
+ cButton redoButton;
3621
+
3622
+ void SetUndoStates()
3623
+ {
3624
+ cRadio tab = GetCurrentTab();
3625
+
3626
+ undoButton.setEnabled(tab.undoindex > 0);
3627
+ redoButton.setEnabled(tab.graphs[tab.undoindex + 1] != null);
3628
+ }
3629
+
33163630 public void Undo()
33173631 {
3632
+ System.err.println("Undo");
3633
+
33183634 cRadio tab = GetCurrentTab();
33193635
33203636 if (tab.undoindex == 0)
....@@ -3331,7 +3647,7 @@
33313647
33323648 tab.undoindex -= 1;
33333649
3334
- CopyChanged(tab.graphs[tab.undoindex]);
3650
+ CopyChanged((Object3D)Uncompress(tab.graphs[tab.undoindex]));
33353651 }
33363652
33373653 public void Redo()
....@@ -3346,7 +3662,7 @@
33463662
33473663 tab.undoindex += 1;
33483664
3349
- CopyChanged(tab.graphs[tab.undoindex]);
3665
+ CopyChanged((Object3D)Uncompress(tab.graphs[tab.undoindex]));
33503666 }
33513667
33523668 void ImportGFD()
....@@ -3498,7 +3814,7 @@
34983814 assert false;
34993815 }
35003816
3501
- void EditSelection()
3817
+ void EditSelection(boolean newWindow)
35023818 {
35033819 }
35043820
....@@ -3993,7 +4309,8 @@
39934309
39944310 void makeSomething(Object3D thing, boolean resetmodel) // deselect)
39954311 {
3996
- Save();
4312
+ if (Globals.SAVEONMAKE) // && resetmodel)
4313
+ Save();
39974314 //Tween.set(thing, 0).target(1).start(tweenManager);
39984315 //Tween.to(thing, 0, 0.5f).target(0).start(tweenManager);
39994316 // if (thing instanceof GenericJointDemo)
....@@ -4080,6 +4397,12 @@
40804397 {
40814398 ResetModel();
40824399 Select(thing.GetTreePath(), true, false); // unselect... false);
4400
+
4401
+ if (thing.Size() == 0)
4402
+ {
4403
+ //EditSelection(false);
4404
+ }
4405
+
40834406 refreshContents();
40844407 }
40854408
....@@ -4217,6 +4540,7 @@
42174540
42184541 try
42194542 {
4543
+ // Try compressed version first.
42204544 java.io.FileInputStream istream = new java.io.FileInputStream(fullname);
42214545 java.util.zip.GZIPInputStream zstream = new java.util.zip.GZIPInputStream(istream);
42224546 java.io.ObjectInputStream p = new java.io.ObjectInputStream(zstream);
....@@ -4286,6 +4610,12 @@
42864610
42874611 void LoadIt(Object obj)
42884612 {
4613
+ if (obj == null)
4614
+ {
4615
+ // Invalid file
4616
+ return;
4617
+ }
4618
+
42894619 System.out.println("Loaded " + obj);
42904620 //new Exception().printStackTrace();
42914621 Object3D readobj = (Object3D) obj;
....@@ -4295,6 +4625,8 @@
42954625
42964626 if (readobj != null)
42974627 {
4628
+ if (Globals.SAVEONMAKE)
4629
+ Save();
42984630 try
42994631 {
43004632 //readobj.deepCopySelf(copy);
....@@ -4472,6 +4804,8 @@
44724804 String filename = browser.getFile();
44734805 if (filename != null && filename.length() > 0)
44744806 {
4807
+ if (!filename.endsWith(".gfd"))
4808
+ filename += ".gfd";
44754809 lastname = browser.getDirectory() + filename;
44764810 save();
44774811 }
....@@ -4665,18 +4999,31 @@
46654999 CheckboxMenuItem togglePaintItem;
46665000 JSplitPane mainPanel;
46675001 JScrollPane scrollpane;
5002
+
46685003 JPanel toolbarPanel;
5004
+
46695005 cGridBag treePanel;
5006
+
46705007 JPanel radioPanel;
46715008 ButtonGroup buttonGroup;
4672
- cGridBag ctrlPanel;
5009
+
5010
+ cGridBag toolboxPanel;
46735011 cGridBag materialPanel;
5012
+ cGridBag ctrlPanel;
5013
+
46745014 JScrollPane infoPanel;
5015
+
46755016 cGridBag optionsPanel;
5017
+
46765018 JTabbedPane objectPanel;
5019
+ boolean materialFlushed;
5020
+ Object3D latestObject;
5021
+
46775022 cGridBag XYZPanel;
5023
+
46785024 JSplitPane gridPanel;
46795025 JSplitPane bigPanel;
5026
+
46805027 cGridBag bigThree;
46815028 cGridBag scenePanel;
46825029 cGridBag centralPanel;
....@@ -4791,7 +5138,7 @@
47915138 cNumberSlider fogField;
47925139 JLabel opacityPowerLabel;
47935140 cNumberSlider opacityPowerField;
4794
- JTree jTree;
5141
+ cTree jTree;
47955142 //ObjectUI parent;
47965143
47975144 cNumberSlider normalpushField;