consistent percentage gaps filter for conservation calculation.
[jalview.git] / src / jalview / gui / AlignFrame.java
index 7071d81..c1a7105 100755 (executable)
@@ -23,16 +23,24 @@ import java.awt.print.*;
 import javax.swing.*;\r
 import javax.swing.event.*;\r
 import java.util.*;\r
-import  java.awt.datatransfer.*;\r
+import java.awt.datatransfer.*;\r
 \r
 \r
 public class AlignFrame extends GAlignFrame\r
 {\r
   final AlignmentPanel alignPanel;\r
   final AlignViewport viewport;\r
+  public static final int NEW_WINDOW_WIDTH = 700;\r
+  public static final int NEW_WINDOW_HEIGHT = 500;\r
+\r
   public AlignFrame(AlignmentI al)\r
   {\r
-    super();\r
+    try{\r
+      String ip = java.net.InetAddress.getLocalHost().getHostAddress();\r
+      if( !ip.startsWith("10."))\r
+        alignMenu.setVisible(false);\r
+    }\r
+    catch(java.net.UnknownHostException e){}\r
     viewport = new AlignViewport(al,true,true,false);\r
 \r
     String fontName = jalview.bin.Cache.getProperty("FONT_NAME");\r
@@ -41,10 +49,20 @@ public class AlignFrame extends GAlignFrame
     if(fontName!=null && fontStyle!=null && fontSize!=null)\r
       viewport.setFont( new Font(fontName,Integer.parseInt(fontStyle),Integer.parseInt(fontSize)) );\r
 \r
+    // add conservation graph to alignment\r
+    viewport.updateConservation();\r
+    viewport.updateConsensus();\r
+\r
 \r
     alignPanel = new AlignmentPanel(this, viewport);\r
+\r
+    alignPanel.annotationPanel.adjustPanelHeight();\r
+    alignPanel.annotationSpaceFillerHolder.setPreferredSize(alignPanel.annotationPanel.getPreferredSize());\r
+    alignPanel.annotationScroller.setPreferredSize(alignPanel.annotationPanel.getPreferredSize());\r
+\r
     getContentPane().add(alignPanel, java.awt.BorderLayout.CENTER);\r
 \r
+\r
     addInternalFrameListener(new InternalFrameAdapter()\r
    {\r
      public void internalFrameActivated(InternalFrameEvent evt)\r
@@ -76,6 +94,7 @@ public class AlignFrame extends GAlignFrame
     else if(e.getActionCommand().equals("PFAM"))\r
       suffix = new String[]{"pfam"};\r
 \r
+\r
     JalviewFileChooser chooser = new JalviewFileChooser(jalview.bin.Cache.getProperty("LAST_DIRECTORY")\r
         , suffix, e.getActionCommand()+" file");\r
     chooser.setFileView(new JalviewFileView());\r
@@ -227,6 +246,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
@@ -336,15 +357,14 @@ public class AlignFrame extends GAlignFrame
         SequenceI[] newSeqs = new SequenceI[seqs.size()];\r
         seqs.toArray(newSeqs);\r
         AlignFrame af = new AlignFrame(new Alignment(newSeqs));\r
-        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", NEW_WINDOW_WIDTH, NEW_WINDOW_HEIGHT);\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
@@ -386,6 +406,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
@@ -398,19 +420,12 @@ 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
 \r
-  public void groupsMenuItem_actionPerformed(ActionEvent e)\r
-  {\r
-    GroupEditor geditor = new GroupEditor(viewport, alignPanel);\r
-    JInternalFrame frame = new JInternalFrame();\r
-    frame.setContentPane(geditor);\r
-    Desktop.addInternalFrame(frame, "Group editor", 710, 410);\r
-    frame.setResizable(false);\r
-  }\r
-\r
   protected void deleteGroups_actionPerformed(ActionEvent e)\r
   {\r
     viewport.alignment.deleteAllGroups();\r
@@ -462,6 +477,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
@@ -473,8 +500,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
@@ -485,6 +523,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
@@ -505,7 +545,8 @@ public class AlignFrame extends GAlignFrame
           jSize--;\r
         }\r
     }\r
-\r
+    viewport.updateConservation();\r
+    viewport.updateConsensus();\r
     alignPanel.RefreshPanels();\r
   }\r
 \r
@@ -525,17 +566,17 @@ public class AlignFrame extends GAlignFrame
 \r
   public void findMenuItem_actionPerformed(ActionEvent e)\r
   {\r
-      JInternalFrame frame = new JInternalFrame();\r
-      Finder finder = new Finder(viewport, alignPanel, frame);\r
-      frame.setContentPane(finder);\r
-     Desktop.addInternalFrame(frame, "Find", 340,110);\r
+    JInternalFrame frame = new JInternalFrame();\r
+    Finder finder = new Finder(viewport, alignPanel, frame);\r
+    frame.setContentPane(finder);\r
+    Desktop.addInternalFrame(frame, "Find", 340,110, false);\r
+    frame.setLayer(JLayeredPane.PALETTE_LAYER);\r
 \r
   }\r
 \r
 \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
@@ -560,8 +601,31 @@ public class AlignFrame extends GAlignFrame
   {\r
     viewport.setWrapAlignment( wrapMenuItem.isSelected() );\r
     alignPanel.setWrapAlignment( wrapMenuItem.isSelected() );\r
+    scaleAbove.setVisible( wrapMenuItem.isSelected() );\r
+    scaleLeft.setVisible( wrapMenuItem.isSelected() );\r
+    scaleRight.setVisible( wrapMenuItem.isSelected() );\r
+    alignPanel.RefreshPanels();\r
+  }\r
+\r
+  protected void scaleAbove_actionPerformed(ActionEvent e)\r
+  {\r
+    viewport.setScaleAboveWrapped(scaleAbove.isSelected());\r
+    alignPanel.repaint();\r
   }\r
 \r
+  protected void scaleLeft_actionPerformed(ActionEvent e)\r
+  {\r
+    viewport.setScaleLeftWrapped(scaleLeft.isSelected());\r
+    alignPanel.repaint();\r
+  }\r
+\r
+  protected void scaleRight_actionPerformed(ActionEvent e)\r
+  {\r
+    viewport.setScaleRightWrapped(scaleRight.isSelected());\r
+    alignPanel.repaint();\r
+  }\r
+\r
+\r
 \r
   public void viewBoxesMenuItem_actionPerformed(ActionEvent e)\r
   {\r
@@ -593,9 +657,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
@@ -713,7 +783,7 @@ public class AlignFrame extends GAlignFrame
                                             sg.sequences, sg.getStartRes(),\r
                                             sg.getEndRes());\r
           c.calculate();\r
-          c.verdict(false, 100);\r
+          c.verdict(false, viewport.ConsPercGaps);\r
           ConservationColourScheme ccs = new ConservationColourScheme(c, sg.cs);\r
 \r
           sg.cs = ccs;\r
@@ -723,16 +793,16 @@ public class AlignFrame extends GAlignFrame
     }\r
 \r
 \r
-    if ( viewport.getAbovePIDThreshold())\r
+    if ( viewport.getAbovePIDThreshold() )\r
     {\r
-      int threshold = 0;\r
-      threshold = Desktop.setPIDSliderSource(alignPanel, cs, "Background");\r
+ //     int threshold = 0;\r
+   //   threshold = Desktop.setPIDSliderSource(alignPanel, cs, "Background");\r
       Desktop.hideConservationSlider();\r
 \r
-      if (cs instanceof ResidueColourScheme)\r
-        ( (ResidueColourScheme) cs).setThreshold(threshold);\r
-      else if (cs instanceof ScoreColourScheme)\r
-        ( (ScoreColourScheme) cs).setThreshold(threshold);\r
+ //     if (cs instanceof ResidueColourScheme)\r
+ //       ( (ResidueColourScheme) cs).setThreshold(threshold);\r
+  //    else if (cs instanceof ScoreColourScheme)\r
+   //     ( (ScoreColourScheme) cs).setThreshold(threshold);\r
 \r
       viewport.setGlobalColourScheme(cs);\r
 \r
@@ -757,14 +827,13 @@ if ( viewport.getConservationSelected() )
                                      al.getWidth());\r
 \r
    c.calculate();\r
-   c.verdict(false, 100);\r
+   c.verdict(false, viewport.ConsPercGaps);\r
 \r
    ccs = new ConservationColourScheme(c, cs);\r
 \r
-   int threshold = Desktop.setConservationSliderSource(alignPanel, ccs,\r
-       "Background");\r
+ //  int threshold = Desktop.setConservationSliderSource(alignPanel, ccs,    "Background");\r
 \r
-   ccs.inc = threshold;\r
+ //  ccs.inc = threshold;\r
 \r
    viewport.setGlobalColourScheme(ccs);\r
 \r
@@ -775,6 +844,16 @@ if ( viewport.getConservationSelected() )
     alignPanel.RefreshPanels();\r
   }\r
 \r
