No need for minorSpacing
[jalview.git] / src / jalview / gui / AlignFrame.java
index b714aea..ccf7303 100755 (executable)
@@ -263,7 +263,7 @@ public class AlignFrame
             java.io.File.separatorChar) + 1);\r
       }\r
 \r
-      Jalview2XML.SaveAlignment(this, file, shortName);\r
+      new Jalview2XML().SaveAlignment(this, file, shortName);\r
 \r
       // USE Jalview2XML to save this file\r
       return true;\r
@@ -360,6 +360,27 @@ public class AlignFrame
     thread.start();\r
   }\r
 \r
+  public void associatedData_actionPerformed(ActionEvent e)\r
+  {\r
+    // Pick the tree file\r
+    JalviewFileChooser chooser = new JalviewFileChooser(jalview.bin.Cache.\r
+        getProperty(\r
+            "LAST_DIRECTORY"));\r
+    chooser.setFileView(new JalviewFileView());\r
+    chooser.setDialogTitle("Load Jalview Annotations or Features File");\r
+    chooser.setToolTipText("Load Jalview Annotations / Features file");\r
+\r
+    int value = chooser.showOpenDialog(null);\r
+\r
+    if (value == JalviewFileChooser.APPROVE_OPTION)\r
+    {\r
+      String choice = chooser.getSelectedFile().getPath();\r
+      jalview.bin.Cache.setProperty("LAST_DIRECTORY", choice);\r
+      loadJalviewDataFile(choice);\r
+    }\r
+\r
+  }\r
+\r
   /**\r
    * DOCUMENT ME!\r
    *\r
@@ -450,42 +471,8 @@ public class AlignFrame
   // used by undo and redo\r
   void restoreHistoryItem(HistoryItem hi)\r
   {\r
-    if (hi.getType() == HistoryItem.SORT)\r
-    {\r
-      for (int i = 0; i < hi.getSequences().size(); i++)\r
-      {\r
-        viewport.alignment.getSequences().setElementAt(hi.getSequences()\r
-            .elementAt(i),\r
-            i);\r
-      }\r
-    }\r
-    else\r
-    {\r
-      for (int i = 0; i < hi.getSequences().size(); i++)\r
-      {\r
-        SequenceI restore = (SequenceI) hi.getSequences().elementAt(i);\r
 \r
-        if (restore.getLength() == 0)\r
-        {\r
-          restore.setSequence(hi.getHidden().elementAt(i).toString());\r
-          viewport.alignment.getSequences().insertElementAt(restore,\r
-              hi.getAlignIndex(i));\r
-        }\r
-        else\r
-        {\r
-          restore.setSequence(hi.getHidden().elementAt(i).toString());\r
-        }\r
-      }\r
-\r
-      if (hi.getType() == HistoryItem.PASTE)\r
-      {\r
-        for (int i = viewport.alignment.getHeight() - 1;\r
-             i > (hi.getSequences().size() - 1); i--)\r
-        {\r
-          viewport.alignment.deleteSequence(i);\r
-        }\r
-      }\r
-    }\r
+    hi.restore();\r
 \r
     updateEditMenuBar();\r
 \r
@@ -719,6 +706,10 @@ public class AlignFrame
         AlignFrame af = new AlignFrame(alignment);\r
         String newtitle = new String("Copied sequences");\r
 \r
+        //>>>This is a fix for the moment, until a better solution is found!!<<<\r
+        FeatureRenderer fr = af.alignPanel.seqPanel.seqCanvas.getFeatureRenderer();\r
+        fr.featureColours = alignPanel.seqPanel.seqCanvas.getFeatureRenderer().featureColours;\r
+\r
         if (title.startsWith("Copied sequences"))\r
         {\r
           newtitle = title;\r
@@ -921,6 +912,11 @@ public class AlignFrame
    */\r
   public void deselectAllSequenceMenuItem_actionPerformed(ActionEvent e)\r
   {\r
+    if(viewport.cursorMode)\r
+    {\r
+      alignPanel.seqPanel.keyboardNo1 = null;\r
+      alignPanel.seqPanel.keyboardNo2 = null;\r
+    }\r
     viewport.setSelectionGroup(null);\r
     viewport.getColumnSelection().clear();\r
     viewport.setSelectionGroup(null);\r
@@ -1143,7 +1139,10 @@ public class AlignFrame
 \r
  public void alignmentChanged()\r
  {\r
-   if(viewport.vconsensus!=null)\r
+   if(viewport.padGaps)\r
+     viewport.getAlignment().padGaps();\r
+\r
+   if(viewport.vconsensus!=null && viewport.autoCalculateConsensus)\r
    {\r
      viewport.updateConsensus();\r
      viewport.updateConservation();\r
@@ -1205,8 +1204,11 @@ public class AlignFrame
   {\r
     addHistoryItem(new HistoryItem("Pad Gaps", viewport.alignment,\r
                                    HistoryItem.HIDE));\r
-    if (viewport.getAlignment().padGaps())\r
-      alignmentChanged();\r
+\r
+    viewport.padGaps = padGapsMenuitem.isSelected();\r
+\r
+   // if (viewport.padGaps)\r
+    alignmentChanged();\r
   }\r
 \r
   /**\r
@@ -1937,6 +1939,13 @@ public class AlignFrame
      new PCAPanel(viewport);\r
   }\r
 \r
+\r
+  public void autoCalculate_actionPerformed(ActionEvent e)\r
+  {\r
+    viewport.autoCalculateConsensus = autoCalculate.isSelected();\r
+  }\r
+\r
+\r
   /**\r
    * DOCUMENT ME!\r
    *\r
@@ -1986,7 +1995,7 @@ public class AlignFrame
    */\r
   void NewTreePanel(String type, String pwType, String title)\r
   {\r
-    final TreePanel tp;\r
+    TreePanel tp;\r
 \r
     if ( (viewport.getSelectionGroup() != null) &&\r
         (viewport.getSelectionGroup().getSize() > 3))\r
@@ -2038,7 +2047,6 @@ public class AlignFrame
     }\r
 \r
     addTreeMenuItem(tp, title);\r
-    viewport.setCurrentTree(tp.getTree());\r
 \r
     Desktop.addInternalFrame(tp, title + " from " + this.title, 600, 500);\r
   }\r
@@ -2575,11 +2583,12 @@ public void showTranslation_actionPerformed(ActionEvent e)
  */\r
 public boolean parseGroupsFile(String file)\r
 {\r
+    String line = null;\r
     try\r
     {\r
       BufferedReader in = new BufferedReader(new FileReader(file));\r
       SequenceI seq = null;\r
-      String line, type, desc, token;\r
+      String type, desc, token;\r
 \r
       int index, start, end;\r
       StringTokenizer st;\r
@@ -2641,8 +2650,7 @@ public boolean parseGroupsFile(String file)
             alignPanel.seqPanel.seqCanvas.getFeatureRenderer().setColour(type, ucs.findColour("A"));\r
           }\r
 \r
-          sf = new SequenceFeature(type, desc, "", start, end);\r
-          sf.setFeatureGroup(featureGroup);\r
+          sf = new SequenceFeature(type, desc, "", start, end, featureGroup);\r
 \r
           seq.getDatasetSequence().addSequenceFeature(sf);\r
         }\r
@@ -2650,8 +2658,9 @@ public boolean parseGroupsFile(String file)
     }\r
     catch (Exception ex)\r
     {\r
+      System.out.println(line);\r
       ex.printStackTrace();\r
-      System.out.println("Error parsing groups file: " + ex);\r
+      System.out.println("Error parsing groups file: " + ex +"\n"+line);\r
       return false;\r
     }\r
 \r
@@ -2715,57 +2724,68 @@ public void drop(DropTargetDropEvent evt)
     {\r
       e.printStackTrace();\r
     }\r
-\r
     if (files != null)\r
     {\r
       try\r
       {\r
-        boolean isAnnotation = false;\r
 \r
         for (int i = 0; i < files.size(); i++)\r
         {\r
-          String file = files.get(i).toString();\r
-\r
-          isAnnotation = new AnnotationReader().readAnnotationFile(viewport.alignment, file);\r
-\r
-          if( !isAnnotation )\r
-          {\r
-            boolean isGroupsFile = parseGroupsFile(file);\r
-            if (!isGroupsFile)\r
-            {\r
-              String protocol = "File";\r
-              String format = new IdentifyFile().Identify(file, protocol);\r
-              SequenceI[] sequences = new FormatAdapter().readFile(file, protocol, format);\r
-\r
-              FastaFile ff = new FastaFile();\r
-              Clipboard c = Toolkit.getDefaultToolkit().getSystemClipboard();\r
-              c.setContents(new StringSelection(ff.print(sequences)), this);\r
-\r
-              this.paste(false);\r
-\r
-            }\r
-          }\r
+          loadJalviewDataFile(files.get(i).toString());\r
         }\r
+      }\r
+      catch (Exception ex)\r
+      {\r
+        ex.printStackTrace();\r
+      }\r
+    }\r
+}\r
 \r
