set gap char modified
[jalview.git] / src / jalview / gui / AlignFrame.java
index 9ec2f23..1b9ee91 100755 (executable)
@@ -247,8 +247,7 @@ public class AlignFrame extends GAlignFrame
       viewport.setAlignment( new Alignment(seq) );\r
       updateEditMenuBar();\r
       viewport.updateConsensus();\r
-      alignPanel.RefreshPanels();\r
-      alignPanel.RefreshPanels();\r
+      alignPanel.repaint();\r
   }\r
 \r
   public void moveSelectedSequences(boolean up)\r
@@ -290,7 +289,7 @@ public class AlignFrame extends GAlignFrame
       }\r
     }\r
 \r
-    alignPanel.RefreshPanels();\r
+    alignPanel.repaint();\r
   }\r
 \r
 \r
@@ -365,7 +364,7 @@ public class AlignFrame extends GAlignFrame
         viewport.alignment.getWidth();\r
         viewport.updateConservation();\r
         viewport.updateConsensus();\r
-        alignPanel.RefreshPanels();\r
+        alignPanel.repaint();\r
       }\r
 \r
     }catch(Exception ex){}// could be anything being pasted in here\r
@@ -408,7 +407,7 @@ public class AlignFrame extends GAlignFrame
      }catch(Exception ex){}\r
    viewport.updateConservation();\r
    viewport.updateConsensus();\r
-     alignPanel.RefreshPanels();\r
+     alignPanel.repaint();\r
 \r
   }\r
 \r
@@ -421,8 +420,8 @@ public class AlignFrame extends GAlignFrame
      viewport.setAlignment( new Alignment(seq) );\r
      updateEditMenuBar();\r
      viewport.updateConsensus();\r
-     alignPanel.RefreshPanels();\r
-     alignPanel.RefreshPanels();\r
+     alignPanel.repaint();\r
+     alignPanel.repaint();\r
   }\r
 \r
 \r
@@ -431,7 +430,7 @@ public class AlignFrame extends GAlignFrame
     viewport.alignment.deleteAllGroups();\r
     viewport.setSelectionGroup(null);\r
 \r
-    alignPanel.RefreshPanels();\r
+    alignPanel.repaint();\r
   }\r
 \r
 \r
@@ -489,7 +488,7 @@ public class AlignFrame extends GAlignFrame
           viewport.alignment.deleteGroup(sg);\r
       }\r
 \r
-      alignPanel.RefreshPanels();\r
+      alignPanel.repaint();\r
     }\r
   }\r
 \r
@@ -514,7 +513,7 @@ public class AlignFrame extends GAlignFrame
 \r
 \r
 \r
-      alignPanel.RefreshPanels();\r
+      alignPanel.repaint();\r
     }\r
 \r
   }\r
@@ -525,7 +524,7 @@ public class AlignFrame extends GAlignFrame
     viewport.getAlignment().removeGaps();\r
     viewport.updateConservation();\r
     viewport.updateConsensus();\r
-    alignPanel.RefreshPanels();\r
+    alignPanel.repaint();\r
   }\r
 \r
   public void removeAllGapsMenuItem_actionPerformed(ActionEvent e)\r
@@ -547,7 +546,7 @@ public class AlignFrame extends GAlignFrame
     }\r
     viewport.updateConservation();\r
     viewport.updateConsensus();\r
-    alignPanel.RefreshPanels();\r
+    alignPanel.repaint();\r
   }\r
 \r
   public void setGapCharMenuItem_actionPerformed(ActionEvent e)\r
@@ -561,7 +560,7 @@ public class AlignFrame extends GAlignFrame
     }\r
     setGapCharMenuItem.setText("Set gap character to \""+nextChar+"\"");\r
     viewport.setGapCharacter(thisChar);\r
-    alignPanel.RefreshPanels();\r
+    alignPanel.repaint();\r
   }\r
 \r
   public void findMenuItem_actionPerformed(ActionEvent e)\r
@@ -580,7 +579,10 @@ public class AlignFrame extends GAlignFrame
     JInternalFrame frame = new JInternalFrame();\r
     FontChooser fc = new FontChooser( alignPanel, frame );\r
     frame.setContentPane(fc);\r
