for now, draw selection box bottom -1
[jalview.git] / src / jalview / gui / AlignFrame.java
index 079f315..1324173 100755 (executable)
@@ -32,7 +32,6 @@ public class AlignFrame extends GAlignFrame
   final AlignViewport viewport;\r
   public AlignFrame(AlignmentI al)\r
   {\r
-    super();\r
     viewport = new AlignViewport(al,true,true,false);\r
 \r
     String fontName = jalview.bin.Cache.getProperty("FONT_NAME");\r
@@ -42,10 +41,18 @@ public class AlignFrame extends GAlignFrame
       viewport.setFont( new Font(fontName,Integer.parseInt(fontStyle),Integer.parseInt(fontSize)) );\r
 \r
 \r
-\r
     alignPanel = new AlignmentPanel(this, viewport);\r
     getContentPane().add(alignPanel, java.awt.BorderLayout.CENTER);\r
 \r
+    // add conservation graph to alignment\r
+    viewport.updateConservation();\r
+    viewport.updateConsensus();\r
+\r
+    alignPanel.annotationPanel.adjustPanelHeight();\r
+    alignPanel.annotationSpaceFillerHolder.setPreferredSize(alignPanel.annotationPanel.getPreferredSize());\r
+    alignPanel.annotationScroller.setPreferredSize(alignPanel.annotationPanel.getPreferredSize());\r
+\r
+\r
     addInternalFrameListener(new InternalFrameAdapter()\r
    {\r
      public void internalFrameActivated(InternalFrameEvent evt)\r
@@ -63,22 +70,29 @@ public class AlignFrame extends GAlignFrame
 \r
   protected void saveAs_actionPerformed(ActionEvent e)\r
   {\r
-    String suffix = "";\r
+    String suffix [] = null;\r
     if(e.getActionCommand().equals("FASTA"))\r
-      suffix = "fa";\r
+      suffix = new String[]{"fa", "fasta"};\r
     else if(e.getActionCommand().equals("MSF"))\r
-      suffix = "msf";\r
+      suffix = new String[]{"msf"};\r
     else if(e.getActionCommand().equals("CLUSTAL"))\r
-      suffix = "aln";\r
+      suffix = new String[]{"aln"};\r
     else if(e.getActionCommand().equals("BLC"))\r
-      suffix = "blc";\r
+      suffix = new String[]{"blc"};\r
     else if(e.getActionCommand().equals("PIR"))\r
-      suffix = "pir";\r
+      suffix = new String[]{"pir"};\r
     else if(e.getActionCommand().equals("PFAM"))\r
-      suffix = "pfam";\r
+      suffix = new String[]{"pfam"};\r
+\r
+    if(e.getActionCommand().equals("XML DUMP"))\r
+    {\r
+      XMLStore store = new XMLStore();\r
+      store.store(viewport);\r
+      return;\r
+    }\r
 \r
     JalviewFileChooser chooser = new JalviewFileChooser(jalview.bin.Cache.getProperty("LAST_DIRECTORY")\r
-        , new String[]{suffix}, e.getActionCommand()+" file");\r
+        , suffix, e.getActionCommand()+" file");\r
     chooser.setFileView(new JalviewFileView());\r
     chooser.setDialogTitle("Save Alignment to file - "+e.getActionCommand() +" format.");\r
     chooser.setToolTipText("Save");\r
@@ -116,31 +130,12 @@ public class AlignFrame extends GAlignFrame
 \r
   protected void createPNG_actionPerformed(ActionEvent e)\r
   {\r
-    int height = (viewport.alignment.getWidth() / viewport.getChunkWidth() +1) * viewport.chunkHeight;\r
-    int width = alignPanel.seqPanel.getWidth() + alignPanel.idPanel.getWidth();\r
-\r
-    if(!viewport.getWrapAlignment())\r
-    {\r
-      height = viewport.alignment.getHeight() * viewport.charHeight;\r
-      width = alignPanel.idPanel.getWidth() + viewport.alignment.getWidth() * viewport.charWidth;\r
-    }\r
-\r
-    alignPanel.makePNG( width, height);\r
+    alignPanel.makePNG();\r
   }\r
 \r
   protected void epsFile_actionPerformed(ActionEvent e)\r
   {\r
-    int height = (viewport.alignment.getWidth() / viewport.getChunkWidth() +1) * viewport.chunkHeight;\r
-    int width = alignPanel.seqPanel.getWidth() + alignPanel.idPanel.getWidth();\r
-\r
-    if(!viewport.getWrapAlignment())\r
-    {\r
-      height = viewport.alignment.getHeight() * viewport.charHeight;\r
-      width = alignPanel.idPanel.getWidth() + viewport.alignment.getWidth() * viewport.charWidth;\r
-    }\r
-\r
-    alignPanel.makeEPS( width, height);\r
-\r
+    alignPanel.makeEPS();\r
   }\r
 \r
 \r
@@ -185,6 +180,7 @@ public class AlignFrame extends GAlignFrame
 \r
   Stack historyList = new Stack();\r
   Stack redoList = new Stack();\r
+  JMenuBar jMenuBar1 = new JMenuBar();\r
 \r
   void updateEditMenuBar()\r
   {\r
@@ -246,6 +242,8 @@ public class AlignFrame extends GAlignFrame
       seq = (SequenceI[]) history[1];\r
       viewport.setAlignment( new Alignment(seq) );\r
       updateEditMenuBar();\r
+      viewport.updateConsensus();\r
+      alignPanel.RefreshPanels();\r
       alignPanel.RefreshPanels();\r
   }\r
 \r
@@ -358,12 +356,14 @@ public class AlignFrame extends GAlignFrame
         int newHeight = newSeqs.length * af.viewport.getCharHeight() + 200;\r
         if (newHeight > 500)\r
           newHeight = 500;\r
-        Desktop.addInternalFrame(af, "Copied sequences", 700, newHeight);\r
+        Desktop.addInternalFrame(af, "Copied sequences", 700, 500);\r
       }\r
       else\r
       {\r
         viewport.setEndSeq(viewport.alignment.getHeight());\r
         viewport.alignment.getWidth();\r
+        viewport.updateConservation();\r
+        viewport.updateConsensus();\r
         alignPanel.RefreshPanels();\r
       }\r
 \r
@@ -405,6 +405,8 @@ public class AlignFrame extends GAlignFrame
      {\r
        this.setClosed(true);\r
      }catch(Exception ex){}\r
+   viewport.updateConservation();\r
+   viewport.updateConsensus();\r
      alignPanel.RefreshPanels();\r
 \r
   }\r
@@ -417,6 +419,8 @@ public class AlignFrame extends GAlignFrame
      SequenceI[] seq = (SequenceI[]) history[1];\r
      viewport.setAlignment( new Alignment(seq) );\r
      updateEditMenuBar();\r
+     viewport.updateConsensus();\r
+     alignPanel.RefreshPanels();\r
      alignPanel.RefreshPanels();\r
   }\r
 \r
