Normand Briere
2019-04-29 bed42c663d286d76a32f155049f9efabc2fdb73f
ObjEditor.java
....@@ -19,6 +19,8 @@
1919 import //weka.core.
2020 matrix.Matrix;
2121
22
+import grafeme.ui.*;
23
+
2224 class ObjEditor /*extends JFrame*/ implements iCallBack, ObjectUI,
2325 ActionListener, ChangeListener,
2426 InputMethodListener,
....@@ -28,7 +30,12 @@
2830 iSendInfo
2931 //KeyListener
3032 {
33
+ boolean timeline;
34
+ boolean wasFullScreen;
3135
36
+ GroupEditor callee;
37
+ JFrame frame;
38
+
3239 // SCRIPT
3340
3441 transient JFrame textpanel = null;
....@@ -119,14 +126,13 @@
119126 void keyPressed(int key, int modifiers)
120127 {
121128 System.out.println("KEY PRESSED");
122
- CameraPane.theRenderer.keyPressed(key, modifiers);
129
+ Globals.theRenderer.keyPressed(key, modifiers);
123130 }
124131 */
125132
126133 static GridBagConstraints aConstraints;
127134 static GridBagConstraints aWindowConstraints;
128
- GroupEditor callee;
129
- JFrame frame;
135
+
130136 static int GRIDWIDTH = 100; // 4;
131137
132138 public void closeUI()
....@@ -158,12 +164,16 @@
158164 objEditor.ctrlPanel.remove(slowerButton);
159165 objEditor.ctrlPanel.remove(fasterButton);
160166 objEditor.ctrlPanel.remove(remarkButton);
167
+
168
+ Remove(normalpushField);
161169 }
162170
163171 public ObjEditor GetEditor()
164172 {
165173 return objEditor; //.GetEditor();
166174 }
175
+
176
+ // Sometimes myself, sometimes my callee's.
167177 ObjEditor objEditor;
168178
169179 /*
....@@ -238,7 +248,7 @@
238248 //if (!isDisplayable())
239249 //setUndecorated(true);
240250
241
- System.out.println("getFullScreenWindow? " + gd.getFullScreenWindow());
251
+ //System.out.println("getFullScreenWindow? " + gd.getFullScreenWindow());
242252 client = inClient;
243253 copy = localCopy;
244254 copy.editWindow = this;
....@@ -292,16 +302,18 @@
292302 //normalLensItem.addActionListener(this);
293303 cameraMenu.add(revertCameraItem = new MenuItem("Revert Camera"));
294304 revertCameraItem.addActionListener(this);
295
- cameraMenu.add(toggleFullItem = new CheckboxMenuItem("Full Screen"));
296
- toggleFullItem.addItemListener(this);
297
- toggleFullItem.setState(CameraPane.FULLSCREEN);
305
+ cameraMenu.add(toggleTimelineItem = new CheckboxMenuItem("Timeline"));
306
+ toggleTimelineItem.addItemListener(this);
307
+ cameraMenu.add(toggleFullScreenItem = new CheckboxMenuItem("Full Screen"));
308
+ toggleFullScreenItem.addItemListener(this);
309
+ toggleFullScreenItem.setState(CameraPane.FULLSCREEN);
298310 cameraMenu.add("-");
299311 cameraMenu.add(toggleTextureItem = new CheckboxMenuItem("Texture"));
300312 toggleTextureItem.addItemListener(this);
301313 toggleTextureItem.setState(CameraPane.textureon);
302314 cameraMenu.add(toggleLiveItem = new CheckboxMenuItem("Live"));
303315 toggleLiveItem.addItemListener(this);
304
- toggleLiveItem.setState(CameraPane.isLIVE());
316
+ toggleLiveItem.setState(Globals.isLIVE());
305317 cameraMenu.add(stepItem = new MenuItem("Step"));
306318 stepItem.addActionListener(this);
307319 // cameraMenu.add(toggleDLItem = new CheckboxMenuItem("Display List"));
....@@ -522,18 +534,18 @@
522534 maxima.y = sel.toParent[3][1];
523535 maxima.z = sel.toParent[3][2];
524536 si.SendInfo(" Orig: " + maxima, "regular");
525
- maxima.x = sel.globalTransform[3][0];
526
- maxima.y = sel.globalTransform[3][1];
527
- maxima.z = sel.globalTransform[3][2];
528
- if (full)
529
- si.SendInfo(" Global Orig: " + maxima, "regular");
530537 maxima.x = sel.toParent[0][0];
531538 maxima.y = sel.toParent[1][1];
532539 maxima.z = sel.toParent[2][2];
533540 si.SendInfo(" Scale: " + maxima, "regular");
534
- maxima.x = sel.globalTransform[0][0];
535
- maxima.y = sel.globalTransform[1][1];
536
- maxima.z = sel.globalTransform[2][2];
541
+ maxima.x = sel.globalTransform[3][0];
542
+ maxima.y = sel.globalTransform[3][1];
543
+ maxima.z = sel.globalTransform[3][2];
544
+ if (full)
545
+ si.SendInfo(" Global Orig: " + maxima, "regular");
546
+ maxima.x = sel.globalTransform[0][0];
547
+ maxima.y = sel.globalTransform[1][1];
548
+ maxima.z = sel.globalTransform[2][2];
537549 if (full)
538550 si.SendInfo(" Global Scale: " + maxima, "regular");
539551 }
....@@ -593,6 +605,22 @@
593605 System.err.println("Couldn't insert initial text into text pane.");
594606 }
595607 }
608
+
609
+ void ToggleFullScreen()
610
+ {
611
+ if (CameraPane.FULLSCREEN)
612
+ {
613
+ frame.getContentPane().remove(/*"Center",*/bigThree);
614
+ framePanel.add(bigThree);
615
+ frame.getContentPane().add(/*"Center",*/framePanel);
616
+ } else
617
+ {
618
+ frame.getContentPane().remove(/*"Center",*/framePanel);
619
+ framePanel.remove(bigThree);
620
+ frame.getContentPane().add(/*"Center",*/bigThree);
621
+ }
622
+ cameraView.ToggleFullScreen();
623
+ }
596624
597625 private JTextArea createTextPane()
598626 {
....@@ -794,7 +822,7 @@
794822
795823 aConstraints.fill = GridBagConstraints.VERTICAL;
796824 jlabel.setHorizontalAlignment(SwingConstants.TRAILING);
797
- aConstraints.gridwidth = 2;
825
+ aConstraints.gridwidth = 1;
798826 ctrlPanel.add(jlabel, aConstraints); //, oe.ctrlPanel.getComponentCount()-1);
799827 aConstraints.gridx += 1;
800828 aConstraints.fill = GridBagConstraints.HORIZONTAL;
....@@ -963,6 +991,9 @@
963991
964992 Return();
965993
994
+ normalpushField = AddSlider(oe.ctrlPanel, "Push", -10, 10, 0, -1);
995
+ Return();
996
+
966997 // oe.ctrlPanel.add(stepButton = new cButton("Step"), ObjEditor.aConstraints, oe.ctrlPanel.getComponentCount() - 2);
967998 // ObjEditor.aConstraints.gridx += 1;
968999
....@@ -1158,10 +1189,21 @@
11581189 //JPanel worldPanel =
11591190 // new gov.nasa.worldwind.examples.ApplicationTemplate.AppPanel(null, true);
11601191 //worldPanel.setName("World");
1161
- /*JPanel*/ cameraPanel =
1162
- new JPanel(new BorderLayout());
1163
- cameraPanel.add(cameraView);
1192
+ centralPanel = new JPanel(new BorderLayout());
1193
+ timelinePanel = new JPanel(new BorderLayout());
1194
+ timelineMenubar = new timeflow.app.TimeflowApp().TimeFlowWindow(timelinePanel);
11641195
1196
+ cameraPanel = new JSplitPane(JSplitPane.VERTICAL_SPLIT, cameraView, timelinePanel);
1197
+ cameraPanel.setContinuousLayout(true);
1198
+ cameraPanel.setOneTouchExpandable(true);
1199
+// cameraPanel.setDividerLocation(0.9);
1200
+// cameraPanel.setDividerSize(9);
1201
+ cameraPanel.setResizeWeight(1.0);
1202
+
1203
+ centralPanel.add(cameraView);
1204
+ //frame.setJMenuBar(timelineMenubar);
1205
+ //centralPanel.add(timelinePanel);
1206
+
11651207 //topView.camera = ;
11661208 //frontView.camera = new Camera(2);
11671209 //sideView.camera = new Camera(3);
....@@ -1177,12 +1219,12 @@
11771219 //frontView.object = copy;
11781220 //sideView.object = copy;
11791221
1180
- XYZPanel = new JPanel();
1181
- XYZPanel.setLayout(new GridLayout(3, 1, 5, 5));
1222
+ XYZPanel = new cGridBag().setVertical(true);
1223
+ //XYZPanel.setLayout(new GridLayout(3, 1, 5, 5));
11821224
1183
- XYZPanel.add(/*BorderLayout.SOUTH,*/sideView); // Scroll);
1184
- XYZPanel.add(/*BorderLayout.CENTER,*/frontView); // Scroll);
1185
- XYZPanel.add(/*BorderLayout.NORTH,*/topView); // Scroll);
1225
+ XYZPanel.addComponent(/*BorderLayout.SOUTH,*/sideView); // Scroll);
1226
+ XYZPanel.addComponent(/*BorderLayout.CENTER,*/frontView); // Scroll);
1227
+ XYZPanel.addComponent(/*BorderLayout.NORTH,*/topView); // Scroll);
11861228
11871229 /*
11881230 gridPanel = new JPanel(); //new BorderLayout());
....@@ -1191,7 +1233,7 @@
11911233 gridPanel.add(cameraView);
11921234 gridPanel.add(XYZPanel);
11931235 */
1194
- gridPanel = new JSplitPane(JSplitPane.HORIZONTAL_SPLIT, cameraPanel, XYZPanel); //new BorderLayout());
1236
+ gridPanel = new JSplitPane(JSplitPane.HORIZONTAL_SPLIT, centralPanel, XYZPanel); //new BorderLayout());
11951237 gridPanel.setContinuousLayout(true);
11961238 gridPanel.setOneTouchExpandable(true);
11971239 gridPanel.setDividerLocation(1.0);
....@@ -1244,15 +1286,18 @@
12441286 scrollpane.setWheelScrollingEnabled(true);
12451287 scrollpane.addMouseWheelListener(this); // Default not fast enough
12461288
1247
- /*JTabbedPane*/ jtp = new JTabbedPane();
1248
- jtp.add(scrollpane);
1289
+ /*JTabbedPane*/ scenePanel = new JTabbedPane();
1290
+ scenePanel.add(scrollpane);
12491291
1250
- jtp.add(FSPane = new cFileSystemPane(this));
1292
+ scenePanel.add(FSPane = new cFileSystemPane(this));
12511293
12521294 optionsPanel = new JPanel(new GridBagLayout());
12531295
12541296 optionsPanel.setName("Options");
1255
- jtp.add(optionsPanel);
1297
+
1298
+ AddOptions(optionsPanel, aConstraints);
1299
+
1300
+ scenePanel.add(optionsPanel);
12561301
12571302
12581303 /*
....@@ -1275,7 +1320,7 @@
12751320 jtp.add(tree);
12761321 */
12771322
1278
- bigPanel = new JSplitPane(JSplitPane.HORIZONTAL_SPLIT, jtp, gridPanel);
1323
+ bigPanel = new JSplitPane(JSplitPane.HORIZONTAL_SPLIT, scenePanel, gridPanel);
12791324 bigPanel.setContinuousLayout(true);
12801325 bigPanel.setOneTouchExpandable(true);
12811326 bigPanel.setDividerLocation(0.8);
....@@ -1287,6 +1332,7 @@
12871332 //bigPanel.setSize(new Dimension(10,10));
12881333 //bigPanel.add(ctrlPanel);
12891334 //bigPanel.add(gridPanel);
1335
+ /**
12901336 bigThree = new JPanel();
12911337 //big.setLayout(new FlowLayout(FlowLayout.LEFT));
12921338 bigThree.setLayout(new GridBagLayout()); //1,3,5,5));
....@@ -1297,20 +1343,26 @@
12971343 aWindowConstraints.fill = GridBagConstraints.VERTICAL;
12981344 aWindowConstraints.weightx = 0;
12991345 aWindowConstraints.weighty = 1;
1300
- bigThree.add(jtp, aWindowConstraints);
1346
+ bigThree.add(scenePanel, aWindowConstraints);
13011347 aWindowConstraints.weightx = 1;
13021348 aWindowConstraints.gridwidth = 3;
13031349 // aConstraints.gridheight = 3;
13041350 aWindowConstraints.gridx = 1;
13051351 aWindowConstraints.fill = GridBagConstraints.BOTH;
1306
- bigThree.add(cameraPanel, aWindowConstraints);
1352
+ bigThree.add(centralPanel, aWindowConstraints);
13071353 aWindowConstraints.weightx = 0;
13081354 aWindowConstraints.gridx = 4;
13091355 aWindowConstraints.gridwidth = 1;
13101356 // aConstraints.gridheight = 3;
13111357 aWindowConstraints.fill = GridBagConstraints.VERTICAL;
13121358 bigThree.add(XYZPanel, aWindowConstraints);
1359
+ /**/
13131360
1361
+ bigThree = new cGridBag();
1362
+ bigThree.addComponent(scenePanel);
1363
+ bigThree.addComponent(centralPanel);
1364
+ bigThree.addComponent(XYZPanel);
1365
+
13141366 // // SIDE EFFECT!!!
13151367 // aConstraints.gridx = 0;
13161368 // aConstraints.gridy = 0;
....@@ -1331,7 +1383,8 @@
13311383 //worldPane.add(bigPanel);
13321384 //worldPane.add(worldPanel);
13331385 /**/
1334
- frame.getContentPane().add(/*"Center",*/framePanel);
1386
+ //frame.getContentPane().add(/*"Center",*/framePanel);
1387
+ frame.add(/*"Center",*/framePanel);
13351388 //frame.getContentPane().add(/*"Center",*/ worldPane);
13361389
13371390 // aConstraints = gbc; // (GridBagConstraints) GrafreeD.clone(gbc);
....@@ -1352,6 +1405,10 @@
13521405 });
13531406 }
13541407
1408
+ void AddOptions(JPanel panel, GridBagConstraints constraints)
1409
+ {
1410
+ }
1411
+
13551412 JTree GetTree()
13561413 {
13571414 return objEditor.jTree;
....@@ -1422,7 +1479,7 @@
14221479 aConstraints.gridx += 1;
14231480 aConstraints.gridwidth = ObjEditor.GRIDWIDTH;
14241481 //aConstraints.weightx = 0;
1425
- ctrlPanel.add(colorField = new NumberSlider(0.001, 1, -0.1), aConstraints);
1482
+ ctrlPanel.add(colorField = new NumberSlider(0.001, 1, -0.5), aConstraints);
14261483 aConstraints.gridx = 0;
14271484 aConstraints.gridy += 1;
14281485 aConstraints.gridwidth = 1;
....@@ -1432,7 +1489,7 @@
14321489 aConstraints.fill = GridBagConstraints.HORIZONTAL;
14331490 aConstraints.gridx += 1;
14341491 aConstraints.gridwidth = ObjEditor.GRIDWIDTH;
1435
- ctrlPanel.add(modulationField = new NumberSlider(0.001, 1, -0.1), aConstraints);
1492
+ ctrlPanel.add(modulationField = new NumberSlider(0.001, 1, -0.5), aConstraints);
14361493 aConstraints.gridx = 0;
14371494 aConstraints.gridy += 1;
14381495 aConstraints.gridwidth = 1;
....@@ -1442,7 +1499,7 @@
14421499 aConstraints.fill = GridBagConstraints.HORIZONTAL;
14431500 aConstraints.gridx += 1;
14441501 aConstraints.gridwidth = ObjEditor.GRIDWIDTH;
1445
- ctrlPanel.add(textureField = new NumberSlider(0.001, 1, -0.1), aConstraints);
1502
+ ctrlPanel.add(textureField = new NumberSlider(0.001, 1, -0.5), aConstraints);
14461503 aConstraints.gridx = 0;
14471504 aConstraints.gridy += 1;
14481505 aConstraints.gridwidth = 1;
....@@ -1452,7 +1509,7 @@
14521509 aConstraints.fill = GridBagConstraints.HORIZONTAL;
14531510 aConstraints.gridx += 1;
14541511 aConstraints.gridwidth = ObjEditor.GRIDWIDTH;
1455
- ctrlPanel.add(anisoField = new NumberSlider(0.001, 1, -0.1), aConstraints);
1512
+ ctrlPanel.add(anisoField = new NumberSlider(0.001, 1, -0.5), aConstraints);
14561513 aConstraints.gridx = 0;
14571514 aConstraints.gridy += 1;
14581515 aConstraints.gridwidth = 1;
....@@ -1462,7 +1519,7 @@
14621519 aConstraints.fill = GridBagConstraints.HORIZONTAL;
14631520 aConstraints.gridx += 1;
14641521 aConstraints.gridwidth = ObjEditor.GRIDWIDTH;
1465
- ctrlPanel.add(anisoVField = new NumberSlider(0.001, 1, -0.1), aConstraints);
1522
+ ctrlPanel.add(anisoVField = new NumberSlider(0.001, 1, -0.5), aConstraints);
14661523 aConstraints.gridx = 0;
14671524 aConstraints.gridy += 1;
14681525 aConstraints.gridwidth = 1;
....@@ -1531,7 +1588,7 @@
15311588 aConstraints.fill = GridBagConstraints.HORIZONTAL;
15321589 aConstraints.gridx += 1;
15331590 aConstraints.gridwidth = ObjEditor.GRIDWIDTH;
1534
- ctrlPanel.add(subsurfaceField = new NumberSlider(0.001, 1, -0.1), aConstraints);
1591
+ ctrlPanel.add(subsurfaceField = new NumberSlider(0.001, 1, -0.5), aConstraints);
15351592 aConstraints.gridx = 0;
15361593 aConstraints.gridy += 1;
15371594 aConstraints.gridwidth = 1;
....@@ -1600,7 +1657,7 @@
16001657 aConstraints.fill = GridBagConstraints.HORIZONTAL;
16011658 aConstraints.gridx += 1;
16021659 aConstraints.gridwidth = ObjEditor.GRIDWIDTH;
1603
- ctrlPanel.add(metalnessField = new NumberSlider(0.001, 1, -0.1), aConstraints);
1660
+ ctrlPanel.add(metalnessField = new NumberSlider(0.001, 1, -0.5), aConstraints);
16041661 aConstraints.gridx = 0;
16051662 aConstraints.gridy += 1;
16061663 aConstraints.gridwidth = 1;
....@@ -1671,7 +1728,7 @@
16711728 aConstraints.fill = GridBagConstraints.HORIZONTAL;
16721729 aConstraints.gridx += 1;
16731730 aConstraints.gridwidth = ObjEditor.GRIDWIDTH;
1674
- ctrlPanel.add(opacityField = new NumberSlider(0.001, 1, -0.1), aConstraints);
1731
+ ctrlPanel.add(opacityField = new NumberSlider(0.001, 1, -0.5), aConstraints);
16751732 aConstraints.gridx = 0;
16761733 aConstraints.gridy += 1;
16771734 aConstraints.gridwidth = 1;
....@@ -2194,6 +2251,8 @@
21942251 {
21952252 Mocap sel = (Mocap) copy.selection.get(0);
21962253
2254
+ sel.SetCurrentBones(sel.frame);
2255
+
21972256 sel.fullname = fullname;
21982257
21992258 if (changename)
....@@ -2207,14 +2266,18 @@
22072266 sel.smoothed = false;
22082267
22092268 // if (!changename)
2210
- sel.SetPositionDelta(false, true, true, true/*?*/); // false
2269
+ //sel.SetPositionDelta(false, true, true, true/*?*/); // false
2270
+ sel.SetGlobalTransform();
2271
+ sel.LoadData();
2272
+ sel.Rewind();
2273
+ sel.Fade();
22112274 // sel.setPose(0);
22122275 refreshContents();
22132276 } else
22142277 {
22152278 mocap.Reset();
22162279 // new skeleton
2217
- makeSomething(mocap, false); // true);
2280
+ makeSomething(mocap, true); // true);
22182281 }
22192282 } catch (Exception e)
22202283 {
....@@ -2241,6 +2304,8 @@
22412304 {
22422305 Mocap sel = (Mocap) select;
22432306
2307
+ sel.SetCurrentBones(sel.frame);
2308
+
22442309 File file = new File(fullname);
22452310
22462311 // Mocap mocap = new Mocap("Mocap" + file.getName());
....@@ -2307,7 +2372,11 @@
23072372
23082373 if (!changename)
23092374 {
2310
- sel.SetPositionDelta(false, true, true, true/*?*/);
2375
+ //sel.SetPositionDelta(false, true, true, true/*?*/);
2376
+ sel.SetGlobalTransform();
2377
+ sel.LoadData();
2378
+ sel.Rewind();
2379
+ sel.Fade();
23112380 }
23122381
23132382 // sel.setPose(0);
....@@ -2946,20 +3015,37 @@
29463015 // june 2013 copy.HardTouch();
29473016 cameraView.repaint();
29483017 return;
2949
- } else if (event.getSource() == toggleFullItem)
3018
+ } else if (event.getSource() == toggleTimelineItem)
29503019 {
2951
- if (CameraPane.FULLSCREEN)
3020
+ timeline ^= true;
3021
+
3022
+ if (timeline)
29523023 {
2953
- frame.getContentPane().remove(/*"Center",*/bigThree);
2954
- framePanel.add(bigThree);
2955
- frame.getContentPane().add(/*"Center",*/framePanel);
2956
- } else
2957
- {
2958
- frame.getContentPane().remove(/*"Center",*/framePanel);
2959
- frame.getContentPane().add(/*"Center",*/bigThree);
3024
+ centralPanel.remove(cameraView);
3025
+ cameraPanel.add(cameraView);
3026
+ centralPanel.add(cameraPanel);
3027
+ frame.setJMenuBar(timelineMenubar);
3028
+ wasFullScreen = CameraPane.FULLSCREEN;
3029
+ if (!CameraPane.FULLSCREEN)
3030
+ ToggleFullScreen();
3031
+ toggleFullScreenItem.setEnabled(false);
29603032 }
3033
+ else
3034
+ {
3035
+ centralPanel.remove(cameraPanel);
3036
+ centralPanel.add(cameraView);
3037
+ frame.setJMenuBar(null);
3038
+ if (!wasFullScreen)
3039
+ ToggleFullScreen();
3040
+ toggleFullScreenItem.setEnabled(true);
3041
+ }
3042
+
29613043 frame.validate();
2962
- cameraView.ToggleFullScreen();
3044
+ return;
3045
+ } else if (event.getSource() == toggleFullScreenItem)
3046
+ {
3047
+ ToggleFullScreen();
3048
+ frame.validate();
29633049
29643050 return;
29653051 } else if (event.getSource() == toggleRandomItem)
....@@ -3069,7 +3155,8 @@
30693155 objEditor.refreshContents();
30703156 } else if (event.getSource() == stepItem)
30713157 {
3072
- cameraView.ONESTEP = true;
3158
+ //cameraView.ONESTEP = true;
3159
+ Globals.ONESTEP = true;
30733160 cameraView.repaint();
30743161 return;
30753162 } else if (event.getSource() == stepButton)
....@@ -3208,9 +3295,9 @@
32083295 cameraView.RevertCamera();
32093296 cameraView.repaint();
32103297 return;
3211
- } else if (event.getSource() == textureButton)
3212
- {
3213
- return; // true;
3298
+// } else if (event.getSource() == textureButton)
3299
+// {
3300
+// return; // true;
32143301 } else // combos...
32153302 if (event.getSource() == texresMenu)
32163303 {
....@@ -3226,25 +3313,25 @@
32263313
32273314 void ToggleAnimation()
32283315 {
3229
- if (!CameraPane.ANIMATION)
3316
+ if (!Globals.ANIMATION)
32303317 {
32313318 FileDialog browser = new FileDialog(frame, "Save Animation As...", FileDialog.SAVE);
32323319 browser.show();
32333320 String filename = browser.getFile();
32343321 if (filename != null && filename.length() > 0)
32353322 {
3236
- CameraPane.filename = browser.getDirectory() + filename;
3323
+ Globals.filename = browser.getDirectory() + filename;
32373324 //CameraPane.framecount = 0;
3238
- CameraPane.imagecount = 0;
3325
+ Globals.imagecount = 0;
32393326
3240
- CameraPane.ANIMATION ^= true;
3327
+ Globals.ANIMATION ^= true;
32413328
32423329 GrafreeD.wav.cursor = 0;
32433330 GrafreeD.wav.loop = 0;
32443331 }
32453332 } else
32463333 {
3247
- CameraPane.ANIMATION ^= true;
3334
+ Globals.ANIMATION ^= true;
32483335 }
32493336 }
32503337
....@@ -3497,7 +3584,13 @@
34973584 //System.out.println("PARENT = " + parent);
34983585 //if (parent != null)
34993586 // parent.applySelf();
3500
- refreshContents();
3587
+ if (e.getSource() == normalpushField)
3588
+ {
3589
+ objEditor.refreshContents();
3590
+ //Refresh();
3591
+ }
3592
+ else
3593
+ refreshContents();
35013594 // ??? client.refreshEditWindow();
35023595 }
35033596 //else
....@@ -3509,7 +3602,7 @@
35093602 //group.name = nameField.getText();
35103603 //objEditor.applySelf();
35113604
3512
- assert (objEditor == this);
3605
+ // OCT2018: assert (objEditor == this);
35133606 if (copy.selection == null || copy.selection.size() == 0)
35143607 //super.applySelf()
35153608 ; else
....@@ -3533,12 +3626,18 @@
35333626 objEditor.copy = keep;
35343627 }
35353628 }
3629
+
3630
+ if (normalpushField != null)
3631
+ copy.NORMALPUSH = (float)normalpushField.getFloat()/1000;
35363632 }
35373633
35383634 void SnapObject()
35393635 {
3540
- Object3D obj = (Object3D)copy.selection.elementAt(0);
3541
- SnapObject(obj);
3636
+ if (copy.selection.size() > 0)
3637
+ {
3638
+ Object3D obj = (Object3D)copy.selection.elementAt(0);
3639
+ SnapObject(obj);
3640
+ }
35423641 }
35433642
35443643 void SnapObject(Object3D obj)
....@@ -3652,7 +3751,7 @@
36523751
36533752 if (obj.parent != null)
36543753 {
3655
- obj.parent.TransformToWorld(interest);
3754
+// obj.parent.TransformToWorld(interest);
36563755 }
36573756
36583757 if (!CameraPane.TRACK)
....@@ -4432,7 +4531,8 @@
44324531 MenuItem revertCameraItem;
44334532 CheckboxMenuItem toggleLiveItem;
44344533 MenuItem stepItem;
4435
- CheckboxMenuItem toggleFullItem;
4534
+ CheckboxMenuItem toggleFullScreenItem;
4535
+ CheckboxMenuItem toggleTimelineItem;
44364536 CheckboxMenuItem toggleRenderItem;
44374537 CheckboxMenuItem toggleDebugItem;
44384538 CheckboxMenuItem toggleFrustumItem;
....@@ -4455,15 +4555,18 @@
44554555 JScrollPane infoPanel;
44564556 JPanel optionsPanel;
44574557 JTabbedPane objectPanel;
4458
- JPanel XYZPanel;
4558
+ cGridBag XYZPanel;
44594559 JSplitPane gridPanel;
44604560 JSplitPane bigPanel;
4461
- JPanel bigThree;
4462
- JTabbedPane jtp;
4463
- JPanel cameraPanel;
4561
+ cGridBag bigThree;
4562
+ JTabbedPane scenePanel;
4563
+ JPanel centralPanel;
4564
+ JSplitPane cameraPanel;
4565
+ JPanel timelinePanel;
4566
+ JMenuBar timelineMenubar;
44644567 JSplitPane framePanel;
44654568 JTextArea/*Field*/ nameField;
4466
- cButton textureButton;
4569
+ //cButton textureButton;
44674570 cButton okButton;
44684571 cButton applyButton;
44694572 cButton cancelButton;
....@@ -4571,4 +4674,6 @@
45714674 NumberSlider opacityPowerField;
45724675 JTree jTree;
45734676 //ObjectUI parent;
4677
+
4678
+ NumberSlider normalpushField;
45744679 }