-    Desktop.addInternalFrame(frame, "Change Font", 480,100);\r
+    Desktop.addInternalFrame(frame, "Change Font", 480,100, false);\r
+    frame.setLayer(JLayeredPane.PALETTE_LAYER);\r
+    if(alignPanel.getOverviewPanel()!=null)\r
+      alignPanel.getOverviewPanel().updateOverviewImage();\r
   }\r
 \r
   protected void fullSeqId_actionPerformed(ActionEvent e)\r
@@ -588,13 +590,13 @@ public class AlignFrame extends GAlignFrame
     viewport.setShowFullId( fullSeqId.isSelected() );\r
 \r
     alignPanel.idPanel.idCanvas.setPreferredSize( alignPanel.calculateIdWidth() );\r
-    alignPanel.RefreshPanels();\r
+    alignPanel.repaint();\r
   }\r
 \r
   protected void colourTextMenuItem_actionPerformed(ActionEvent e)\r
   {\r
       viewport.setColourText( colourTextMenuItem.isSelected() );\r
-      alignPanel.RefreshPanels();\r
+      alignPanel.repaint();\r
   }\r
 \r
   protected void wrapMenuItem_actionPerformed(ActionEvent e)\r
@@ -604,7 +606,7 @@ public class AlignFrame extends GAlignFrame
     scaleAbove.setVisible( wrapMenuItem.isSelected() );\r
     scaleLeft.setVisible( wrapMenuItem.isSelected() );\r
     scaleRight.setVisible( wrapMenuItem.isSelected() );\r
-    alignPanel.RefreshPanels();\r
+    alignPanel.repaint();\r
   }\r
 \r
   protected void scaleAbove_actionPerformed(ActionEvent e)\r
@@ -630,20 +632,20 @@ public class AlignFrame extends GAlignFrame
   public void viewBoxesMenuItem_actionPerformed(ActionEvent e)\r
   {\r
     viewport.setShowBoxes( viewBoxesMenuItem.isSelected() );\r
-    alignPanel.RefreshPanels();\r
+    alignPanel.repaint();\r
   }\r
 \r
   public void viewTextMenuItem_actionPerformed(ActionEvent e)\r
   {\r
     viewport.setShowText( viewTextMenuItem.isSelected() );\r
-    alignPanel.RefreshPanels();\r
+    alignPanel.repaint();\r
   }\r
 \r
 \r
   protected void renderGapsMenuItem_actionPerformed(ActionEvent e)\r
   {\r
     viewport.setRenderGaps(renderGapsMenuItem.isSelected());\r
-    alignPanel.RefreshPanels();\r
+    alignPanel.repaint();\r
   }\r
 \r
   public void sequenceFeatures_actionPerformed(ActionEvent evt)\r
@@ -654,7 +656,7 @@ public class AlignFrame extends GAlignFrame
          AlignmentUtil.fetchSequenceFeatures( viewport.alignment , alignPanel);\r
          ((Alignment)viewport.alignment).featuresAdded = true;\r
     }\r
-    alignPanel.RefreshPanels();\r
+    alignPanel.repaint();\r
   }\r
 \r
   public void annotationPanelMenuItem_actionPerformed(ActionEvent e)\r
@@ -674,27 +676,20 @@ public class AlignFrame extends GAlignFrame
       return;\r
 \r
     JInternalFrame frame = new JInternalFrame();\r
-    OverviewPanel overview = alignPanel.getOverviewPanel();\r
-   try{\r
-     overview = new OverviewPanel(alignPanel, viewport);\r
+    OverviewPanel overview = new OverviewPanel(alignPanel);\r
      frame.setContentPane(overview);\r
     Desktop.addInternalFrame(frame, "Overview " + this.getTitle(),\r
                              frame.getWidth(), frame.getHeight());\r
     frame.pack();\r
+    frame.setLayer(JLayeredPane.PALETTE_LAYER);\r
     frame.addInternalFrameListener(new javax.swing.event.InternalFrameAdapter()\r
     { public void internalFrameClosed(javax.swing.event.InternalFrameEvent evt)\r
       {\r
             alignPanel.setOverviewPanel(null);\r
       };\r
     });\r
-    alignPanel.setOverviewPanel( overview );\r
 \r
-  }catch(java.lang.OutOfMemoryError ex)\r
-   {\r
-     JOptionPane.showInternalMessageDialog(this, "Sequence alignment too large to\nproduce overview image!!"\r
-                                   +"\nTry reducing the font size.",\r
-                                   "Out of memory", JOptionPane.WARNING_MESSAGE);\r
-   }\r
+    alignPanel.setOverviewPanel( overview );\r
 \r
 \r
   }\r
