Normand Briere
2019-06-23 8088590686a45e71278f9a52bb9cc37943dc0c37
ObjEditor.java
....@@ -36,6 +36,8 @@
3636 GroupEditor callee;
3737 JFrame frame;
3838
39
+ static ObjEditor theFrame;
40
+
3941 // SCRIPT
4042
4143 transient JFrame textpanel = null;
....@@ -168,6 +170,7 @@
168170 // objEditor.ctrlPanel.remove(remarkButton);
169171
170172 objEditor.ctrlPanel.remove(setupPanel);
173
+ objEditor.ctrlPanel.remove(setupPanel2);
171174 objEditor.ctrlPanel.remove(commandsPanel);
172175 objEditor.ctrlPanel.remove(pushPanel);
173176 //objEditor.ctrlPanel.remove(fillPanel);
....@@ -243,6 +246,7 @@
243246 //localCopy.parent = null;
244247
245248 frame = new JFrame();
249
+ frame.setUndecorated(true);
246250 objEditor = this;
247251 this.callee = callee;
248252
....@@ -278,7 +282,7 @@
278282 frame.setMenuBar(menuBar = new MenuBar());
279283 menuBar.add(fileMenu = new Menu("File"));
280284 fileMenu.add(newItem = new MenuItem("New"));
281
- fileMenu.add(loadItem = new MenuItem("Load..."));
285
+ fileMenu.add(loadItem = new MenuItem("Open..."));
282286
283287 //oe.menuBar.add(menu = new Menu("Include"));
284288 Menu menu = new Menu("Import");
....@@ -419,10 +423,10 @@
419423 e.printStackTrace();
420424 }
421425
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();
426
+// String selection = infoarea.getText();
427
+// java.awt.datatransfer.StringSelection data = new java.awt.datatransfer.StringSelection(selection);
428
+// java.awt.datatransfer.Clipboard clipboard =
429
+// Toolkit.getDefaultToolkit().getSystemClipboard();
426430 //clipboard.setContents(data, data);
427431 }
428432
....@@ -582,19 +586,89 @@
582586 }
583587 }
584588
589
+static GraphicsDevice device = GraphicsEnvironment
590
+ .getLocalGraphicsEnvironment().getScreenDevices()[0];
591
+
592
+ Rectangle keeprect;
593
+ cRadio radio;
594
+
595
+cButton keepButton;
596
+ cButton twoButton; // Full 3D
597
+ cButton sixButton;
598
+ cButton threeButton;
599
+ cButton sevenButton;
600
+ cButton fourButton; // full panel
601
+ cButton oneButton; // full XYZ
602
+ //cButton currentLayout;
603
+
604
+ boolean maximized;
605
+
606
+ void Minimize()
607
+ {
608
+ frame.setState(Frame.ICONIFIED);
609
+ }
610
+
611
+ void Maximize()
612
+ {
613
+ if (maximized)
614
+ {
615
+ frame.setBounds(keeprect.x, keeprect.y, keeprect.width, keeprect.height);
616
+ }
617
+ else
618
+ {
619
+ keeprect = frame.getBounds();
620
+ Rectangle rect = GraphicsEnvironment.getLocalGraphicsEnvironment().getMaximumWindowBounds();
621
+ Dimension rect2 = frame.getToolkit().getScreenSize();
622
+ frame.setBounds(0, rect2.height - rect.height, rect.width, rect.height);
623
+// frame.setState(Frame.MAXIMIZED_BOTH);
624
+ }
625
+
626
+ maximized ^= true;
627
+ }
628
+
585629 void ToggleFullScreen()
586630 {
587631 if (CameraPane.FULLSCREEN)
588632 {
589
- frame.getContentPane().remove(/*"Center",*/bigThree);
590
- framePanel.add(bigThree);
591
- frame.getContentPane().add(/*"Center",*/framePanel);
633
+ device.setFullScreenWindow(null);
634
+ //frame.setVisible(false);
635
+// frame.removeNotify();
636
+// frame.setUndecorated(false);
637
+// frame.addNotify();
638
+ //frame.setBounds(keeprect.x, keeprect.y, keeprect.width, keeprect.height);
639
+
640
+// X frame.getContentPane().remove(/*"Center",*/bigThree);
641
+// X framePanel.add(bigThree);
642
+// X frame.getContentPane().add(/*"Center",*/framePanel);
643
+ framePanel.setDividerLocation(1);
644
+
645
+ //frame.setVisible(true);
646
+ radio.layout = keepButton;
647
+ //theFrame = null;
648
+ keepButton = null;
649
+ radio.layout.doClick();
650
+
592651 } else
593652 {
594
- frame.getContentPane().remove(/*"Center",*/framePanel);
595
- framePanel.remove(bigThree);
596
- frame.getContentPane().add(/*"Center",*/bigThree);
653
+ keepButton = radio.layout;
654
+ //keeprect = frame.getBounds();
655
+// frame.setBounds(0, 0, frame.getToolkit().getScreenSize().width,
656
+// frame.getToolkit().getScreenSize().height);
657
+ //frame.setVisible(false);
658
+ device.setFullScreenWindow(frame);
659
+// frame.removeNotify();
660
+// frame.setUndecorated(true);
661
+// frame.addNotify();
662
+// X frame.getContentPane().remove(/*"Center",*/framePanel);
663
+// X framePanel.remove(bigThree);
664
+// X frame.getContentPane().add(/*"Center",*/bigThree);
665
+ framePanel.setDividerLocation(0);
666
+
667
+ radio.layout = twoButton;
668
+ radio.layout.doClick();
669
+ //frame.setVisible(true);
597670 }
671
+
598672 cameraView.ToggleFullScreen();
599673 }
600674
....@@ -747,6 +821,7 @@
747821
748822 cGridBag namePanel;
749823 cGridBag setupPanel;
824
+ cGridBag setupPanel2;
750825 cGridBag commandsPanel;
751826 cGridBag pushPanel;
752827 cGridBag fillPanel;
....@@ -939,21 +1014,25 @@
9391014 markCB = AddCheckBox(setupPanel, "Mark", copy.marked);
9401015 markCB.setToolTipText("Set the animation target transform");
9411016
942
- rewindCB = AddCheckBox(setupPanel, "Rewind", copy.rewind);
1017
+ setupPanel2 = new cGridBag().setVertical(false);
1018
+
1019
+ rewindCB = AddCheckBox(setupPanel2, "Rewind", copy.rewind);
9431020 rewindCB.setToolTipText("Rewind animation");
9441021
945
- randomCB = AddCheckBox(setupPanel, "Random", copy.random);
946
- randomCB.setToolTipText("Option for switch node");
1022
+ randomCB = AddCheckBox(setupPanel2, "Rand", copy.random);
1023
+ randomCB.setToolTipText("Randomly Rewind or Go back and forth");
9471024
9481025 if (Globals.ADVANCED)
9491026 {
950
- link2masterCB = AddCheckBox(setupPanel, "Support", copy.link2master);
1027
+ link2masterCB = AddCheckBox(setupPanel2, "Supp", copy.link2master);
9511028 link2masterCB.setToolTipText("Attach to support");
952
- speedupCB = AddCheckBox(setupPanel, "Speed", copy.speedup);
1029
+ speedupCB = AddCheckBox(setupPanel2, "Speed", copy.speedup);
9531030 speedupCB.setToolTipText("Option motion capture");
9541031 }
9551032
9561033 oe.ctrlPanel.add(setupPanel);
1034
+ oe.ctrlPanel.Return();
1035
+ oe.ctrlPanel.add(setupPanel2);
9571036 oe.ctrlPanel.Return();
9581037
9591038 commandsPanel = new cGridBag().setVertical(false);
....@@ -1178,8 +1257,11 @@
11781257 //worldPanel.setName("World");
11791258 centralPanel = new cGridBag();
11801259 centralPanel.preferredWidth = 20;
1181
- timelinePanel = new JPanel(new BorderLayout());
1182
- timelineMenubar = new timeflow.app.TimeflowApp().TimeFlowWindow(timelinePanel);
1260
+
1261
+ if (Globals.ADVANCED)
1262
+ {
1263
+ timelinePanel = new JPanel(new BorderLayout());
1264
+ timelineMenubar = new timeflow.app.TimeflowApp().TimeFlowWindow(timelinePanel);
11831265
11841266 cameraPanel = new JSplitPane(JSplitPane.VERTICAL_SPLIT, cameraView, timelinePanel);
11851267 cameraPanel.setContinuousLayout(true);
....@@ -1188,7 +1270,10 @@
11881270 // cameraPanel.setDividerSize(9);
11891271 cameraPanel.setResizeWeight(1.0);
11901272
1273
+ }
1274
+
11911275 centralPanel.add(cameraView);
1276
+ centralPanel.setFocusable(true);
11921277 //frame.setJMenuBar(timelineMenubar);
11931278 //centralPanel.add(timelinePanel);
11941279
....@@ -1386,6 +1471,8 @@
13861471 frame.setSize(1280, 860);
13871472 frame.setVisible(true);
13881473
1474
+ cameraView.requestFocusInWindow();
1475
+
13891476 gridPanel.setDividerLocation(1.0);
13901477
13911478 frame.setDefaultCloseOperation(WindowConstants.DO_NOTHING_ON_CLOSE);
....@@ -2072,19 +2159,19 @@
20722159
20732160 void LoadObjFile(String fullname)
20742161 {
2075
- /*
2162
+ System.out.println("Loading " + fullname);
2163
+ /**/
20762164 //lastFilename = fullname;
20772165 if(loadObjThread == null)
20782166 {
2079
- loadObjThread = new LoadOBJThread();
2080
- loadObjThread.start();
2167
+ loadObjThread = new LoadOBJThread();
2168
+ loadObjThread.start();
20812169 }
20822170
20832171 loadObjThread.add(fullname);
2084
- */
2172
+ /**/
20852173
2086
- System.out.println("Loading " + fullname);
2087
- makeSomething(new FileObject(fullname, true), true);
2174
+ //makeSomething(new FileObject(fullname, true), true);
20882175 }
20892176
20902177 void LoadGFDFile(String fullname)
....@@ -3214,7 +3301,7 @@
32143301 objEditor.refreshContents();
32153302 }
32163303
3217
- static public byte[] Compress(Object o)
3304
+ static public byte[] Compress(Object3D o)
32183305 {
32193306 try
32203307 {
....@@ -3222,8 +3309,13 @@
32223309 java.util.zip.GZIPOutputStream zstream = new java.util.zip.GZIPOutputStream(baos);
32233310 ObjectOutputStream out = new ObjectOutputStream(zstream);
32243311
3312
+ Object3D parent = o.parent;
3313
+ o.parent = null;
3314
+
32253315 out.writeObject(o);
32263316
3317
+ o.parent = parent;
3318
+
32273319 out.flush();
32283320
32293321 zstream.close();
....@@ -3306,12 +3398,17 @@
33063398 {
33073399 cRadio tab = GetCurrentTab();
33083400
3401
+ boolean temp = CameraPane.SWITCH;
3402
+ CameraPane.SWITCH = false;
3403
+
33093404 copy.ExtractBigData(hashtable);
33103405
33113406 //EditorFrame.m_MainFrame.requestFocusInWindow();
33123407 tab.graphs[tab.undoindex++] = Compress(copy);
33133408
33143409 copy.RestoreBigData(hashtable);
3410
+
3411
+ CameraPane.SWITCH = temp;
33153412
33163413 //assert(hashtable.isEmpty());
33173414
....@@ -3342,6 +3439,9 @@
33423439
33433440 void CopyChanged(Object3D obj)
33443441 {
3442
+ boolean temp = CameraPane.SWITCH;
3443
+ CameraPane.SWITCH = false;
3444
+
33453445 copy.ExtractBigData(hashtable);
33463446
33473447 copy.clear();
....@@ -3352,6 +3452,8 @@
33523452 }
33533453
33543454 copy.RestoreBigData(hashtable);
3455
+
3456
+ CameraPane.SWITCH = temp;
33553457
33563458 //assert(hashtable.isEmpty());
33573459
....@@ -4280,6 +4382,7 @@
42804382
42814383 try
42824384 {
4385
+ // Try compressed version first.
42834386 java.io.FileInputStream istream = new java.io.FileInputStream(fullname);
42844387 java.util.zip.GZIPInputStream zstream = new java.util.zip.GZIPInputStream(istream);
42854388 java.io.ObjectInputStream p = new java.io.ObjectInputStream(zstream);
....@@ -4349,6 +4452,12 @@
43494452
43504453 void LoadIt(Object obj)
43514454 {
4455
+ if (obj == null)
4456
+ {
4457
+ // Invalid file
4458
+ return;
4459
+ }
4460
+
43524461 System.out.println("Loaded " + obj);
43534462 //new Exception().printStackTrace();
43544463 Object3D readobj = (Object3D) obj;