check if colourscheme is null
[jalview.git] / src / jalview / gui / AlignFrame.java
index 76c483e..80f16a3 100755 (executable)
@@ -16,37 +16,95 @@ import jalview.schemes.*;
 import jalview.datamodel.*;\r
 import jalview.analysis.*;\r
 import jalview.io.*;\r
-import MCview.*;\r
+import jalview.ws.*;\r
 import java.awt.*;\r
 import java.awt.event.*;\r
 import java.awt.print.*;\r
 import javax.swing.*;\r
+import javax.swing.event.*;\r
 import java.util.*;\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
-    viewport = new AlignViewport(al,true,true,true,false);\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
+    String fontStyle= jalview.bin.Cache.getProperty("FONT_STYLE");\r
+    String fontSize = jalview.bin.Cache.getProperty("FONT_SIZE");\r
+    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
-    fontNameMenuItem.setText(viewport.getFont().getName());\r
-    fontSizeMenuItem.setText(viewport.getFont().getSize()+"");\r
+\r
+\r
+    addInternalFrameListener(new InternalFrameAdapter()\r
+   {\r
+     public void internalFrameActivated(InternalFrameEvent evt)\r
+     {\r
+          javax.swing.SwingUtilities.invokeLater(new Runnable()\r
+          {\r
+            public void run()\r
+            {      alignPanel.requestFocus();    }\r
+          });\r
+\r
+     }\r
+   });\r
+\r
   }\r
 \r
   protected void saveAs_actionPerformed(ActionEvent e)\r
   {\r
-    JFileChooser chooser = new JFileChooser(jalview.bin.Cache.LAST_DIRECTORY);\r
+    String suffix [] = null;\r
+    if(e.getActionCommand().equals("FASTA"))\r
+      suffix = new String[]{"fa", "fasta"};\r
+    else if(e.getActionCommand().equals("MSF"))\r
+      suffix = new String[]{"msf"};\r
+    else if(e.getActionCommand().equals("CLUSTAL"))\r
+      suffix = new String[]{"aln"};\r
+    else if(e.getActionCommand().equals("BLC"))\r
+      suffix = new String[]{"blc"};\r
+    else if(e.getActionCommand().equals("PIR"))\r
+      suffix = new String[]{"pir"};\r
+    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
     chooser.setDialogTitle("Save Alignment to file - "+e.getActionCommand() +" format.");\r
     chooser.setToolTipText("Save");\r
     int value = chooser.showSaveDialog(this);\r
-    if(value == JFileChooser.APPROVE_OPTION)\r
+    if(value == JalviewFileChooser.APPROVE_OPTION)\r
     {\r
       String choice =  chooser.getSelectedFile().getPath();\r
-      jalview.bin.Cache.LAST_DIRECTORY = choice;\r
+      jalview.bin.Cache.setProperty("LAST_DIRECTORY", choice);\r
       String output = FormatAdapter.get(e.getActionCommand(), viewport.getAlignment().getSequences());\r
       try{\r
         java.io.PrintWriter out = new java.io.PrintWriter( new java.io.FileWriter( choice )  );\r
@@ -70,10 +128,21 @@ public class AlignFrame extends GAlignFrame
 \r
   protected void htmlMenuItem_actionPerformed(ActionEvent e)\r
   {\r
-    HTMLOutput htmlOutput = new HTMLOutput(viewport.getAlignment(), alignPanel.seqPanel.getColourScheme());\r
+    HTMLOutput htmlOutput = new HTMLOutput(viewport);\r
     htmlOutput = null;\r
   }\r
 \r
+  protected void createPNG_actionPerformed(ActionEvent e)\r
+  {\r
+    alignPanel.makePNG();\r
+  }\r
+\r
+  protected void epsFile_actionPerformed(ActionEvent e)\r
+  {\r
+    alignPanel.makeEPS();\r
+  }\r
+\r
+\r
   public void printMenuItem_actionPerformed(ActionEvent e)\r
   {\r
     //Putting in a thread avoids Swing painting problems\r
@@ -113,8 +182,9 @@ public class AlignFrame extends GAlignFrame
     }catch(Exception ex){}\r
   }\r
 \r
-  ArrayList  historyList = new ArrayList();\r
-  ArrayList redoList = new ArrayList();\r
+  Stack historyList = new Stack();\r
+  Stack redoList = new Stack();\r
+  JMenuBar jMenuBar1 = new JMenuBar();\r
 \r
   void updateEditMenuBar()\r
   {\r
@@ -176,97 +246,221 @@ public class AlignFrame extends GAlignFrame
       seq = (SequenceI[]) history[1];\r
       viewport.setAlignment( new Alignment(seq) );\r
       updateEditMenuBar();\r
-      alignPanel.RefreshPanels();\r
+      viewport.updateConsensus();\r
+      alignPanel.repaint();\r
   }\r
 \r
-\r
-  protected void redoMenuItem_actionPerformed(ActionEvent e)\r
+  public void moveSelectedSequences(boolean up)\r
   {\r
-     Object [] history = (Object[])redoList.remove(0);\r
-     SequenceI[] seq = (SequenceI[]) history[1];\r
-     viewport.setAlignment( new Alignment(seq) );\r
-     updateEditMenuBar();\r
-     alignPanel.RefreshPanels();\r
+    SequenceGroup sg = viewport.getSelectionGroup();\r
+    if (sg == null)\r
+      return;\r
+\r
+    if (up)\r
+    {\r
+      for (int i = 1; i < viewport.alignment.getHeight(); i++)\r
+      {\r
+        SequenceI seq = viewport.alignment.getSequenceAt(i);\r
+        if (!sg.sequences.contains(seq))\r
+          continue;\r
+\r
+        SequenceI temp = viewport.alignment.getSequenceAt(i - 1);\r
+        if (sg.sequences.contains(temp))\r
+          continue;\r
+\r
+        viewport.alignment.getSequences().setElementAt(temp, i);\r
+        viewport.alignment.getSequences().setElementAt(seq, i - 1);\r
+      }\r
+    }\r
+    else\r
+    {\r
+      for (int i = viewport.alignment.getHeight() - 2; i > -1; i--)\r
+      {\r
+        SequenceI seq = viewport.alignment.getSequenceAt(i);\r
+        if (!sg.sequences.contains(seq))\r
+          continue;\r
+\r
+        SequenceI temp = viewport.alignment.getSequenceAt(i + 1);\r
+        if (sg.sequences.contains(temp))\r
+          continue;\r
+\r
+        viewport.alignment.getSequences().setElementAt(temp, i);\r
+        viewport.alignment.getSequences().setElementAt(seq, i + 1);\r
+      }\r
+    }\r
+\r
+    alignPanel.repaint();\r
   }\r
 \r
 \r
 \r
-  public void groupsMenuItem_actionPerformed(ActionEvent e)\r
+  protected void copy_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
+   if(viewport.getSelectionGroup()==null)\r
+     return;\r
+\r
+   SequenceGroup sg = viewport.getSelectionGroup();\r
+\r
+     Clipboard c = Toolkit.getDefaultToolkit().getSystemClipboard();\r
+     StringBuffer buffer= new StringBuffer();\r
+\r
+       for(int i=0; i<sg.getSize(); i++)\r
+       {\r
+         SequenceI seq = sg.getSequenceAt(i);\r
+         buffer.append( seq.getName()+"\t"+seq.findPosition( sg.getStartRes() ) +"\t"\r
+                        +seq.findPosition( sg.getEndRes() )+ "\t"\r
+                        +sg.getSequenceAt(i).getSequence(sg.getStartRes(), sg.getEndRes()+1)+"\n");\r
+       }\r
+     c.setContents( new StringSelection( buffer.toString()) , null ) ;\r
+\r
   }\r
 \r
-  public void groupEditingMenuItem_actionPerformed(ActionEvent e)\r
+\r
+  protected void pasteNew_actionPerformed(ActionEvent e)\r
   {\r
-    viewport.setGroupEdit( groupEditingMenuItem.isSelected() );\r
+    paste(true);\r
   }\r
 \r
-  public void selectAllSequenceMenuItem_actionPerformed(ActionEvent e)\r
+  protected void pasteThis_actionPerformed(ActionEvent e)\r
   {\r
-    Selection sel = viewport.getSelection();\r
-    for (int i=0; i<viewport.getAlignment().getSequences().size(); i++)\r
-      sel.addElement( viewport.getAlignment().getSequenceAt(i));\r
-    PaintRefresher.Refresh(null);\r
+    addHistoryItem("Paste");\r
+    paste(false);\r
   }\r
 \r
-  public void deselectAllSequenceMenuItem_actionPerformed(ActionEvent e)\r
+  void paste(boolean newAlignment)\r
   {\r
-    viewport.getSelection().clear();\r
-    PaintRefresher.Refresh(null);\r
+    try{\r
+      Clipboard c = Toolkit.getDefaultToolkit().getSystemClipboard();\r
+      Transferable contents = c.getContents(this);\r
+      if (contents == null)\r
+        return;\r
+\r
+      String str = (String) contents.getTransferData(DataFlavor.stringFlavor);\r
+      StringTokenizer st = new StringTokenizer(str);\r
+      ArrayList seqs = new ArrayList();\r
+      while (st.hasMoreElements())\r
+      {\r
+        String name = st.nextToken();\r
+        int start = Integer.parseInt(st.nextToken());\r
+        int end = Integer.parseInt(st.nextToken());\r
+        Sequence sequence = new Sequence(name,st.nextToken(), start, end);\r
+\r
+        if(!newAlignment)\r
+          viewport.alignment.addSequence(sequence);\r
+        else\r
+          seqs.add(sequence);\r
+      }\r
+\r
+      if(newAlignment)\r
+      {\r
+        SequenceI[] newSeqs = new SequenceI[seqs.size()];\r
+        seqs.toArray(newSeqs);\r
+        AlignFrame af = new AlignFrame(new Alignment(newSeqs));\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.repaint();\r
+      }\r
+\r
+    }catch(Exception ex){}// could be anything being pasted in here\r
+\r
   }\r
 \r
-  public void invertSequenceMenuItem_actionPerformed(ActionEvent e)\r
+\r
+  protected void cut_actionPerformed(ActionEvent e)\r
   {\r
-    Selection sel = viewport.getSelection();\r
-    for (int i=0; i<viewport.getAlignment().getSequences().size(); i++)\r
-    {\r
-      if (sel.contains(viewport.getAlignment().getSequenceAt(i)))\r
-        sel.removeElement(viewport.getAlignment().getSequenceAt(i));\r
-      else\r
-        sel.addElement(viewport.getAlignment().getSequenceAt(i));\r
-    }\r
-    PaintRefresher.Refresh(null);\r
+    copy_actionPerformed(null);\r
+    delete_actionPerformed(null);\r
   }\r
 \r
-  public void deleteSelectedMenuItem_actionPerformed(ActionEvent e)\r
+  protected void delete_actionPerformed(ActionEvent e)\r
   {\r
-    addHistoryItem("delete selection");\r
+    addHistoryItem("Delete");\r
+    if (viewport.getSelectionGroup() == null)\r
+      return;\r
+\r
+     SequenceGroup sg = viewport.getSelectionGroup();\r
+     for (int i=0;i < sg.sequences.size(); i++)\r
+     {\r
+       SequenceI seq = sg.getSequenceAt(i);\r
+       int index = viewport.getAlignment().findIndex(seq);\r
+       seq.deleteChars(sg.getStartRes(), sg.getEndRes()+1);\r
+\r
+       if(seq.getSequence().length()<1)\r
+          viewport.getAlignment().deleteSequence(seq);\r
+      else\r
+          viewport.getAlignment().getSequences().setElementAt(seq, index);\r
+     }\r
+\r
+     viewport.setSelectionGroup(null);\r
+     viewport.alignment.deleteGroup(sg);\r
+     viewport.resetSeqLimits( alignPanel.seqPanel.seqCanvas.getHeight());\r
+     if(viewport.getAlignment().getHeight()<1)\r
+     try\r
+     {\r
+       this.setClosed(true);\r
+     }catch(Exception ex){}\r
+   viewport.updateConservation();\r
+   viewport.updateConsensus();\r
+     alignPanel.repaint();\r
+\r
+  }\r
+\r
 \r
-    for (int i=0;i < viewport.getSelection().size(); i++)\r
-            viewport.getAlignment().deleteSequence(viewport.getSelection().sequenceAt(i));\r
 \r
-    viewport.getSelection().clear();\r
-    viewport.resetSeqLimits(alignPanel.seqPanel.seqCanvas.getHeight());\r
-    alignPanel.RefreshPanels();\r
+  protected void redoMenuItem_actionPerformed(ActionEvent e)\r
+  {\r
+     Object [] history = (Object[])redoList.remove(0);\r
+     SequenceI[] seq = (SequenceI[]) history[1];\r
+     viewport.setAlignment( new Alignment(seq) );\r
+     updateEditMenuBar();\r
+     viewport.updateConsensus();\r
+     alignPanel.repaint();\r
+     alignPanel.repaint();\r
   }\r
 \r
-  public void moveSelectedMenuItem_actionPerformed(ActionEvent e)\r
+\r
+  protected void deleteGroups_actionPerformed(ActionEvent e)\r
   {\r
-    copySelectedMenuItem_actionPerformed(null);\r
-    deleteSelectedMenuItem_actionPerformed(null);\r
+    viewport.alignment.deleteAllGroups();\r
+    viewport.setSelectionGroup(null);\r
+\r
     alignPanel.repaint();\r
   }\r
 \r
-  public void copySelectedMenuItem_actionPerformed(ActionEvent e)\r
+\r
+\r
+  public void selectAllSequenceMenuItem_actionPerformed(ActionEvent e)\r
   {\r
-    if(viewport.getSelection().size()==0)\r
-      return;\r
+    SequenceGroup sg = new SequenceGroup();\r
+    for (int i=0; i<viewport.getAlignment().getSequences().size(); i++)\r
+      sg.addSequence( viewport.getAlignment().getSequenceAt(i));\r
+    sg.setEndRes(viewport.alignment.getWidth());\r
+    viewport.setSelectionGroup(sg);\r
+    PaintRefresher.Refresh(null);\r
+  }\r
 \r
-   SequenceI[] s = new Sequence[viewport.getSelection().size()];\r
-   for (int i=0; i < viewport.getSelection().size(); i++) {\r
-     s[i] = new Sequence(viewport.getSelection().sequenceAt(i));\r
-    }\r
-    AlignFrame af = new AlignFrame(new Alignment(s));\r
-    int newHeight = s.length * af.viewport.getCharHeight() + 200;\r
-    if(newHeight>500)\r
-      newHeight=500;\r
-    Desktop.addInternalFrame(af, "Copied sequences", 700,newHeight);\r
+  public void deselectAllSequenceMenuItem_actionPerformed(ActionEvent e)\r
+  {\r
+    viewport.setSelectionGroup(null);\r
+    PaintRefresher.Refresh(null);\r
   }\r
 \r
+  public void invertSequenceMenuItem_actionPerformed(ActionEvent e)\r
+  {\r
+    SequenceGroup sg = viewport.getSelectionGroup();\r
+    for (int i=0; i<viewport.getAlignment().getSequences().size(); i++)\r
+      sg.addOrRemove (viewport.getAlignment().getSequenceAt(i));\r
+\r
+    PaintRefresher.Refresh(null);\r
+  }\r
+\r
+\r
   public void deselectAllColumnsMenuItem_actionPerformed(ActionEvent e)\r
   {\r
     viewport.getColumnSelection().clear();\r
@@ -282,7 +476,19 @@ public class AlignFrame extends GAlignFrame
       int min = colSel.getMin();\r
       viewport.getAlignment().trimLeft(min);\r
       colSel.compensateForEdit(0,min);\r
-      alignPanel.RefreshPanels();\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.repaint();\r
     }\r
   }\r
 \r