+  protected void modifyPID_actionPerformed(ActionEvent e)\r
+  {\r
+    Desktop.setPIDSliderSource(alignPanel, viewport.getGlobalColourScheme(), "Background");\r
+  }\r
+\r
+  protected void modifyConservation_actionPerformed(ActionEvent e)\r
+  {\r
+    Desktop.setConservationSliderSource(alignPanel, viewport.globalColourScheme,    "Background");\r
+  }\r
+\r
 \r
   protected  void conservationMenuItem_actionPerformed(ActionEvent e)\r
   {\r
@@ -832,10 +911,7 @@ if ( viewport.getConservationSelected() )
     JInternalFrame frame = new JInternalFrame();\r
     UserDefinedColours chooser = new UserDefinedColours( frame, alignPanel, null);\r
     frame.setContentPane(chooser);\r
-    Desktop.addInternalFrame(frame,"User defined colours", 450,540 );\r
-    frame.setResizable(false);\r
-    frame.setIconifiable(false);\r
-    frame.setMaximizable(false);\r
+    Desktop.addInternalFrame(frame,"User defined colours", 450,540, false );\r
   }\r
 \r
   public void PIDColour_actionPerformed(ActionEvent e)\r
@@ -873,24 +949,12 @@ if ( viewport.getConservationSelected() )
     alignPanel.RefreshPanels();\r
   }\r
 \r
