.. | .. |
---|
15 | 15 | //import javax.swing.plaf.ColorUIResource; |
---|
16 | 16 | //import javax.swing.plaf.metal.DefaultMetalTheme; |
---|
17 | 17 | |
---|
| 18 | +import javax.swing.plaf.basic.BasicSplitPaneDivider; |
---|
| 19 | +import javax.swing.plaf.basic.BasicSplitPaneUI; |
---|
| 20 | + |
---|
18 | 21 | //import javax.media.opengl.GLCanvas; |
---|
19 | 22 | |
---|
20 | 23 | import //weka.core. |
---|
.. | .. |
---|
207 | 210 | |
---|
208 | 211 | objEditor.ctrlPanel.remove(namePanel); |
---|
209 | 212 | |
---|
210 | | - if (!GroupEditor.allparams) |
---|
| 213 | + if (!allparams) |
---|
211 | 214 | return; |
---|
212 | 215 | |
---|
213 | 216 | // objEditor.ctrlPanel.remove(liveCB); |
---|
.. | .. |
---|
337 | 340 | return frame.action(event, obj); |
---|
338 | 341 | } |
---|
339 | 342 | |
---|
| 343 | + // Cannot work without static |
---|
| 344 | + static boolean allparams = true; |
---|
| 345 | + |
---|
| 346 | + static java.util.Vector<Object3D> listUI = new java.util.Vector<Object3D>(); |
---|
| 347 | + |
---|
340 | 348 | void SetupMenu() |
---|
341 | 349 | { |
---|
342 | 350 | frame.setMenuBar(menuBar = new MenuBar()); |
---|
.. | .. |
---|
398 | 406 | // |
---|
399 | 407 | // materialFlushed = true; |
---|
400 | 408 | // } |
---|
| 409 | +// if (objectPanel.getSelectedIndex() == objectPanel.indexOfTab("Edit")) |
---|
| 410 | +// { |
---|
| 411 | +// if (listUI.size() == 0) |
---|
| 412 | +// EditSelection(false); |
---|
| 413 | +// } |
---|
401 | 414 | |
---|
402 | 415 | refreshContents(false); // To refresh Info tab |
---|
403 | 416 | } |
---|
.. | .. |
---|
448 | 461 | mainPanel.setDividerSize(9); |
---|
449 | 462 | mainPanel.setDividerLocation(0.5); //1.0); |
---|
450 | 463 | mainPanel.setResizeWeight(0.5); |
---|
451 | | - |
---|
| 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 | + mainPanel.setUI(new BasicSplitPaneUI()); |
---|
| 471 | + |
---|
452 | 472 | //ctrlPanel.setLayout(new GridLayout(4, 1, 5, 5)); |
---|
453 | 473 | //mainPanel.setLayout(new GridBagLayout()); |
---|
454 | 474 | toolbarPanel.setLayout(new FlowLayout(FlowLayout.LEFT)); |
---|
.. | .. |
---|
723 | 743 | |
---|
724 | 744 | void ToggleFullScreen() |
---|
725 | 745 | { |
---|
726 | | - if (CameraPane.FULLSCREEN) |
---|
| 746 | + cameraView.ToggleFullScreen(); |
---|
| 747 | + |
---|
| 748 | + if (!CameraPane.FULLSCREEN) |
---|
727 | 749 | { |
---|
728 | 750 | device.setFullScreenWindow(null); |
---|
729 | 751 | //frame.setVisible(false); |
---|
.. | .. |
---|
763 | 785 | radio.layout.doClick(); |
---|
764 | 786 | //frame.setVisible(true); |
---|
765 | 787 | } |
---|
766 | | - |
---|
767 | | - cameraView.ToggleFullScreen(); |
---|
768 | 788 | } |
---|
769 | 789 | |
---|
770 | 790 | private JTextPane createTextPane() |
---|
.. | .. |
---|
1102 | 1122 | |
---|
1103 | 1123 | oe.ctrlPanel.Return(); |
---|
1104 | 1124 | |
---|
1105 | | - if (!GroupEditor.allparams) |
---|
| 1125 | + if (!allparams) |
---|
1106 | 1126 | return; |
---|
1107 | 1127 | |
---|
1108 | 1128 | setupPanel = new cGridBag().setVertical(false); |
---|
.. | .. |
---|
1115 | 1135 | hideCB = AddCheckBox(setupPanel, "Hide", copy.hide); |
---|
1116 | 1136 | hideCB.setToolTipText("Hide object"); |
---|
1117 | 1137 | markCB = AddCheckBox(setupPanel, "Mark", copy.marked); |
---|
1118 | | - markCB.setToolTipText("Set the animation target transform"); |
---|
| 1138 | + markCB.setToolTipText("As animation target transform"); |
---|
1119 | 1139 | |
---|
1120 | 1140 | setupPanel2 = new cGridBag().setVertical(false); |
---|
1121 | 1141 | |
---|
.. | .. |
---|
1123 | 1143 | rewindCB.setToolTipText("Rewind animation"); |
---|
1124 | 1144 | |
---|
1125 | 1145 | randomCB = AddCheckBox(setupPanel2, "Rand", copy.random); |
---|
1126 | | - randomCB.setToolTipText("Randomly Rewind or Go back and forth"); |
---|
| 1146 | + randomCB.setToolTipText("Randomly Rewind (or Go back and forth)"); |
---|
1127 | 1147 | |
---|
1128 | 1148 | if (Globals.ADVANCED) |
---|
1129 | 1149 | { |
---|
.. | .. |
---|
1439 | 1459 | //JScrollPane tmp = new JScrollPane(ctrlPanel, ScrollPaneConstants.VERTICAL_SCROLLBAR_AS_NEEDED, ScrollPaneConstants.HORIZONTAL_SCROLLBAR_NEVER); |
---|
1440 | 1460 | //tmp.setName("Edit"); |
---|
1441 | 1461 | objectPanel.add(materialPanel); |
---|
1442 | | - objectPanel.add(toolboxPanel); |
---|
1443 | 1462 | // JPanel north = new JPanel(new BorderLayout()); |
---|
1444 | 1463 | // north.setName("Edit"); |
---|
1445 | 1464 | // north.add(ctrlPanel, BorderLayout.NORTH); |
---|
1446 | 1465 | // objectPanel.add(north); |
---|
1447 | 1466 | objectPanel.add(editPanel); |
---|
1448 | 1467 | objectPanel.add(infoPanel); |
---|
| 1468 | + objectPanel.add(toolboxPanel); |
---|
1449 | 1469 | |
---|
1450 | 1470 | /* |
---|
1451 | 1471 | aConstraints.gridx = 0; |
---|
.. | .. |
---|
1454 | 1474 | aConstraints.gridy += 1; |
---|
1455 | 1475 | aConstraints.gridwidth = 1; |
---|
1456 | 1476 | mainPanel.add(objectPanel, aConstraints); |
---|
1457 | | - */ |
---|
| 1477 | + */ |
---|
1458 | 1478 | |
---|
1459 | 1479 | scrollpane = new JScrollPane(mainPanel, ScrollPaneConstants.// VERTICAL_SCROLLBAR_ALWAYS, |
---|
1460 | 1480 | VERTICAL_SCROLLBAR_AS_NEEDED, |
---|
.. | .. |
---|
3007 | 3027 | // } |
---|
3008 | 3028 | |
---|
3009 | 3029 | /**/ |
---|
3010 | | - if (deselect) |
---|
| 3030 | + if (deselect || child == null) |
---|
3011 | 3031 | { |
---|
3012 | 3032 | //group.deselectAll(); |
---|
3013 | 3033 | //freeze = true; |
---|
3014 | 3034 | GetTree().clearSelection(); |
---|
3015 | 3035 | //freeze = false; |
---|
| 3036 | + |
---|
| 3037 | + if (child == null) |
---|
| 3038 | + { |
---|
| 3039 | + return; |
---|
| 3040 | + } |
---|
3016 | 3041 | } |
---|
3017 | 3042 | |
---|
3018 | 3043 | //group.addSelectee(child); |
---|
.. | .. |
---|
3527 | 3552 | tab.graphs[i] = null; |
---|
3528 | 3553 | } |
---|
3529 | 3554 | |
---|
| 3555 | + SetUndoStates(); |
---|
| 3556 | + |
---|
3530 | 3557 | // test save |
---|
3531 | 3558 | if (false) |
---|
3532 | 3559 | { |
---|
.. | .. |
---|
3549 | 3576 | |
---|
3550 | 3577 | void CopyChanged(Object3D obj) |
---|
3551 | 3578 | { |
---|
| 3579 | + SetUndoStates(); |
---|
| 3580 | + |
---|
3552 | 3581 | boolean temp = CameraPane.SWITCH; |
---|
3553 | 3582 | CameraPane.SWITCH = false; |
---|
3554 | 3583 | |
---|
.. | .. |
---|
3586 | 3615 | } |
---|
3587 | 3616 | |
---|
3588 | 3617 | refreshContents(); |
---|
| 3618 | + } |
---|
| 3619 | + |
---|
| 3620 | + cButton undoButton; |
---|
| 3621 | + cButton redoButton; |
---|
| 3622 | + |
---|
| 3623 | + void SetUndoStates() |
---|
| 3624 | + { |
---|
| 3625 | + cRadio tab = GetCurrentTab(); |
---|
| 3626 | + |
---|
| 3627 | + undoButton.setEnabled(tab.undoindex > 0); |
---|
| 3628 | + redoButton.setEnabled(tab.graphs[tab.undoindex + 1] != null); |
---|
3589 | 3629 | } |
---|
3590 | 3630 | |
---|
3591 | 3631 | public void Undo() |
---|
.. | .. |
---|
4765 | 4805 | String filename = browser.getFile(); |
---|
4766 | 4806 | if (filename != null && filename.length() > 0) |
---|
4767 | 4807 | { |
---|
| 4808 | + if (!filename.endsWith(".gfd")) |
---|
| 4809 | + filename += ".gfd"; |
---|
4768 | 4810 | lastname = browser.getDirectory() + filename; |
---|
4769 | 4811 | save(); |
---|
4770 | 4812 | } |
---|