@@ -293,10 +499,21 @@ 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
-      alignPanel.RefreshPanels();\r
+\r
+      alignPanel.repaint();\r
     }\r
 \r
   }\r
@@ -305,7 +522,9 @@ public class AlignFrame extends GAlignFrame
   {\r
     addHistoryItem("delete gapped columns");\r
     viewport.getAlignment().removeGaps();\r
-    alignPanel.RefreshPanels();\r
+    viewport.updateConservation();\r
+    viewport.updateConsensus();\r
+    alignPanel.repaint();\r
   }\r
 \r
   public void removeAllGapsMenuItem_actionPerformed(ActionEvent e)\r
@@ -318,129 +537,141 @@ public class AlignFrame extends GAlignFrame
       current = viewport.getAlignment().getSequenceAt(i);\r
       jSize = current.getLength();\r
       for (int j=0; j < jSize; j++)\r
-        if (current.getCharAt(j)=='-' || current.getCharAt(j)=='.' || current.getCharAt(j)==' ')\r
+        if(jalview.util.Comparison.isGap(current.getCharAt(j)))\r
         {\r
           current.deleteCharAt(j);\r
           j--;\r
           jSize--;\r
         }\r
     }\r
-\r
-    alignPanel.RefreshPanels();\r
+    viewport.updateConservation();\r
+    viewport.updateConsensus();\r
+    alignPanel.repaint();\r
   }\r
 \r
   public void setGapCharMenuItem_actionPerformed(ActionEvent e)\r
   {\r
-    String thisChar = "-";\r
-    String nextChar = ".";\r
-    if(viewport.getGapCharacter().equals("-"))\r
+    char thisChar = '-';\r
+    char nextChar = '.';\r
+    if(viewport.getGapCharacter()=='-')\r
     {\r
-      thisChar = ".";\r
-      nextChar = "-";\r
+      thisChar = '.';\r
+      nextChar = '-';\r
     }\r
     setGapCharMenuItem.setText("Set gap character to \""+nextChar+"\"");\r
     viewport.setGapCharacter(thisChar);\r
+    alignPanel.repaint();\r
   }\r
 \r