@@ -481,6 +485,18 @@ public class AlignFrame extends GAlignFrame
       int min = colSel.getMin();\r
       viewport.getAlignment().trimLeft(min);\r
       colSel.compensateForEdit(0,min);\r
+\r
+      if(viewport.getSelectionGroup()!=null)\r
+        viewport.getSelectionGroup().adjustForRemoveLeft(min);\r
+\r
+      Vector groups = viewport.alignment.getGroups();\r
+      for(int i=0; i<groups.size(); i++)\r
+      {\r
+        SequenceGroup sg = (SequenceGroup) groups.get(i);\r
+        if(!sg.adjustForRemoveLeft(min))\r
+          viewport.alignment.deleteGroup(sg);\r
+      }\r
+\r
       alignPanel.RefreshPanels();\r
     }\r
   }\r
@@ -492,8 +508,19 @@ public class AlignFrame extends GAlignFrame
     if (colSel.size() > 0)\r
     {\r
       int max = colSel.getMax();\r
-      if(max>1)\r
-        viewport.getAlignment().trimRight(max);\r
+      viewport.getAlignment().trimRight(max);\r
+      if(viewport.getSelectionGroup()!=null)\r
+        viewport.getSelectionGroup().adjustForRemoveRight(max);\r
+\r
+      Vector groups = viewport.alignment.getGroups();\r
+      for(int i=0; i<groups.size(); i++)\r
+      {\r
+        SequenceGroup sg = (SequenceGroup) groups.get(i);\r
+        if(!sg.adjustForRemoveRight(max))\r
+          viewport.alignment.deleteGroup(sg);\r
+      }\r
+\r
+\r
 \r
       alignPanel.RefreshPanels();\r
     }\r
