+\r
+ public TreePanel ShowNewickTree(NewickFile nf, String title)\r
+ {\r
+ return ShowNewickTree(nf,title,600,500,4,5);\r
+ }\r
+ /**\r
+ * DOCUMENT ME!\r
+ *\r
+ * @param nf DOCUMENT ME!\r
+ * @param title DOCUMENT ME!\r
+ *\r
+ * @return DOCUMENT ME!\r
+ */\r
+ public TreePanel ShowNewickTree(NewickFile nf, String title, int w,int h,int x, int y)\r
+ {\r
+ TreePanel tp = null;\r
+\r
+ try\r
+ {\r
+ nf.parse();\r
+\r
+ if (nf.getTree() != null)\r
+ {\r
+ tp = new TreePanel(viewport,\r
+ viewport.getAlignment().getSequences(), nf,\r
+ "FromFile",\r
+ title);\r
+\r
+ tp.setSize(w,h);\r
+\r
+ if(x>0 && y>0)\r
+ tp.setLocation(x,y);\r
+\r
+\r
+ Desktop.addInternalFrame(tp, title, w, h);\r
+ addTreeMenuItem(tp, title);\r
+ }\r
+ }\r
+ catch (Exception ex)\r
+ {\r
+ ex.printStackTrace();\r
+ }\r
+\r
+ return tp;\r
+ }\r
+\r
+ class PrintThread\r
+ extends Thread\r
+ {\r
+ public void run()\r
+ {\r
+ PrinterJob printJob = PrinterJob.getPrinterJob();\r
+ PageFormat pf = printJob.pageDialog(printJob.defaultPage());\r
+ printJob.setPrintable(alignPanel, pf);\r
+\r
+ if (printJob.printDialog())\r
+ {\r
+ try\r
+ {\r
+ printJob.print();\r
+ }\r
+ catch (Exception PrintException)\r
+ {\r
+ PrintException.printStackTrace();\r
+ }\r
+ }\r
+ }\r
+ }\r
+\r
+ /**\r
+ * Generates menu items and listener event actions for web service clients\r
+ *\r
+ */\r
+ public void BuildWebServiceMenu()\r
+ {\r
+ if ( (Discoverer.services != null)\r
+ && (Discoverer.services.size() > 0))\r
+ {\r
+ Vector msaws = (Vector) Discoverer.services.get("MsaWS");\r
+ Vector secstrpr = (Vector) Discoverer.services.get("SecStrPred");\r
+ Vector wsmenu = new Vector();\r
+ if (msaws != null)\r
+ {\r
+ // Add any Multiple Sequence Alignment Services\r
+ final JMenu msawsmenu = new JMenu("Alignment");\r
+ for (int i = 0, j = msaws.size(); i < j; i++)\r
+ {\r
+ final ext.vamsas.ServiceHandle sh = (ext.vamsas.ServiceHandle) msaws.\r
+ get(i);\r
+ final JMenuItem method = new JMenuItem(sh.getName());\r
+ method.addActionListener(new ActionListener()\r
+ {\r
+ public void actionPerformed(ActionEvent e)\r
+ {\r
+ SequenceI[] msa = gatherSequencesForAlignment();\r
+ new jalview.ws.MsaWSClient(sh, title, msa,\r
+ false, true);\r
+\r
+ }\r
+\r
+ });\r
+ msawsmenu.add(method);\r
+ // Deal with services that we know accept partial alignments.\r
+ if (sh.getName().indexOf("lustal") > -1)\r
+ {\r
+ // We know that ClustalWS can accept partial alignments for refinement.\r
+ final JMenuItem methodR = new JMenuItem(sh.getName()+" Realign");\r
+ methodR.addActionListener(new ActionListener()\r
+ {\r
+ public void actionPerformed(ActionEvent e)\r
+ {\r
+ SequenceI[] msa = gatherSequencesForAlignment();\r
+ new jalview.ws.MsaWSClient(sh, title, msa,\r
+ true, true);\r
+\r
+ }\r
+\r
+ });\r
+ msawsmenu.add(methodR);\r
+\r
+ }\r
+ }\r
+ wsmenu.add(msawsmenu);\r
+ }\r
+ if (secstrpr != null)\r
+ {\r
+ // Add any secondary structure prediction services\r
+ final JMenu secstrmenu = new JMenu("Secondary Structure Prediction");\r
+ for (int i = 0, j = secstrpr.size(); i < j; i++)\r
+ {\r
+ final ext.vamsas.ServiceHandle sh = (ext.vamsas.ServiceHandle)\r
+ secstrpr.get(i);\r
+ final JMenuItem method = new JMenuItem(sh.getName());\r
+ method.addActionListener(new ActionListener()\r
+ {\r
+ public void actionPerformed(ActionEvent e)\r
+ {\r
+ SequenceI[] msa = gatherSeqOrMsaForSecStrPrediction();\r
+ if (msa.length == 1)\r
+ {\r
+ // Single Sequence prediction\r
+ new jalview.ws.JPredClient(sh,title, msa[0]);\r
+ }\r
+ else\r
+ {\r
+ if (msa.length > 1)\r
+ {\r
+ // Single Sequence prediction\r
+ jalview.ws.JPredClient ct = new jalview.ws.JPredClient(sh,\r
+ title, msa);\r
+ }\r
+ }\r
+ }\r
+ });\r
+ secstrmenu.add(method);\r
+ }\r
+ wsmenu.add(secstrmenu);\r
+ }\r
+ this.webService.removeAll();\r
+ for (int i = 0, j = wsmenu.size(); i < j; i++)\r
+ {\r
+ webService.add( (JMenu) wsmenu.get(i));\r
+ }\r
+ }\r
+ else\r
+ {\r
+ this.webService.removeAll();\r
+ this.webService.add(this.webServiceNoServices);\r
+ }\r
+ // TODO: add in rediscovery function\r
+ // TODO: reduce code redundancy.\r
+ // TODO: group services by location as well as function.\r
+ }\r
+\r
+ public void vamsasStore_actionPerformed(ActionEvent e)\r
+ {\r
+ JalviewFileChooser chooser = new JalviewFileChooser(jalview.bin.Cache.\r
+ getProperty("LAST_DIRECTORY"));\r
+\r
+ chooser.setFileView(new JalviewFileView());\r
+ chooser.setDialogTitle("Export to Vamsas file");\r
+ chooser.setToolTipText("Export");\r
+\r
+ int value = chooser.showSaveDialog(this);\r
+\r
+ if (value == JalviewFileChooser.APPROVE_OPTION)\r
+ {\r
+ jalview.io.VamsasDatastore vs = new jalview.io.VamsasDatastore(viewport);\r
+ vs.store(chooser.getSelectedFile().getAbsolutePath()\r
+ );\r
+ }\r
+ }\r
+\r
+ public void featureSettings_actionPerformed(ActionEvent e)\r
+ {\r
+ new FeatureSettings(viewport, alignPanel);\r
+ }\r
+\r
+\r
+\r
+public void showTranslation_actionPerformed(ActionEvent e)\r
+{\r
+\r
+ if(!viewport.alignment.isNucleotide())\r
+ return;\r
+\r
+ viewport.showTranslation(showTranslation.isSelected());\r
+\r
+ if(!viewport.alignment.isNucleotide())\r
+ return;\r
+\r
+ int s, sSize = viewport.alignment.getHeight();\r
+ SequenceI [] newSeq = new SequenceI[sSize];\r
+\r
+ int res, resSize;\r
+ StringBuffer protein;\r
+ SequenceI seq;\r
+ for(s=0; s<sSize; s++)\r
+ {\r
+ protein = new StringBuffer();\r
+ seq = (SequenceI)viewport.alignment.getSequenceAt(s);\r
+ resSize = seq.getLength();\r
+ for(res = 0; res < resSize; res+=3)\r
+ {\r
+ String codon = seq.getSequence(res, res+3);\r
+ codon = codon.replace('U', 'T');\r
+ String aa = ResidueProperties.codonTranslate(codon);\r
+ if(aa==null)\r
+ protein.append(viewport.getGapCharacter());\r
+ else if(aa.equals("STOP"))\r
+ protein.append("X");\r
+ else\r
+ protein.append( aa );\r
+ }\r
+ newSeq[s] = new Sequence(seq.getName(), protein.toString());\r
+ }\r
+\r
+\r
+ AlignmentI al = new Alignment(newSeq);\r
+ al.setDataset(null);\r
+\r
+\r
+ ////////////////////////////////\r
+ // Copy annotations across\r
+ jalview.datamodel.AlignmentAnnotation[] annotations\r
+ = viewport.alignment.getAlignmentAnnotation();\r
+ int a, aSize;\r
+ for (int i = 0; i < annotations.length; i++)\r
+ {\r
+\r
+ if (annotations[i].label.equals("Quality") ||\r
+ annotations[i].label.equals("Conservation") ||\r
+ annotations[i].label.equals("Consensus"))\r
+ {\r
+ continue;\r
+ }\r
+\r
+\r
+ aSize = viewport.alignment.getWidth()/3;\r
+ jalview.datamodel.Annotation [] anots =\r
+ new jalview.datamodel.Annotation[aSize];\r
+\r
+ for(a=0; a<viewport.alignment.getWidth(); a++)\r
+ {\r
+ if( annotations[i].annotations[a]==null\r
+ || annotations[i].annotations[a]==null)\r
+ continue;\r
+\r
+ anots[a/3] = new Annotation(\r
+ annotations[i].annotations[a].displayCharacter,\r
+ annotations[i].annotations[a].description,\r
+ annotations[i].annotations[a].secondaryStructure,\r
+ annotations[i].annotations[a].value,\r
+ annotations[i].annotations[a].colour);\r
+ }\r
+\r
+ jalview.datamodel.AlignmentAnnotation aa\r
+ = new jalview.datamodel.AlignmentAnnotation(annotations[i].label,\r
+ annotations[i].description, anots );\r
+ al.addAnnotation(aa);\r
+ }\r
+\r
+\r
+ // Desktop.addInternalFrame(af, "Translation of "+this.getTitle(),\r
+ // NEW_WINDOW_WIDTH,\r
+ // NEW_WINDOW_HEIGHT);\r
+\r
+ AlignViewport newViewport = new AlignViewport(al);\r
+ AlignmentPanel ap = new AlignmentPanel(this, newViewport);\r
+ tabbedPane.add("Protein", ap);\r
+ viewports.add(newViewport);\r
+ alignPanels.add(ap);\r
+\r
+ ///Dataset tab\r
+ /////////////////////////\r
+\r
+ AlignViewport ds = new AlignViewport(al.getDataset());\r
+ ds.setDataset(true);\r
+ AlignmentPanel dap = new AlignmentPanel(this, ds);\r
+ tabbedPane.add("Dataset", dap);\r
+ viewports.add(ds);\r
+ alignPanels.add(dap);\r
+ /////////////////////////\r
+\r
+\r
+}\r
+\r
+public void tabSelected()\r
+{\r
+ int index = tabbedPane.getSelectedIndex();\r
+ viewport = (AlignViewport)viewports.elementAt(index);\r
+ alignPanel = (AlignmentPanel)alignPanels.elementAt(index);\r
+}\r
+\r