-\r
-  public void fontNameMenuItem_actionPerformed(ActionEvent e)\r
+  public void findMenuItem_actionPerformed(ActionEvent e)\r
   {\r
-    String fonts[] = java.awt.GraphicsEnvironment.getLocalGraphicsEnvironment().getAvailableFontFamilyNames();\r
-\r
-\r
-    String selection = JOptionPane.showInputDialog(this,\r
-                                "Select font",\r
-                                "Font selection",\r
-                                JOptionPane.QUESTION_MESSAGE,\r
-                                null,fonts\r
-                                ,fontNameMenuItem.getText()).toString();\r
-    if(selection!=null)\r
-    {\r
-       fontNameMenuItem.setText(selection);\r
-       SetFont();\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, false);\r
+    frame.setLayer(JLayeredPane.PALETTE_LAYER);\r
 \r
   }\r
 \r
-  public void fontSizeMenuItem_actionPerformed(ActionEvent e)\r
+\r
+  public void font_actionPerformed(ActionEvent e)\r
   {\r
-    String selection = JOptionPane.showInputDialog(this,\r
-                                "Select font size",\r
-                                "Font size",\r
-                                JOptionPane.QUESTION_MESSAGE,\r
-                                null, new String[]{"1","2","4","6","8","10","12","14","16","18","20"}\r
-                                ,fontSizeMenuItem.getText()).toString();\r
-    if(selection!=null)\r
-     {\r
-       fontSizeMenuItem.setText(selection);\r
-       SetFont();\r
-     }\r
+    JInternalFrame frame = new JInternalFrame();\r
+    FontChooser fc = new FontChooser( alignPanel, frame );\r
+    frame.setContentPane(fc);\r
+    Desktop.addInternalFrame(frame, "Change Font", 480,100);\r
+    frame.setLayer(JLayeredPane.PALETTE_LAYER);\r
   }\r
 \r