@@ -504,6 +531,8 @@ public class AlignFrame extends GAlignFrame
   {\r
     addHistoryItem("delete gapped columns");\r
     viewport.getAlignment().removeGaps();\r
+    viewport.updateConservation();\r
+    viewport.updateConsensus();\r
     alignPanel.RefreshPanels();\r
   }\r
 \r
@@ -524,7 +553,8 @@ public class AlignFrame extends GAlignFrame
           jSize--;\r
         }\r
     }\r
-\r
+    viewport.updateConservation();\r
+    viewport.updateConsensus();\r
     alignPanel.RefreshPanels();\r
   }\r
 \r
@@ -554,7 +584,6 @@ public class AlignFrame extends GAlignFrame
 \r
   public void font_actionPerformed(ActionEvent e)\r
   {\r
-   // JOptionPane op = new JOptionPane();\r
     JInternalFrame frame = new JInternalFrame();\r
     FontChooser fc = new FontChooser( alignPanel, frame );\r
     frame.setContentPane(fc);\r
@@ -612,9 +641,15 @@ public class AlignFrame extends GAlignFrame
     alignPanel.RefreshPanels();\r
   }\r
 \r
-  public void consensusGraphMenuItem_actionPerformed(ActionEvent e)\r
+  public void annotationPanelMenuItem_actionPerformed(ActionEvent e)\r
   {\r
-    alignPanel.setGraphPanelVisible( consensusGraphMenuItem.isSelected() );\r
+    if(annotationPanelMenuItem.isSelected() && viewport.getWrapAlignment())\r
+    {\r
+      annotationPanelMenuItem.setSelected(false);\r
+      return;\r
+    }\r
+    viewport.setShowAnnotation( annotationPanelMenuItem.isSelected() );\r
+    alignPanel.setAnnotationVisible( annotationPanelMenuItem.isSelected() );\r
   }\r
 \r
   public void overviewMenuItem_actionPerformed(ActionEvent e)\r
@@ -798,6 +833,10 @@ if ( viewport.getConservationSelected() )
   protected  void conservationMenuItem_actionPerformed(ActionEvent e)\r
   {\r
     viewport.setConservationSelected(conservationMenuItem.isSelected());\r
+    if(coloursChanging)\r
+      return;\r
+\r
+    coloursChanging = true;\r
 \r
     viewport.setAbovePIDThreshold(false);\r
     abovePIDThreshold.setSelected(false);\r
@@ -810,11 +849,17 @@ if ( viewport.getConservationSelected() )
      changeColour( ((ConservationColourScheme)cs).cs );\r
     else\r
       changeColour( cs );\r
-  }\r
 \r
+    coloursChanging = false;\r
+  }\r
 \r
+  boolean coloursChanging = false;\r
   public void abovePIDThreshold_actionPerformed(ActionEvent e)\r
   {\r
+    if(coloursChanging)\r
+      return;\r
+\r
+    coloursChanging = true;\r
     viewport.setAbovePIDThreshold(abovePIDThreshold.isSelected());\r
 \r
     conservationMenuItem.setSelected(false);\r
@@ -831,6 +876,7 @@ if ( viewport.getConservationSelected() )
     else\r
         changeColour( cs );\r
 \r
+    coloursChanging = false;\r
   }\r
 \r
 \r