-        if(isAnnotation)\r
+  // This method will attempt to load a "dropped" file first by testing\r
+  // whether its and Annotation file, then features file. If both are\r
+  // false then the user may have dropped an alignment file onto this\r
+  // AlignFrame\r
+   public void loadJalviewDataFile(String file)\r
+  {\r
+    try{\r
+      boolean isAnnotation = new AnnotationReader().readAnnotationFile(viewport.\r
+          alignment, file);\r
+\r
+      if (!isAnnotation)\r
+      {\r
+        boolean isGroupsFile = parseGroupsFile(file);\r
+        if (!isGroupsFile)\r
         {\r
-          int height = alignPanel.annotationPanel.adjustPanelHeight();\r
-          alignPanel.annotationScroller.setPreferredSize(\r
-              new Dimension(alignPanel.annotationScroller.getWidth(),\r
-                            height));\r
+          String protocol = "File";\r
+          String format = new IdentifyFile().Identify(file, protocol);\r
+          SequenceI[] sequences = new FormatAdapter().readFile(file, protocol,\r
+              format);\r
 \r
-          alignPanel.annotationSpaceFillerHolder.setPreferredSize(new Dimension(\r
-              alignPanel.annotationSpaceFillerHolder.getWidth(),\r
-              height));\r
+          FastaFile ff = new FastaFile();\r
+          Clipboard c = Toolkit.getDefaultToolkit().getSystemClipboard();\r
+          c.setContents(new StringSelection(ff.print(sequences)), this);\r
 \r
-          alignPanel.addNotify();\r
+          this.paste(false);\r
         }\r
       }\r
-      catch (Exception ex)\r
+\r
+      if (isAnnotation)\r
       {\r
-        ex.printStackTrace();\r
+        int height = alignPanel.annotationPanel.adjustPanelHeight();\r
+        alignPanel.annotationScroller.setPreferredSize(\r
+            new Dimension(alignPanel.annotationScroller.getWidth(),\r
+                          height));\r
+\r
+        alignPanel.annotationSpaceFillerHolder.setPreferredSize(new Dimension(\r
+            alignPanel.annotationSpaceFillerHolder.getWidth(),\r
+            height));\r
+\r
+        alignPanel.addNotify();\r
       }\r
-    }\r
-}\r
 \r
+    }catch(Exception ex)\r
+    {\r
+      ex.printStackTrace();\r
+    }\r
+  }\r
 }\r