-  public void sortTreeOrderMenuItem_actionPerformed(ActionEvent e)\r
-  {\r
-    addHistoryItem("sort");\r
-    if(viewport.getCurrentTree()==null)\r
-      return;\r
-\r
-    AlignmentSorter.sortByTree(viewport.getAlignment(), viewport.getCurrentTree());\r
-    alignPanel.RefreshPanels();\r
-  }\r
-\r
   public void removeRedundancyMenuItem_actionPerformed(ActionEvent e)\r
   {\r
     RedundancyPanel sp = new RedundancyPanel(alignPanel);\r
     JInternalFrame frame = new JInternalFrame();\r
     frame.setContentPane(sp);\r
-    Desktop.addInternalFrame(frame, "Redundancy threshold selection", 400, 100);\r
-    frame.setMaximizable(false);\r
-    frame.setResizable(false);\r
+    Desktop.addInternalFrame(frame, "Redundancy threshold selection", 400, 100, false);\r
 \r
   }\r
 \r
@@ -964,22 +1028,48 @@ if ( viewport.getConservationSelected() )
       return;\r
     }\r
 \r
-    TreePanel tp=null;\r
-   if (viewport.getSelectionGroup() != null && viewport.getSelectionGroup().getSize() > 3)\r
-   {\r
-     tp = new TreePanel(viewport, viewport.getSelectionGroup().sequences,type, pwType,\r
+    final TreePanel tp;\r
+    if (viewport.getSelectionGroup() != null &&\r
+        viewport.getSelectionGroup().getSize() > 3)\r
+    {\r
+      tp = new TreePanel(viewport, viewport.getSelectionGroup().sequences, type,\r
+                         pwType,\r
                          0, viewport.alignment.getWidth());\r
-   }\r
-   else\r
-   {\r
-     tp = new TreePanel(viewport, viewport.getAlignment().getSequences(),\r
-                         type, pwType,  0, viewport.alignment.getWidth());\r
-   }\r
+    }\r
+    else\r
+    {\r
+      tp = new TreePanel(viewport, viewport.getAlignment().getSequences(),\r
+                         type, pwType, 0, viewport.alignment.getWidth());\r
+    }\r
+\r
+   addTreeMenuItem(tp, title);\r
 \r
    Desktop.addInternalFrame(tp, title, 600, 500);\r
   }\r
 \r
+  void addTreeMenuItem(final TreePanel treePanel, String title)\r
+  {\r
+    final JMenuItem item = new JMenuItem(title);\r
+    sortByTreeMenu.add(item);\r
+    item.addActionListener(new java.awt.event.ActionListener()\r
+    {\r
+      public void actionPerformed(ActionEvent e)\r
+      {\r
+        addHistoryItem("sort");\r
+        AlignmentSorter.sortByTree(viewport.getAlignment(), treePanel.getTree());\r
+        alignPanel.RefreshPanels();\r
+      }\r
+    });\r
+\r
+    treePanel.addInternalFrameListener(new javax.swing.event.InternalFrameAdapter()\r
+    {\r
+      public void internalFrameClosed(javax.swing.event.InternalFrameEvent evt)\r
+      {\r
+        sortByTreeMenu.remove(item);\r
+      };\r
+    });\r
 \r
+  }\r
 \r
 \r
   public void clustalAlignMenuItem_actionPerformed(ActionEvent e)\r
@@ -989,47 +1079,49 @@ if ( viewport.getConservationSelected() )
     Thread t = new Thread(ct);\r
     t.start();\r
     frame.setContentPane(ct);\r