-  public void fontStyleMenuItem_actionPerformed(ActionEvent e)\r
+  protected void fullSeqId_actionPerformed(ActionEvent e)\r
   {\r
-    String selection = JOptionPane.showInputDialog(this,\r
-                                "Select font style",\r
-                                "Font style",\r
-                                JOptionPane.QUESTION_MESSAGE,\r
-                                null, new String[]{"plain", "bold", "italic"}\r
-                                ,fontStyleMenuItem.getText()).toString();\r
-    if(selection!=null)\r
-    {\r
-      fontStyleMenuItem.setText(selection);\r
-      SetFont();\r
-    }\r
+    viewport.setShowFullId( fullSeqId.isSelected() );\r
 \r
+    alignPanel.idPanel.idCanvas.setPreferredSize( alignPanel.calculateIdWidth() );\r
+    alignPanel.repaint();\r
   }\r
 \r
   protected void colourTextMenuItem_actionPerformed(ActionEvent e)\r
   {\r
-    viewport.setColourText( colourTextMenuItem.isSelected() );\r
-    alignPanel.RefreshPanels();\r
+      viewport.setColourText( colourTextMenuItem.isSelected() );\r
+      alignPanel.repaint();\r
   }\r
 \r
-  void SetFont()\r
+  protected void wrapMenuItem_actionPerformed(ActionEvent e)\r
   {\r
-      int style = java.awt.Font.PLAIN;\r
-      if(fontStyleMenuItem.getText().equals("bold"))\r
-        style = java.awt.Font.BOLD;\r
-      else if(fontStyleMenuItem.getText().equals("italic"))\r
-        style = java.awt.Font.ITALIC;\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.repaint();\r
+  }\r
 \r