@@ -765,106 +760,143 @@ public class AlignFrame extends GAlignFrame
 \r
   void changeColour(ColourSchemeI cs)\r
   {\r
+    int threshold = 0;\r
 \r
-    if(viewport.getColourAppliesToAllGroups())\r
+    if ( viewport.getAbovePIDThreshold() )\r
     {\r
-      Vector groups = viewport.alignment.getGroups();\r
-      for(int i=0; i<groups.size(); i++)\r
-      {\r
-        SequenceGroup sg = (SequenceGroup)groups.elementAt(i);\r
-        sg.cs = cs;\r
+      threshold = SliderPanel.setPIDSliderSource(alignPanel, cs, "Background");\r
 \r
-        if(abovePIDThreshold.isSelected())\r
-          abovePIDThreshold_actionPerformed(null);\r
-        else if( viewport.getConservationSelected() )\r
-        {\r
-          Conservation c = new Conservation("Group",\r
-                                            ResidueProperties.propHash, 3,\r
-                                            sg.sequences, sg.getStartRes(),\r
-                                            sg.getEndRes());\r
-          c.calculate();\r
-          c.verdict(false, viewport.ConsPercGaps);\r
-          ConservationColourScheme ccs = new ConservationColourScheme(c, sg.cs);\r
-          sg.cs = ccs;\r
-        }\r
+      if (cs instanceof ResidueColourScheme)\r
+        ( (ResidueColourScheme) cs).setThreshold(threshold);\r
+      else if (cs instanceof ScoreColourScheme)\r
+        ( (ScoreColourScheme) cs).setThreshold(threshold);\r
 \r
-      }\r
+      viewport.setGlobalColourScheme(cs);\r
     }\r
+    else if (cs instanceof ResidueColourScheme)\r
+      ( (ResidueColourScheme) cs).setThreshold(0);\r
+    else if (cs instanceof ScoreColourScheme)\r
+      ( (ScoreColourScheme) cs).setThreshold(0);\r
 \r
 \r
-    if ( viewport.getAbovePIDThreshold() )\r
+\r
+    if (viewport.getConservationSelected())\r
     {\r
- //     int threshold = 0;\r
-   //   threshold = Desktop.setPIDSliderSource(alignPanel, cs, "Background");\r
-      Desktop.hideConservationSlider();\r
+      ConservationColourScheme ccs = null;\r
 \r
- //     if (cs instanceof ResidueColourScheme)\r
- //       ( (ResidueColourScheme) cs).setThreshold(threshold);\r
-  //    else if (cs instanceof ScoreColourScheme)\r
-   //     ( (ScoreColourScheme) cs).setThreshold(threshold);\r
+      Alignment al = (Alignment) viewport.alignment;\r
+      Conservation c = new Conservation("All",\r
+                                        ResidueProperties.propHash, 3,\r
+                                        al.getSequences(), 0,\r
+                                        al.getWidth() - 1);\r
 \r
-      viewport.setGlobalColourScheme(cs);\r
+      c.calculate();\r
+      c.verdict(false, viewport.ConsPercGaps);\r
+\r
+      ccs = new ConservationColourScheme(c, cs);\r
+\r
+      // MUST NOTIFY THE COLOURSCHEME OF CONSENSUS!\r
+      ccs.setConsensus( viewport.vconsensus );\r
+      viewport.setGlobalColourScheme(ccs);\r
+\r
+      SliderPanel.setConservationSlider(alignPanel, ccs, "Background");\r
 \r
     }\r
     else\r
-    if (cs instanceof ResidueColourScheme)\r
-      ( (ResidueColourScheme) cs).setThreshold(0);\r
-    else if (cs instanceof ScoreColourScheme)\r
-      ( (ScoreColourScheme) cs).setThreshold(0);\r
-\r
+    {\r
+        // MUST NOTIFY THE COLOURSCHEME OF CONSENSUS!\r
+        if (cs != null)\r
+          cs.setConsensus(viewport.vconsensus);\r
+        viewport.setGlobalColourScheme(cs);\r
+    }\r
 \r
 \r
+    if(viewport.getColourAppliesToAllGroups())\r
+    {\r
+      Vector groups = viewport.alignment.getGroups();\r
+      for(int i=0; i<groups.size(); i++)\r
+      {\r
+        SequenceGroup sg = (SequenceGroup)groups.elementAt(i);\r
 \r
-if ( viewport.getConservationSelected() )\r
- {\r
-   ConservationColourScheme ccs = null;\r
+        if (cs instanceof ClustalxColourScheme)\r
+        {\r
+          sg.cs = new ClustalxColourScheme(sg.sequences, sg.getWidth());\r
+        }\r
+        else\r
+          try\r
+          {\r
+            sg.cs = (ColourSchemeI) cs.getClass().newInstance();\r
+          }\r
+          catch (Exception ex)\r
+          {\r
+            ex.printStackTrace();\r
+            sg.cs = cs;\r
+          }\r
 \r
-   Alignment al = (Alignment) viewport.alignment;\r
-   Conservation c = new Conservation("All",\r
-                                     ResidueProperties.propHash, 3,\r
-                                     al.getSequences(), 0,\r
-                                     al.getWidth()-1);\r
+        if(viewport.getAbovePIDThreshold())\r
+        {\r
+          if (sg.cs instanceof ResidueColourScheme)\r
+            ( (ResidueColourScheme) sg.cs).setThreshold(threshold);\r
+          else if (sg.cs instanceof ScoreColourScheme)\r
+            ( (ScoreColourScheme) sg.cs).setThreshold(threshold);\r
 \r
-   c.calculate();\r
-   c.verdict(false, viewport.ConsPercGaps);\r
+           sg.cs.setConsensus( AAFrequency.calculate(sg.sequences, 0, sg.getWidth()) );\r
+        }\r
 \r
-   ccs = new ConservationColourScheme(c, cs);\r
+        if( viewport.getConservationSelected() )\r
+        {\r
+          Conservation c = new Conservation("Group",\r
+                                            ResidueProperties.propHash, 3,\r
+                                            sg.sequences, 0, viewport.alignment.getWidth()-1);\r
+          c.calculate();\r
+          c.verdict(false, viewport.ConsPercGaps);\r
+          ConservationColourScheme ccs = new ConservationColourScheme(c, sg.cs);\r
 \r
-   viewport.setGlobalColourScheme(ccs);\r
+          // MUST NOTIFY THE COLOURSCHEME OF CONSENSUS!\r
+          ccs.setConsensus( AAFrequency.calculate(sg.sequences, 0, sg.getWidth()));\r
+          sg.cs = ccs;\r
+        }\r
+        else\r
+        {\r
+          // MUST NOTIFY THE COLOURSCHEME OF CONSENSUS!\r
+          sg.cs.setConsensus(AAFrequency.calculate(sg.sequences, 0, sg.getWidth()));\r
+        }\r
 \r
-  }\r
-  else\r
-       viewport.setGlobalColourScheme( cs );\r
+      }\r
+    }\r
 \r
-    alignPanel.RefreshPanels();\r
+    if(alignPanel.getOverviewPanel()!=null)\r
+      alignPanel.getOverviewPanel().updateOverviewImage();\r
+    alignPanel.repaint();\r
   }\r
 \r
   protected void modifyPID_actionPerformed(ActionEvent e)\r
   {\r
-    if(viewport.getAbovePIDThreshold())\r
-    Desktop.setPIDSliderSource(alignPanel, viewport.getGlobalColourScheme(), "Background");\r
+      if(viewport.getAbovePIDThreshold())\r
+      {\r
+        SliderPanel.setPIDSliderSource(alignPanel, viewport.getGlobalColourScheme(),\r
+                                   "Background");\r
+        SliderPanel.showPIDSlider();\r
+      }\r
   }\r
 \r
   protected void modifyConservation_actionPerformed(ActionEvent e)\r
   {\r
     if(viewport.getConservationSelected())\r
-    Desktop.setConservationSliderSource(alignPanel, viewport.globalColourScheme,    "Background");\r
+    {\r
+      SliderPanel.setConservationSlider(alignPanel, viewport.globalColourScheme,\r
+                                        "Background");\r
+      SliderPanel.showConservationSlider();\r
+    }\r
   }\r
 \r
 \r
   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
