.. | .. |
---|
31 | 31 | boolean timeline; |
---|
32 | 32 | boolean wasFullScreen; |
---|
33 | 33 | |
---|
| 34 | + GroupEditor callee; |
---|
| 35 | + JFrame frame; |
---|
| 36 | + |
---|
34 | 37 | // SCRIPT |
---|
35 | 38 | |
---|
36 | 39 | transient JFrame textpanel = null; |
---|
.. | .. |
---|
121 | 124 | void keyPressed(int key, int modifiers) |
---|
122 | 125 | { |
---|
123 | 126 | System.out.println("KEY PRESSED"); |
---|
124 | | - CameraPane.theRenderer.keyPressed(key, modifiers); |
---|
| 127 | + Globals.theRenderer.keyPressed(key, modifiers); |
---|
125 | 128 | } |
---|
126 | 129 | */ |
---|
127 | 130 | |
---|
128 | 131 | static GridBagConstraints aConstraints; |
---|
129 | 132 | static GridBagConstraints aWindowConstraints; |
---|
130 | | - GroupEditor callee; |
---|
131 | | - JFrame frame; |
---|
| 133 | + |
---|
132 | 134 | static int GRIDWIDTH = 100; // 4; |
---|
133 | 135 | |
---|
134 | 136 | public void closeUI() |
---|
.. | .. |
---|
160 | 162 | objEditor.ctrlPanel.remove(slowerButton); |
---|
161 | 163 | objEditor.ctrlPanel.remove(fasterButton); |
---|
162 | 164 | objEditor.ctrlPanel.remove(remarkButton); |
---|
| 165 | + |
---|
| 166 | + Remove(normalpushField); |
---|
163 | 167 | } |
---|
164 | 168 | |
---|
165 | 169 | public ObjEditor GetEditor() |
---|
166 | 170 | { |
---|
167 | 171 | return objEditor; //.GetEditor(); |
---|
168 | 172 | } |
---|
| 173 | + |
---|
| 174 | + // Sometimes myself, sometimes my callee's. |
---|
169 | 175 | ObjEditor objEditor; |
---|
170 | 176 | |
---|
171 | 177 | /* |
---|
.. | .. |
---|
305 | 311 | toggleTextureItem.setState(CameraPane.textureon); |
---|
306 | 312 | cameraMenu.add(toggleLiveItem = new CheckboxMenuItem("Live")); |
---|
307 | 313 | toggleLiveItem.addItemListener(this); |
---|
308 | | - toggleLiveItem.setState(CameraPane.isLIVE()); |
---|
| 314 | + toggleLiveItem.setState(Globals.isLIVE()); |
---|
309 | 315 | cameraMenu.add(stepItem = new MenuItem("Step")); |
---|
310 | 316 | stepItem.addActionListener(this); |
---|
311 | 317 | // cameraMenu.add(toggleDLItem = new CheckboxMenuItem("Display List")); |
---|
.. | .. |
---|
814 | 820 | |
---|
815 | 821 | aConstraints.fill = GridBagConstraints.VERTICAL; |
---|
816 | 822 | jlabel.setHorizontalAlignment(SwingConstants.TRAILING); |
---|
817 | | - aConstraints.gridwidth = 2; |
---|
| 823 | + aConstraints.gridwidth = 1; |
---|
818 | 824 | ctrlPanel.add(jlabel, aConstraints); //, oe.ctrlPanel.getComponentCount()-1); |
---|
819 | 825 | aConstraints.gridx += 1; |
---|
820 | 826 | aConstraints.fill = GridBagConstraints.HORIZONTAL; |
---|
.. | .. |
---|
983 | 989 | |
---|
984 | 990 | Return(); |
---|
985 | 991 | |
---|
| 992 | + normalpushField = AddSlider(oe.ctrlPanel, "Push", -10, 10, 0, -1); |
---|
| 993 | + Return(); |
---|
| 994 | + |
---|
986 | 995 | // oe.ctrlPanel.add(stepButton = new cButton("Step"), ObjEditor.aConstraints, oe.ctrlPanel.getComponentCount() - 2); |
---|
987 | 996 | // ObjEditor.aConstraints.gridx += 1; |
---|
988 | 997 | |
---|
.. | .. |
---|
1182 | 1191 | timelinePanel = new JPanel(new BorderLayout()); |
---|
1183 | 1192 | timelineMenubar = new timeflow.app.TimeflowApp().TimeFlowWindow(timelinePanel); |
---|
1184 | 1193 | |
---|
| 1194 | + cameraPanel = new JSplitPane(JSplitPane.VERTICAL_SPLIT, cameraView, timelinePanel); |
---|
| 1195 | + cameraPanel.setContinuousLayout(true); |
---|
| 1196 | + cameraPanel.setOneTouchExpandable(true); |
---|
| 1197 | +// cameraPanel.setDividerLocation(0.9); |
---|
| 1198 | +// cameraPanel.setDividerSize(9); |
---|
| 1199 | + cameraPanel.setResizeWeight(1.0); |
---|
| 1200 | + |
---|
1185 | 1201 | centralPanel.add(cameraView); |
---|
1186 | 1202 | //frame.setJMenuBar(timelineMenubar); |
---|
1187 | 1203 | //centralPanel.add(timelinePanel); |
---|
.. | .. |
---|
1355 | 1371 | //worldPane.add(bigPanel); |
---|
1356 | 1372 | //worldPane.add(worldPanel); |
---|
1357 | 1373 | /**/ |
---|
1358 | | - frame.getContentPane().add(/*"Center",*/framePanel); |
---|
| 1374 | + //frame.getContentPane().add(/*"Center",*/framePanel); |
---|
| 1375 | + frame.add(/*"Center",*/framePanel); |
---|
1359 | 1376 | //frame.getContentPane().add(/*"Center",*/ worldPane); |
---|
1360 | 1377 | |
---|
1361 | 1378 | // aConstraints = gbc; // (GridBagConstraints) GrafreeD.clone(gbc); |
---|
.. | .. |
---|
1446 | 1463 | aConstraints.gridx += 1; |
---|
1447 | 1464 | aConstraints.gridwidth = ObjEditor.GRIDWIDTH; |
---|
1448 | 1465 | //aConstraints.weightx = 0; |
---|
1449 | | - ctrlPanel.add(colorField = new NumberSlider(0.001, 1, -0.1), aConstraints); |
---|
| 1466 | + ctrlPanel.add(colorField = new NumberSlider(0.001, 1, -0.5), aConstraints); |
---|
1450 | 1467 | aConstraints.gridx = 0; |
---|
1451 | 1468 | aConstraints.gridy += 1; |
---|
1452 | 1469 | aConstraints.gridwidth = 1; |
---|
.. | .. |
---|
1456 | 1473 | aConstraints.fill = GridBagConstraints.HORIZONTAL; |
---|
1457 | 1474 | aConstraints.gridx += 1; |
---|
1458 | 1475 | aConstraints.gridwidth = ObjEditor.GRIDWIDTH; |
---|
1459 | | - ctrlPanel.add(modulationField = new NumberSlider(0.001, 1, -0.1), aConstraints); |
---|
| 1476 | + ctrlPanel.add(modulationField = new NumberSlider(0.001, 1, -0.5), aConstraints); |
---|
1460 | 1477 | aConstraints.gridx = 0; |
---|
1461 | 1478 | aConstraints.gridy += 1; |
---|
1462 | 1479 | aConstraints.gridwidth = 1; |
---|
.. | .. |
---|
1466 | 1483 | aConstraints.fill = GridBagConstraints.HORIZONTAL; |
---|
1467 | 1484 | aConstraints.gridx += 1; |
---|
1468 | 1485 | aConstraints.gridwidth = ObjEditor.GRIDWIDTH; |
---|
1469 | | - ctrlPanel.add(textureField = new NumberSlider(0.001, 1, -0.1), aConstraints); |
---|
| 1486 | + ctrlPanel.add(textureField = new NumberSlider(0.001, 1, -0.5), aConstraints); |
---|
1470 | 1487 | aConstraints.gridx = 0; |
---|
1471 | 1488 | aConstraints.gridy += 1; |
---|
1472 | 1489 | aConstraints.gridwidth = 1; |
---|
.. | .. |
---|
1476 | 1493 | aConstraints.fill = GridBagConstraints.HORIZONTAL; |
---|
1477 | 1494 | aConstraints.gridx += 1; |
---|
1478 | 1495 | aConstraints.gridwidth = ObjEditor.GRIDWIDTH; |
---|
1479 | | - ctrlPanel.add(anisoField = new NumberSlider(0.001, 1, -0.1), aConstraints); |
---|
| 1496 | + ctrlPanel.add(anisoField = new NumberSlider(0.001, 1, -0.5), aConstraints); |
---|
1480 | 1497 | aConstraints.gridx = 0; |
---|
1481 | 1498 | aConstraints.gridy += 1; |
---|
1482 | 1499 | aConstraints.gridwidth = 1; |
---|
.. | .. |
---|
1486 | 1503 | aConstraints.fill = GridBagConstraints.HORIZONTAL; |
---|
1487 | 1504 | aConstraints.gridx += 1; |
---|
1488 | 1505 | aConstraints.gridwidth = ObjEditor.GRIDWIDTH; |
---|
1489 | | - ctrlPanel.add(anisoVField = new NumberSlider(0.001, 1, -0.1), aConstraints); |
---|
| 1506 | + ctrlPanel.add(anisoVField = new NumberSlider(0.001, 1, -0.5), aConstraints); |
---|
1490 | 1507 | aConstraints.gridx = 0; |
---|
1491 | 1508 | aConstraints.gridy += 1; |
---|
1492 | 1509 | aConstraints.gridwidth = 1; |
---|
.. | .. |
---|
1555 | 1572 | aConstraints.fill = GridBagConstraints.HORIZONTAL; |
---|
1556 | 1573 | aConstraints.gridx += 1; |
---|
1557 | 1574 | aConstraints.gridwidth = ObjEditor.GRIDWIDTH; |
---|
1558 | | - ctrlPanel.add(subsurfaceField = new NumberSlider(0.001, 1, -0.1), aConstraints); |
---|
| 1575 | + ctrlPanel.add(subsurfaceField = new NumberSlider(0.001, 1, -0.5), aConstraints); |
---|
1559 | 1576 | aConstraints.gridx = 0; |
---|
1560 | 1577 | aConstraints.gridy += 1; |
---|
1561 | 1578 | aConstraints.gridwidth = 1; |
---|
.. | .. |
---|
1624 | 1641 | aConstraints.fill = GridBagConstraints.HORIZONTAL; |
---|
1625 | 1642 | aConstraints.gridx += 1; |
---|
1626 | 1643 | aConstraints.gridwidth = ObjEditor.GRIDWIDTH; |
---|
1627 | | - ctrlPanel.add(metalnessField = new NumberSlider(0.001, 1, -0.1), aConstraints); |
---|
| 1644 | + ctrlPanel.add(metalnessField = new NumberSlider(0.001, 1, -0.5), aConstraints); |
---|
1628 | 1645 | aConstraints.gridx = 0; |
---|
1629 | 1646 | aConstraints.gridy += 1; |
---|
1630 | 1647 | aConstraints.gridwidth = 1; |
---|
.. | .. |
---|
1695 | 1712 | aConstraints.fill = GridBagConstraints.HORIZONTAL; |
---|
1696 | 1713 | aConstraints.gridx += 1; |
---|
1697 | 1714 | aConstraints.gridwidth = ObjEditor.GRIDWIDTH; |
---|
1698 | | - ctrlPanel.add(opacityField = new NumberSlider(0.001, 1, -0.1), aConstraints); |
---|
| 1715 | + ctrlPanel.add(opacityField = new NumberSlider(0.001, 1, -0.5), aConstraints); |
---|
1699 | 1716 | aConstraints.gridx = 0; |
---|
1700 | 1717 | aConstraints.gridy += 1; |
---|
1701 | 1718 | aConstraints.gridwidth = 1; |
---|
.. | .. |
---|
2989 | 3006 | if (timeline) |
---|
2990 | 3007 | { |
---|
2991 | 3008 | centralPanel.remove(cameraView); |
---|
2992 | | - centralPanel.add(timelinePanel); |
---|
| 3009 | + cameraPanel.add(cameraView); |
---|
| 3010 | + centralPanel.add(cameraPanel); |
---|
2993 | 3011 | frame.setJMenuBar(timelineMenubar); |
---|
2994 | 3012 | wasFullScreen = CameraPane.FULLSCREEN; |
---|
2995 | 3013 | if (!CameraPane.FULLSCREEN) |
---|
.. | .. |
---|
2998 | 3016 | } |
---|
2999 | 3017 | else |
---|
3000 | 3018 | { |
---|
3001 | | - centralPanel.remove(timelinePanel); |
---|
| 3019 | + centralPanel.remove(cameraPanel); |
---|
3002 | 3020 | centralPanel.add(cameraView); |
---|
3003 | 3021 | frame.setJMenuBar(null); |
---|
3004 | 3022 | if (!wasFullScreen) |
---|
.. | .. |
---|
3121 | 3139 | objEditor.refreshContents(); |
---|
3122 | 3140 | } else if (event.getSource() == stepItem) |
---|
3123 | 3141 | { |
---|
3124 | | - cameraView.ONESTEP = true; |
---|
| 3142 | + //cameraView.ONESTEP = true; |
---|
| 3143 | + Globals.ONESTEP = true; |
---|
3125 | 3144 | cameraView.repaint(); |
---|
3126 | 3145 | return; |
---|
3127 | 3146 | } else if (event.getSource() == stepButton) |
---|
.. | .. |
---|
3278 | 3297 | |
---|
3279 | 3298 | void ToggleAnimation() |
---|
3280 | 3299 | { |
---|
3281 | | - if (!CameraPane.ANIMATION) |
---|
| 3300 | + if (!Globals.ANIMATION) |
---|
3282 | 3301 | { |
---|
3283 | 3302 | FileDialog browser = new FileDialog(frame, "Save Animation As...", FileDialog.SAVE); |
---|
3284 | 3303 | browser.show(); |
---|
3285 | 3304 | String filename = browser.getFile(); |
---|
3286 | 3305 | if (filename != null && filename.length() > 0) |
---|
3287 | 3306 | { |
---|
3288 | | - CameraPane.filename = browser.getDirectory() + filename; |
---|
| 3307 | + Globals.filename = browser.getDirectory() + filename; |
---|
3289 | 3308 | //CameraPane.framecount = 0; |
---|
3290 | | - CameraPane.imagecount = 0; |
---|
| 3309 | + Globals.imagecount = 0; |
---|
3291 | 3310 | |
---|
3292 | | - CameraPane.ANIMATION ^= true; |
---|
| 3311 | + Globals.ANIMATION ^= true; |
---|
3293 | 3312 | |
---|
3294 | 3313 | GrafreeD.wav.cursor = 0; |
---|
3295 | 3314 | GrafreeD.wav.loop = 0; |
---|
3296 | 3315 | } |
---|
3297 | 3316 | } else |
---|
3298 | 3317 | { |
---|
3299 | | - CameraPane.ANIMATION ^= true; |
---|
| 3318 | + Globals.ANIMATION ^= true; |
---|
3300 | 3319 | } |
---|
3301 | 3320 | } |
---|
3302 | 3321 | |
---|
.. | .. |
---|
3549 | 3568 | //System.out.println("PARENT = " + parent); |
---|
3550 | 3569 | //if (parent != null) |
---|
3551 | 3570 | // parent.applySelf(); |
---|
3552 | | - refreshContents(); |
---|
| 3571 | + if (e.getSource() == normalpushField) |
---|
| 3572 | + { |
---|
| 3573 | + objEditor.refreshContents(); |
---|
| 3574 | + //Refresh(); |
---|
| 3575 | + } |
---|
| 3576 | + else |
---|
| 3577 | + refreshContents(); |
---|
3553 | 3578 | // ??? client.refreshEditWindow(); |
---|
3554 | 3579 | } |
---|
3555 | 3580 | //else |
---|
.. | .. |
---|
3561 | 3586 | //group.name = nameField.getText(); |
---|
3562 | 3587 | //objEditor.applySelf(); |
---|
3563 | 3588 | |
---|
3564 | | - assert (objEditor == this); |
---|
| 3589 | + // OCT2018: assert (objEditor == this); |
---|
3565 | 3590 | if (copy.selection == null || copy.selection.size() == 0) |
---|
3566 | 3591 | //super.applySelf() |
---|
3567 | 3592 | ; else |
---|
.. | .. |
---|
3585 | 3610 | objEditor.copy = keep; |
---|
3586 | 3611 | } |
---|
3587 | 3612 | } |
---|
| 3613 | + |
---|
| 3614 | + if (normalpushField != null) |
---|
| 3615 | + copy.NORMALPUSH = (float)normalpushField.getFloat()/1000; |
---|
3588 | 3616 | } |
---|
3589 | 3617 | |
---|
3590 | 3618 | void SnapObject() |
---|
.. | .. |
---|
4517 | 4545 | JPanel bigThree; |
---|
4518 | 4546 | JTabbedPane scenePanel; |
---|
4519 | 4547 | JPanel centralPanel; |
---|
| 4548 | + JSplitPane cameraPanel; |
---|
4520 | 4549 | JPanel timelinePanel; |
---|
4521 | 4550 | JMenuBar timelineMenubar; |
---|
4522 | 4551 | JSplitPane framePanel; |
---|
.. | .. |
---|
4629 | 4658 | NumberSlider opacityPowerField; |
---|
4630 | 4659 | JTree jTree; |
---|
4631 | 4660 | //ObjectUI parent; |
---|
| 4661 | + |
---|
| 4662 | + NumberSlider normalpushField; |
---|
4632 | 4663 | } |
---|