-     Desktop.addInternalFrame(frame, title, 300, 80);\r
+     Desktop.addInternalFrame(frame, title, 320, 90);\r
 \r
   }\r
 \r
   class ClustalThread extends JPanel implements Runnable\r
   {\r
-    Image [] image;\r
-    int imageIndex = 0;\r
+    Image image;\r
+    int angle = 0;\r
     boolean webServiceRunning = false;\r
     JInternalFrame frame;\r
     public ClustalThread(JInternalFrame frame)\r
     {\r
       this.frame = frame;\r
-      image = new Image[9];\r
-      for(int i=0; i<9; i++)\r
+\r
+      java.net.URL url = getClass().getResource("/images/logo.gif");\r
+      if (url != null)\r
       {\r
-        java.net.URL url = getClass().getResource("/images/dna" + (i+1) + ".gif");\r
-        if (url != null)\r
+        image = java.awt.Toolkit.getDefaultToolkit().createImage(url);\r
+        MediaTracker mt = new MediaTracker(this);\r
+        mt.addImage(image, 0);\r
+        try\r
         {\r
-          image[i] = java.awt.Toolkit.getDefaultToolkit().createImage(url);\r
-          MediaTracker mt = new MediaTracker(this);\r
-          mt.addImage(image[i], i);\r
-          try{mt.waitForID(i);}\r
-          catch(Exception ex){}\r
+          mt.waitForID(0);\r
         }\r
+        catch (Exception ex)\r
+        {}\r
       }\r
-      DNATwirler twirler = new DNATwirler();\r
-      twirler.start();\r
+\r
+      ImageSpinner spinner = new ImageSpinner();\r
+      spinner.start();\r
       webServiceRunning = true;\r
     }\r
 \r
-    class DNATwirler extends Thread\r
+    class ImageSpinner extends Thread\r
     {\r
       public void run()\r
       {\r
         while(webServiceRunning)\r
         {\r
           try{\r
-            Thread.sleep(100);\r
-            imageIndex++;\r
-            imageIndex %=9;\r
+            Thread.sleep(10);\r
+            angle+=1;\r
+            angle %=360;\r
             repaint();\r
           }\r
           catch(Exception ex){}\r
@@ -1058,10 +1150,9 @@ if ( viewport.getConservationSelected() )
          if (alignment != null)\r
          {\r
            AlignFrame af = new AlignFrame(new Alignment(alignment));\r
-          af.clustalColour.setSelected(true);\r
-          af.clustalColour_actionPerformed(null);\r
-           Desktop.addInternalFrame(af, getTitle().concat(" - ClustalW Alignment"),\r
-                                    700, 500); // JBPNote - is there a new window geom. property ?\r
+           Desktop.addInternalFrame(af, getTitle().concat(" - ClustalW Alignment"),NEW_WINDOW_WIDTH, NEW_WINDOW_HEIGHT);\r
+           af.clustalColour_actionPerformed(null);\r
+           af.clustalColour.setSelected(true);\r
          }\r
          else\r
            JOptionPane.showMessageDialog(Desktop.desktop, "Problem obtaining clustal alignment", "Web service error",\r
@@ -1073,25 +1164,72 @@ if ( viewport.getConservationSelected() )
          }catch(Exception ex){}\r
        }\r
 \r
-       public void paintComponent(Graphics g)\r
+       public void paintComponent(Graphics g1)\r
        {\r
+         Graphics2D g = (Graphics2D)g1;\r
          g.setColor(Color.white);\r
          g.fillRect(0,0,getWidth(), getHeight());\r
          if(image!=null)\r
          {\r
-           g.drawImage(image[imageIndex],10,10,this);\r
+\r
+           g.rotate (Math.toRadians(angle), 28, 28);\r
+\r
+           g.drawImage(image,10,10,this);\r
+           g.rotate (-Math.toRadians(angle), 28, 28 );\r
          }\r
          g.setFont(new Font("Arial", Font.BOLD, 12));\r
          g.setColor(Color.black);\r
-         g.drawString("Clustal Alignment Web Service running", 30,30);\r
+         g.drawString("Clustal Alignment Web Service running", 60,30);\r
        }\r
   }\r
-  public void jpredMenuItem_actionPerformed(ActionEvent e)\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
-    //  JInternalFrame frame = new JInternalFrame();\r
-//      JPredClient ct = new JPredClient((SequenceI)\r
-    ///                                   viewport.getAlignment().getSequences().elementAt(0));\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
@@ -1117,6 +1255,7 @@ if ( viewport.getConservationSelected() )
           tp = new TreePanel(viewport, viewport.getAlignment().getSequences(),\r
                              fin, "FromFile", choice);\r
           Desktop.addInternalFrame(tp, title, 600, 500);\r
+          addTreeMenuItem(tp, title);\r
         }\r
       }\r
       catch (Exception ex)\r