From 8f1afe25ea8fc8801aab66331c32a50859a758c2 Mon Sep 17 00:00:00 2001
From: Normand Briere <nbriere@noware.ca>
Date: Mon, 12 Aug 2019 18:20:19 -0400
Subject: [PATCH] Fix version manager.

---
 ObjEditor.java |  139 +++++++++++++++++++++++++++++++++------------
 1 files changed, 101 insertions(+), 38 deletions(-)

diff --git a/ObjEditor.java b/ObjEditor.java
index 8e14d77..35727f1 100644
--- a/ObjEditor.java
+++ b/ObjEditor.java
@@ -297,11 +297,13 @@
         client = inClient;
         copy = client;
 
-        if (copy.versionlist == null)
-        {
-            copy.versionlist = new Object3D[100];
-            copy.versionindex = -1;
-        }
+//        if (copy.versionlist == null)
+//        {
+//            copy.versionlist = new Object3D[100];
+//            copy.versionindex = -1;
+//            
+//            callee.Save(true);
+//        }
         
         // "this" is not called: SetupUI2(objEditor);
     }
@@ -320,6 +322,8 @@
         {
             copy.versionlist = new Object3D[100];
             copy.versionindex = -1;
+            
+//            Save(true);
         }
         
         SetupUI2(callee.GetEditor());
@@ -354,11 +358,13 @@
         copy = localCopy;
         copy.editWindow = this;
 
-        if (copy.versionlist == null)
-        {
-//            copy.versions = new byte[100][];
+//        if (copy.versionlist == null)
+//        {
+//            copy.versionlist = new Object3D[100];
 //            copy.versionindex = -1;
-        }
+//            
+//            Save(true);
+//        }
         
         SetupMenu();
 
@@ -445,7 +451,7 @@
 //                        EditSelection(false);
 //                }
 
-                refreshContents(false); // To refresh Info tab
+//                refreshContents(false); // To refresh Info tab
             }
         };
         objectPanel.addChangeListener(changeListener);
@@ -754,6 +760,7 @@
         boolean maximized;
     
         cButton fullscreenLayout;
+        cButton expandedLayout;
 
         void Minimize()
         {
@@ -793,10 +800,12 @@
 	cButton minButton;
 	cButton maxButton;
 	cButton fullButton;
+	cButton collapseButton;
+        cButton maximize3DButton;
         
         void ToggleFullScreen()
         {
-GraphicsDevice device = frame.getGraphicsConfiguration().getDevice();
+            GraphicsDevice device = frame.getGraphicsConfiguration().getDevice();
 
                 cameraView.ToggleFullScreen();
                 
@@ -817,13 +826,13 @@
 // X                   frame.getContentPane().remove(/*"Center",*/bigThree);
 // X                   framePanel.add(bigThree);
 // X                   frame.getContentPane().add(/*"Center",*/framePanel);
-                    framePanel.setDividerLocation(46);
+//                    framePanel.setDividerLocation(46); // icons are 24x24
                     
                     //frame.setVisible(true);
-                    radio.layout = keepButton;
+//                    radio.layout = keepButton;
                     //theFrame = null;
                     keepButton = null;
-                    radio.layout.doClick();
+//                    radio.layout.doClick();
                     
                 } else
                 {
@@ -844,10 +853,10 @@
 // X                   frame.getContentPane().remove(/*"Center",*/framePanel);
 // X                   framePanel.remove(bigThree);
 // X                   frame.getContentPane().add(/*"Center",*/bigThree);
-                    framePanel.setDividerLocation(0);
+//                    framePanel.setDividerLocation(0);
 
-                    radio.layout = fullscreenLayout;
-                    radio.layout.doClick();
+//                    radio.layout = fullscreenLayout;
+//                    radio.layout.doClick();
                     //frame.setVisible(true);
                 }
             frame.validate();
@@ -855,23 +864,31 @@
             cameraView.requestFocusInWindow();
         }
 
-    private Object3D CompressCopy()
+        void CollapseToolbar()
+        {
+            framePanel.setDividerLocation(0);
+            //frame.validate();
+            
+            cameraView.requestFocusInWindow();
+        }
+        
+    private Object3D Duplicate(Object3D object)
     {
         boolean temp = CameraPane.SWITCH;
         CameraPane.SWITCH = false;
         
-        copy.ExtractBigData(versiontable);
+        object.ExtractBigData(versiontable);
         // if (copy == client)
         
-        Object3D versions[] = copy.versionlist;
-        copy.versionlist = null;
+        Object3D versions[] = object.versionlist;
+        object.versionlist = null;
         
         //byte[] compress = Compress(copy);
-        Object3D compress = (Object3D)Grafreed.clone(copy);
+        Object3D compress = (Object3D)Grafreed.clone(object);
         
-        copy.versionlist = versions;
+        object.versionlist = versions;
         
-        copy.RestoreBigData(versiontable);
+        object.RestoreBigData(versiontable);
         
         CameraPane.SWITCH = temp;
         
@@ -1702,6 +1719,23 @@
 //		aConstraints.gridheight = 1;
 
         framePanel = new JSplitPane(JSplitPane.VERTICAL_SPLIT, toolbarPanel, bigThree);
+        
+        framePanel.addPropertyChangeListener(JSplitPane.DIVIDER_LOCATION_PROPERTY,
+                new java.beans.PropertyChangeListener()
+                {
+                    public void propertyChange(java.beans.PropertyChangeEvent pce)
+                    {
+                        if ((Integer)pce.getOldValue() == 1)
+                        {
+                            if (radio.layout != expandedLayout)
+                            {
+                                radio.layout = expandedLayout;
+                                radio.layout.doClick();
+                            }
+                        }
+                    }
+                });
+
         framePanel.setContinuousLayout(false);
         framePanel.setOneTouchExpandable(false);
         //.setDividerLocation(0.8);
@@ -2120,6 +2154,25 @@
             }
         });
         presetpanel.add(candle);