-      viewport.setFont(new java.awt.Font(fontNameMenuItem.getText(),\r
-                                           style,\r
-                                           Integer.parseInt(fontSizeMenuItem.getText())));\r
-      alignPanel.RefreshPanels();\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 wrapMenuItem_actionPerformed(ActionEvent e)\r
+  protected void scaleRight_actionPerformed(ActionEvent e)\r
   {\r
-    viewport.setWrapAlignment( wrapMenuItem.isSelected() );\r
-    alignPanel.setWrapAlignment( wrapMenuItem.isSelected() );\r
+    viewport.setScaleRightWrapped(scaleRight.isSelected());\r
+    alignPanel.repaint();\r
   }\r
 \r
 \r
+\r
   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
-  public void consensusGraphMenuItem_actionPerformed(ActionEvent e)\r
+  protected void renderGapsMenuItem_actionPerformed(ActionEvent e)\r
   {\r
-    alignPanel.setGraphPanelVisible( consensusGraphMenuItem.isSelected() );\r
+    viewport.setRenderGaps(renderGapsMenuItem.isSelected());\r
+    alignPanel.repaint();\r
+  }\r
+\r
+  public void sequenceFeatures_actionPerformed(ActionEvent evt)\r
+  {\r
+    viewport.showSequenceFeatures(sequenceFeatures.isSelected());\r
+    if(viewport.showSequenceFeatures && !((Alignment)viewport.alignment).featuresAdded)\r
+    {\r
+         AlignmentUtil.fetchSequenceFeatures( viewport.alignment , alignPanel);\r
+         ((Alignment)viewport.alignment).featuresAdded = true;\r
+    }\r
+    alignPanel.repaint();\r
+  }\r
+\r
+  public void annotationPanelMenuItem_actionPerformed(ActionEvent e)\r
+  {\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
   {\r
+    if (alignPanel.overviewPanel != null)\r
+      return;\r
 \r
     JInternalFrame frame = new JInternalFrame();\r
     OverviewPanel overview = alignPanel.getOverviewPanel();\r
@@ -460,7 +691,7 @@ public class AlignFrame extends GAlignFrame
 \r
   }catch(java.lang.OutOfMemoryError ex)\r
    {\r
-     JOptionPane.showMessageDialog(this, "Sequence alignment too large to\nproduce overview image!!"\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
@@ -470,151 +701,288 @@ public class AlignFrame extends GAlignFrame
 \r
   protected void noColourmenuItem_actionPerformed(ActionEvent e)\r
   {\r
-    alignPanel.setColourScheme(null, false);\r
+    changeColour( null );\r
   }\r
 \r
 \r
   public void clustalColour_actionPerformed(ActionEvent e)\r
   {\r
-   // alignPanel.setColourScheme( new ClustalxColourScheme() );\r
+    abovePIDThreshold.setSelected(false);\r
+    changeColour(new ClustalxColourScheme(viewport.alignment.getSequences(), viewport.alignment.getWidth()));\r
   }\r
 \r
   public void zappoColour_actionPerformed(ActionEvent e)\r
   {\r
-    alignPanel.setColourScheme( new ZappoColourScheme(), conservationMenuItem.isSelected() );\r
+    changeColour(new ZappoColourScheme());\r
   }\r
 \r
   public void taylorColour_actionPerformed(ActionEvent e)\r
   {\r
-    alignPanel.setColourScheme( new TaylorColourScheme(),conservationMenuItem.isSelected() );\r
+    changeColour(new TaylorColourScheme());\r
   }\r
 \r
 \r
   public void hydrophobicityColour_actionPerformed(ActionEvent e)\r
   {\r
-    alignPanel.setColourScheme( new HydrophobicColourScheme(),conservationMenuItem.isSelected() );\r
+    changeColour( new HydrophobicColourScheme() );\r
   }\r
 \r
   public void helixColour_actionPerformed(ActionEvent e)\r
   {\r
-    alignPanel.setColourScheme( new HelixColourScheme(),conservationMenuItem.isSelected() );\r
+    changeColour(new HelixColourScheme() );\r
   }\r
 \r
 \r
   public void strandColour_actionPerformed(ActionEvent e)\r
   {\r
-    alignPanel.setColourScheme( new StrandColourScheme() ,conservationMenuItem.isSelected() );\r
+    changeColour(new StrandColourScheme());\r
   }\r
 \r
 \r
   public void turnColour_actionPerformed(ActionEvent e)\r
   {\r
-    alignPanel.setColourScheme( new TurnColourScheme() ,conservationMenuItem.isSelected() );\r
+    changeColour(new TurnColourScheme());\r
   }\r
 \r
 \r
   public void buriedColour_actionPerformed(ActionEvent e)\r
   {\r
-    alignPanel.setColourScheme( new BuriedColourScheme() ,conservationMenuItem.isSelected() );\r
+    changeColour(new BuriedColourScheme() );\r
+  }\r
+\r
+  public void nucleotideColour_actionPerformed(ActionEvent e)\r
+  {\r
+    changeColour(new NucleotideColourScheme());\r
   }\r
 \r
 \r
-  protected  void conservationMenuItem_actionPerformed(ActionEvent e)\r
+  protected void applyToAllGroups_actionPerformed(ActionEvent e)\r
   {\r
-    alignPanel.setColourScheme ( alignPanel.seqPanel.getColourScheme(),conservationMenuItem.isSelected() );\r
-    conservationColourIncMenuItem.setEnabled( conservationMenuItem.isSelected() );\r
+    viewport.setColourAppliesToAllGroups(applyToAllGroups.isSelected());\r
   }\r
 \r
 \r
 \r
-  public void conservationColourIncMenuItem_actionPerformed(ActionEvent e)\r
- {\r
-   ConservationIncrementPanel cip = new ConservationIncrementPanel(viewport, alignPanel);\r
-   JInternalFrame frame = new JInternalFrame();\r
-   frame.setContentPane(cip);\r
-   Desktop.addInternalFrame(frame, "Conservation Colour Increment", 400,90);\r
-   frame.setMaximizable(false);\r
- }\r
+  void changeColour(ColourSchemeI cs)\r
+  {\r
+    int threshold = 0;\r
+\r
+    if ( viewport.getAbovePIDThreshold() )\r
+    {\r
+      threshold = SliderPanel.setPIDSliderSource(alignPanel, cs, "Background");\r
+\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
+    else if (cs instanceof ResidueColourScheme)\r
+      ( (ResidueColourScheme) cs).setThreshold(0);\r
+    else if (cs instanceof ScoreColourScheme)\r
+      ( (ScoreColourScheme) cs).setThreshold(0);\r
+\r
+\r
+\r
+    if (viewport.getConservationSelected())\r
+    {\r
+      ConservationColourScheme ccs = null;\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
+\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
+    }\r
+    else\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 (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
+        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
+           sg.cs.setConsensus( AAFrequency.calculate(sg.sequences, 0, sg.getWidth()) );\r
+        }\r
+\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
+          // 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
+    }\r
 \r
 \r
-  public void abovePIDColour_actionPerformed(ActionEvent e)\r
+\r
+    alignPanel.repaint();\r
+  }\r
+\r
+  protected void modifyPID_actionPerformed(ActionEvent e)\r
+  {\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
+    {\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
+\r
+    viewport.setAbovePIDThreshold(false);\r
+    abovePIDThreshold.setSelected(false);\r
+\r
+   ColourSchemeI cs = viewport.getGlobalColourScheme();\r
+   if(cs instanceof ConservationColourScheme )\r
+     changeColour( ((ConservationColourScheme)cs).cs );\r
+    else\r
+      changeColour( cs );\r
+\r
+  }\r
+\r
+ // boolean coloursChanging = false;\r
+  public void abovePIDThreshold_actionPerformed(ActionEvent e)\r
   {\r
-    alignPanel.setColourScheme( new PIDColourScheme() ,conservationMenuItem.isSelected() );\r
+    viewport.setAbovePIDThreshold(abovePIDThreshold.isSelected());\r
+\r
+    conservationMenuItem.setSelected(false);\r
+    viewport.setConservationSelected(false);\r
+\r
+    ColourSchemeI cs = viewport.getGlobalColourScheme();\r
+\r
+    if(cs instanceof ConservationColourScheme )\r
+        changeColour( ((ConservationColourScheme)cs).cs );\r
+    else\r
+        changeColour( cs );\r
   }\r
 \r
 \r
+\r
   public void userDefinedColour_actionPerformed(ActionEvent e)\r
   {\r
     JInternalFrame frame = new JInternalFrame();\r
-    UserDefinedColours chooser = new UserDefinedColours( frame, alignPanel.seqPanel );\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
   {\r
-    alignPanel.setColourScheme( new PIDColourScheme(),conservationMenuItem.isSelected() );\r
+    changeColour( new PIDColourScheme() );\r
   }\r
 \r
 \r
   public void BLOSUM62Colour_actionPerformed(ActionEvent e)\r
   {\r
-    alignPanel.setColourScheme( new Blosum62ColourScheme(viewport) ,conservationMenuItem.isSelected() );\r
+    changeColour(new Blosum62ColourScheme() );\r
   }\r
 \r
 \r
 \r
-  protected void schemeKeyMenuItem_actionPerformed(ActionEvent e)\r
-  {\r
-    ColourKey colourKey = new ColourKey( alignPanel.seqPanel.getColourScheme() );\r
-    Desktop.addInternalFrame(colourKey, "Colour scheme key", 400, 320);\r
-  }\r
-\r
-\r
   public void sortPairwiseMenuItem_actionPerformed(ActionEvent e)\r
   {\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
   {\r
     addHistoryItem("sort");\r
+    AlignmentSorter.sortByGroup(viewport.getAlignment());\r
     AlignmentSorter.sortGroups(viewport.getAlignment());\r
-    AlignmentSorter.sortGroups(viewport.getAlignment());\r
-    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
+    alignPanel.repaint();\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, false);\r
 \r
   }\r
 \r
   public void pairwiseAlignmentMenuItem_actionPerformed(ActionEvent e)\r
   {\r
-    if(viewport.getSelection().size()<2)\r
-      JOptionPane.showMessageDialog(this, "You must select at least 2 sequences.", "Invalid Selection", JOptionPane.WARNING_MESSAGE);\r
+    if(viewport.getSelectionGroup().getSize()<2)\r
+      JOptionPane.showInternalMessageDialog(this, "You must select at least 2 sequences.", "Invalid Selection", JOptionPane.WARNING_MESSAGE);\r
     else\r
     {\r
       JInternalFrame frame = new JInternalFrame();\r
@@ -625,10 +993,11 @@ public class AlignFrame extends GAlignFrame
 \r
   public void PCAMenuItem_actionPerformed(ActionEvent e)\r
   {\r
-    if( (viewport.getSelection().size()<4 && viewport.getSelection().size()>0)\r
+\r
+    if( (viewport.getSelectionGroup()!=null && viewport.getSelectionGroup().getSize()<4 && viewport.getSelectionGroup().getSize()>0)\r
        || viewport.getAlignment().getHeight()<4)\r
     {\r
-      JOptionPane.showMessageDialog(this, "Principal component analysis must take\n"\r
+      JOptionPane.showInternalMessageDialog(this, "Principal component analysis must take\n"\r
                                     +"at least 4 input sequences.",\r
                                     "Sequence selection insufficient",\r
                                     JOptionPane.WARNING_MESSAGE);\r
@@ -642,7 +1011,7 @@ public class AlignFrame extends GAlignFrame
       Desktop.addInternalFrame(frame, "Principal component analysis", 400, 400);\r
    }catch(java.lang.OutOfMemoryError ex)\r
    {\r
-     JOptionPane.showMessageDialog(this, "Too many sequences selected\nfor Principal Component Analysis!!",\r
+     JOptionPane.showInternalMessageDialog(this, "Too many sequences selected\nfor Principal Component Analysis!!",\r
                                    "Out of memory", JOptionPane.WARNING_MESSAGE);\r
    }\r
 \r
@@ -672,62 +1041,191 @@ public class AlignFrame extends GAlignFrame
 \r
   void NewTreePanel(String type, String pwType, String title)\r
   {\r
-    JInternalFrame frame = new javax.swing.JInternalFrame();\r
-    TreePanel tp=null;\r
-   if (viewport.getSelection() != null && viewport.getSelection().size() > 3)\r
-   {\r
-     tp = new TreePanel(viewport, viewport.getSelection().asVector(),type, pwType,\r
-                         viewport.getStartRes(), viewport.getEndRes());\r
-   }\r
-   else\r
-   {\r
-     tp = new TreePanel(viewport, viewport.getAlignment().getSequences(),\r
-                         type, pwType, viewport.getStartRes(),\r
-                         viewport.getEndRes());\r
-   }\r
+    //are the sequences aligned?\r
+    if(!viewport.alignment.isAligned())\r
+    {\r
+      JOptionPane.showMessageDialog(Desktop.desktop, "The sequences must be aligned before creating a tree.",\r
+                                    "Sequences not aligned", JOptionPane.WARNING_MESSAGE);\r
+      return;\r
+    }\r
 \r
-   frame.setContentPane(tp);\r
-   Desktop.addInternalFrame(frame, title, 600, 500);\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
+   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.repaint();\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
   {\r
-    JOptionPane.showMessageDialog(this, "Jalview is currently being reengineered"\r
-                                  +"\nwithin the Barton Group, Dundee University."\r
-                                  +"\nThis will be available as a web service 2005",\r
-                                  "Web service", JOptionPane.INFORMATION_MESSAGE);\r
+     WebserviceInfo info = new WebserviceInfo("Clustal web service",\r
+     "\"Thompson, J.D., Higgins, D.G. and Gibson, T.J. (1994) CLUSTAL W: improving the sensitivity of progressive multiple"+\r
+     " sequence alignment through sequence weighting, position specific gap penalties and weight matrix choice."\r
+    +" Nucleic Acids Research, submitted, June 1994.",\r
+     450, 150);\r
+\r
+    ClustalThread thread = new ClustalThread(info);\r
+    thread.start();\r
   }\r
 \r
-  public void pdbTest_actionPerformed(ActionEvent e)\r
-  {\r
-   String reply = JOptionPane.showInputDialog(this, "Enter pdb code", "PDB test viewer", JOptionPane.QUESTION_MESSAGE);\r
+    class ClustalThread extends Thread\r
+    {\r
+      WebserviceInfo info;\r
+      public ClustalThread(WebserviceInfo info)\r
+      {this.info = info; }\r
 \r
-   String url = "http://www.ebi.ac.uk/cgi-bin/pdbfetch?id=1a4u";\r
-   if (reply.length()>1)\r
-     url = "http://www.ebi.ac.uk/cgi-bin/pdbfetch?id="+reply;\r
+      public void run()\r
+      {\r
+        info.setStatus(WebserviceInfo.STATE_RUNNING);\r
+        jalview.ws.Jemboss jemboss = new jalview.ws.Jemboss();\r
+        Vector sv = viewport.getAlignment().getSequences();\r
+        SequenceI[] seqs = new SequenceI[sv.size()];\r
 \r
-   try\r
-   {\r
-     PDBfile pdb = new PDBfile(url,\r
-                               "URL");\r
-    Sequence seq = (Sequence)viewport.getAlignment().getSequenceAt(0);\r
-    seq.setPDBfile(pdb);\r
-     ( (PDBChain) pdb.chains.elementAt(seq.maxchain)).isVisible = true;\r
-     ( (PDBChain) pdb.chains.elementAt(seq.maxchain)).sequence = seq;\r
-  // ( (PDBChain) pdb.chains.elementAt(seq.maxchain)).colourBySequence();\r
-\r
-     rotCanvas rc = new rotCanvas(pdb);\r
-     JInternalFrame frame = new JInternalFrame();\r
-     frame.setContentPane(rc);\r
-     Desktop.addInternalFrame(frame, url, 400,400);\r
-   }\r
-   catch (Exception ex)\r
-   {\r
-     ex.printStackTrace();\r
-   }\r
+        int i = 0;\r
+        do\r
+        {\r
+          seqs[i] = (SequenceI) sv.elementAt(i);\r
+        }\r
+        while (++i < sv.size());\r
+\r
+        SequenceI[] alignment = jemboss.clustalW(seqs); // gaps removed within method\r
+        if (alignment != null)\r
+        {\r
+          AlignFrame af = new AlignFrame(new Alignment(alignment));\r
+          Desktop.addInternalFrame(af, title.concat(" - ClustalW Alignment"),\r
+                                   NEW_WINDOW_WIDTH, NEW_WINDOW_HEIGHT);\r
+          af.clustalColour_actionPerformed(null);\r
+          af.clustalColour.setSelected(true);\r
+          info.setStatus(WebserviceInfo.STATE_STOPPED_OK);\r
+        }\r
+        else\r
+        {\r
+            info.setStatus(WebserviceInfo.STATE_STOPPED_ERROR);\r
+            info.appendProgressText("Problem obtaining clustal alignment");\r
+        }\r
+      }\r
+    }\r
+\r
+  protected void jpred_actionPerformed(ActionEvent e)\r
+{\r
+\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)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
+          addTreeMenuItem(tp, title);\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