@@ -1094,4 +1140,90 @@ if ( viewport.getConservationSelected() )
          g.drawString("Clustal Alignment Web Service running", 30,30);\r
        }\r
   }\r
+  protected void jpred_actionPerformed(ActionEvent e)\r
+{\r
+\r
+    JInternalFrame frame = new JInternalFrame();\r
+    if (viewport.getSelectionGroup() != null && viewport.getSelectionGroup().getSize()>0)\r
+    {\r
+      // JBPNote UGLY! To prettify, make SequenceGroup and Alignment conform to some common interface!\r
+      SequenceGroup seqs = viewport.getSelectionGroup();\r
+      if (seqs.getSize() == 1 || !viewport.alignment.isAligned())\r
+      {\r
+        JPredClient ct = new JPredClient( (SequenceI)\r
+                                         seqs.getSequenceAt(0));\r
+      }\r
+      else\r
+      {\r
+        int sz;\r
+        SequenceI[] msa = new SequenceI[sz=seqs.getSize()];\r
+        for (int i = 0; i < sz; i++)\r
+        {\r
+          msa[i] = (SequenceI) seqs.getSequenceAt(i);\r
+        }\r
+\r
+        JPredClient ct = new JPredClient(msa);\r
+      }\r
+\r
+    }\r
+    else\r
+    {\r
+      Vector seqs = viewport.getAlignment().getSequences();\r
+\r
+      if (seqs.size() == 1 || !viewport.alignment.isAligned())\r
+      {\r
+        JPredClient ct = new JPredClient( (SequenceI)\r
+                                         seqs.elementAt(0));\r
+      }\r
+      else\r
+      {\r
+        SequenceI[] msa = new SequenceI[seqs.size()];\r
+        for (int i = 0; i < seqs.size(); i++)\r
+        {\r
+          msa[i] = (SequenceI) seqs.elementAt(i);\r
+        }\r
+\r
+        JPredClient ct = new JPredClient(msa);\r
+      }\r
+\r
+    }\r
+  }\r
+\r
+    protected void LoadtreeMenuItem_actionPerformed(ActionEvent e) {\r
+    // Pick the tree file\r
+    JalviewFileChooser chooser = new JalviewFileChooser(jalview.bin.Cache.\r
+        getProperty("LAST_DIRECTORY"));\r
+    chooser.setFileView(new JalviewFileView());\r
+    chooser.setDialogTitle("Select a newick-like tree file");\r
+    chooser.setToolTipText("Load a tree file");\r
+    int value = chooser.showOpenDialog(null);\r
+    if (value == JalviewFileChooser.APPROVE_OPTION)\r
+    {\r
+      String choice = chooser.getSelectedFile().getPath();\r
+      jalview.bin.Cache.setProperty("LAST_DIRECTORY", choice);\r
+      TreePanel treepanel = null;\r
+      try\r
+      {\r
+        jalview.io.NewickFile fin = new jalview.io.NewickFile(choice, "File");\r
+        fin.parse();\r
+\r
+        if (fin.getTree() != null)\r
+        {\r
+          TreePanel tp = null;\r
+          tp = new TreePanel(viewport, viewport.getAlignment().getSequences(),\r
+                             fin, "FromFile", choice);\r
+          Desktop.addInternalFrame(tp, title, 600, 500);\r
+        }\r
+      }\r
+      catch (Exception ex)\r
+      {\r
+        JOptionPane.showMessageDialog(Desktop.desktop,\r
+                                      "Problem reading tree file",\r
+                                      ex.getMessage(),\r
+                                      JOptionPane.WARNING_MESSAGE);\r
+        ex.printStackTrace();\r
+      }\r
+    }\r
+  }\r
+\r
 }\r