-    Desktop.hidePIDSlider();\r
-    if(!viewport.getConservationSelected())\r
-      Desktop.hideConservationSlider();\r
 \r
    ColourSchemeI cs = viewport.getGlobalColourScheme();\r
    if(cs instanceof ConservationColourScheme )\r
@@ -872,33 +904,24 @@ if ( viewport.getConservationSelected() )
     else\r
       changeColour( cs );\r
 \r
-    coloursChanging = false;\r
+    modifyConservation_actionPerformed(null);\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
     viewport.setConservationSelected(false);\r
-    Desktop.hideConservationSlider();\r
-\r
-    if(!viewport.getAbovePIDThreshold())\r
-      Desktop.hidePIDSlider();\r
-\r
 \r
     ColourSchemeI cs = viewport.getGlobalColourScheme();\r
+\r
     if(cs instanceof ConservationColourScheme )\r
         changeColour( ((ConservationColourScheme)cs).cs );\r
     else\r
         changeColour( cs );\r
 \r
-    coloursChanging = false;\r
+    modifyPID_actionPerformed(null);\r
   }\r
 \r
 \r
@@ -919,7 +942,7 @@ if ( viewport.getConservationSelected() )
 \r
   public void BLOSUM62Colour_actionPerformed(ActionEvent e)\r
   {\r
-    changeColour(new Blosum62ColourScheme(viewport) );\r
+    changeColour(new Blosum62ColourScheme() );\r
   }\r
 \r
 \r