+        
+        cLabel shadowShader = GetLabel("icons/shadericons/shadow.png", !Grafreed.NIMBUSLAF);
+        shadowShader.setToolTipText("Shadow");
+        shadowShader.addMouseListener(new MouseAdapter()
+        {
+            public void mouseClicked(MouseEvent e)
+            {
+                diffuseField.setFloat(0.001);
+                ambientField.setFloat(0.001);
+                cameraField.setFloat(0.001);
+                specularField.setFloat(0.001);
+                fakedepthField.setFloat(0.001);
+                opacityField.setFloat(0.6);
+
+                materialtouched = true;
+                applySelf();
+            }
+        });
+        presetpanel.add(shadowShader);
         
         cGridBag panel = new cGridBag().setVertical(true);
         
@@ -4112,11 +4165,11 @@
     public boolean Save(boolean user)
     {
         System.err.println("Save");
-        //Replace();
+        Replace();
         
-        cRadio tab = GetCurrentTab();
+        //cRadio tab = GetCurrentTab();
         
-        Object3D compress = CompressCopy(); // Saved version. No need for "Replace"?
+        Object3D compress = Duplicate(copy); // Saved version. No need for "Replace"?
         
         boolean thesame = false;
         
@@ -4210,7 +4263,7 @@
 
     void CopyChanged()
     {
-        Object3D obj = copy.versionlist[copy.versionindex];
+        Object3D obj = (Object3D)Grafreed.clone(copy.versionlist[copy.versionindex]);
         
         SetUndoStates();
         
@@ -4281,10 +4334,13 @@
     
     void SetUndoStates()
     {
-        cRadio tab = GetCurrentTab();
+        //if (true)
+        //    return;
+                    
+        //cRadio tab = GetCurrentTab();
         
-        restoreButton.setEnabled(true); // copy.versionindex != -1);
-        replaceButton.setEnabled(true); // copy.versionindex != -1);
+        restoreButton.setEnabled(copy.versionindex != -1);
+        replaceButton.setEnabled(copy.versionindex != -1);
         
         previousVersionButton.setEnabled(copy.versionindex > 0);
         nextVersionButton.setEnabled(copy.versionlist[copy.versionindex + 1] != null);
@@ -4293,8 +4349,10 @@
                                         copy.versionlist[copy.versionindex + 1] != null);
         
         muteSlider = true;
+        versionSlider.setMinimum(0);
         versionSlider.setMaximum(VersionCount() - 1);
         versionSlider.setInteger(copy.versionindex);
+        versionSlider.setEnabled(copy.versionindex != -1);
         muteSlider = false;
     }
     
@@ -4305,7 +4363,7 @@
         
         System.err.println("Undo");
         
-        cRadio tab = GetCurrentTab();
+        //cRadio tab = GetCurrentTab();
         
         if (copy.versionindex == 0)
         {
@@ -4337,7 +4395,7 @@
     {
         System.err.println("Restore");
         
-        cRadio tab = GetCurrentTab();
+        //cRadio tab = GetCurrentTab();
         
         if (copy.versionindex == -1 || copy.versionlist[copy.versionindex] == null)
         {
@@ -4355,7 +4413,7 @@
     {
         System.err.println("Replace");
         
-        cRadio tab = GetCurrentTab();
+        //cRadio tab = GetCurrentTab();
         
         if (copy.versionindex == -1 || copy.versionlist[copy.versionindex] == null)
         {
@@ -4363,7 +4421,7 @@
             return false;
         }
 
-        copy.versionlist[copy.versionindex] = CompressCopy();
+        copy.versionlist[copy.versionindex] = Duplicate(copy);
         
         return true;
     }
@@ -4373,7 +4431,7 @@
         // Option?
         Replace();
         
-        cRadio tab = GetCurrentTab();
+        //cRadio tab = GetCurrentTab();
         
         if (copy.versionlist[copy.versionindex + 1] == null)
         {
@@ -4694,7 +4752,7 @@
             
             int version = versionSlider.getInteger();
             
-            if (copy.versionlist[version] != null)
+            if (version != -1 && copy.versionlist[version] != null)
             {
                 copy.versionindex = version;
                 CopyChanged();
@@ -4738,7 +4796,7 @@
             //System.out.println("stateChanged = " + this);
             materialtouched = true;
             
-            if (e.getSource() == colorField && saturationField.getFloat() == 0.001)
+            if (Globals.AUTOSATURATE && e.getSource() == colorField && saturationField.getFloat() == 0.001)
             {
                 saturationField.setFloat(1);
             }
@@ -5442,8 +5500,11 @@
             
         if (copy.versionlist == null)
         {
+            // Backward compatibility
             copy.versionlist = new Object3D[100];
             copy.versionindex = -1;
+            
+            Save(true);
         }
         
             //? SetUndoStates();
@@ -5882,6 +5943,7 @@
     cNumberSlider anisoField;
     JLabel anisoVLabel;
     cNumberSlider anisoVField;
+    
     JLabel cameraLabel;
     cNumberSlider cameraField;
     JLabel selfshadowLabel;
@@ -5896,6 +5958,7 @@
     cNumberSlider fakedepthField;
     JLabel shadowbiasLabel;
     cNumberSlider shadowbiasField;
+    
     JLabel bumpLabel;
     cNumberSlider bumpField;
     JLabel noiseLabel;

--
Gitblit v1.6.2