@@ -928,14 +951,14 @@ if ( viewport.getConservationSelected() )
   {\r
     addHistoryItem("sort");\r
     AlignmentSorter.sortByPID(viewport.getAlignment(), viewport.getAlignment().getSequenceAt(0));\r
-    alignPanel.RefreshPanels();\r
+    alignPanel.repaint();\r
   }\r
 \r
   public void sortIDMenuItem_actionPerformed(ActionEvent e)\r
   {\r
     addHistoryItem("sort");\r
     AlignmentSorter.sortByID( viewport.getAlignment() );\r
-    alignPanel.RefreshPanels();\r
+    alignPanel.repaint();\r
   }\r
 \r
   public void sortGroupMenuItem_actionPerformed(ActionEvent e)\r
@@ -943,7 +966,7 @@ if ( viewport.getConservationSelected() )
     addHistoryItem("sort");\r
     AlignmentSorter.sortByGroup(viewport.getAlignment());\r
     AlignmentSorter.sortGroups(viewport.getAlignment());\r
-    alignPanel.RefreshPanels();\r
+    alignPanel.repaint();\r
   }\r
 \r
   public void removeRedundancyMenuItem_actionPerformed(ActionEvent e)\r
@@ -1054,7 +1077,7 @@ if ( viewport.getConservationSelected() )
       {\r
         addHistoryItem("sort");\r
         AlignmentSorter.sortByTree(viewport.getAlignment(), treePanel.getTree());\r
-        alignPanel.RefreshPanels();\r
+        alignPanel.repaint();\r
       }\r
     });\r
 \r
@@ -1165,6 +1188,39 @@ if ( viewport.getConservationSelected() )
 \r
     }\r
   }\r
+  protected void msaAlignMenuItem_actionPerformed(ActionEvent e)\r
+  {\r
+    // TODO:resolve which menu item was actually selected\r
+    // Now, check we have enough sequences\r
+      if (viewport.getSelectionGroup() != null && viewport.getSelectionGroup().getSize()>1)\r
+      {\r
+        // JBPNote UGLY! To prettify, make SequenceGroup and Alignment conform to some common interface!\r
+        SequenceGroup seqs = viewport.getSelectionGroup();\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
+        MsaWSClient ct = new jalview.ws.MsaWSClient(msa);\r
+      }\r
+      else\r
+      {\r
+        Vector seqs = viewport.getAlignment().getSequences();\r
+\r
+        if (seqs.size() > 1) {\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
+          MsaWSClient ct = new MsaWSClient(msa);\r
+        }\r
+\r
+      }\r
+    }\r
 \r
     protected void LoadtreeMenuItem_actionPerformed(ActionEvent e) {\r
     // Pick the tree file\r