X-Git-Url: http://source.jalview.org/gitweb/?a=blobdiff_plain;f=src%2Fjalview%2Fgui%2FAlignFrame.java;h=b6e0f7018fa0317e95194cad9786eaa31812587e;hb=e6c50ddb6fedc9917c9fbe112750680feb42cd12;hp=b281767cccb65d502338fe9ef8ec9e67eb8f8429;hpb=7bc226b58110fa26d9dbd3f0c78095d06909ffc3;p=jalview.git diff --git a/src/jalview/gui/AlignFrame.java b/src/jalview/gui/AlignFrame.java index b281767..b6e0f70 100755 --- a/src/jalview/gui/AlignFrame.java +++ b/src/jalview/gui/AlignFrame.java @@ -28,6 +28,7 @@ import java.awt.dnd.*; import java.awt.event.*; import java.awt.print.*; import javax.swing.*; +import javax.swing.event.MenuEvent; import jalview.analysis.*; import jalview.commands.*; @@ -57,11 +58,17 @@ public class AlignFrame Vector alignPanels = new Vector(); - /** DOCUMENT ME!! */ - String currentFileFormat = null; + /** + * Last format used to load or save alignments in this window + */ + String currentFileFormat = null; + /** + * Current filename for this alignment + */ String fileName = null; + /** * Creates a new AlignFrame object. * @@ -72,6 +79,7 @@ public class AlignFrame this(al, null, width, height); } + /** * new alignment window with hidden columns * @param al AlignmentI @@ -85,7 +93,7 @@ public class AlignFrame alignPanel = new AlignmentPanel(this, viewport); - if (al.getDataset() == null) + if(al.getDataset()==null) { al.setDataset(null); } @@ -109,16 +117,14 @@ public class AlignFrame void init() { - this.setDropTarget(new java.awt.dnd.DropTarget(this, this)); - if (viewport.conservation == null) { BLOSUM62Colour.setEnabled(false); conservationMenuItem.setEnabled(false); modifyConservation.setEnabled(false); - // PIDColour.setEnabled(false); - // abovePIDThreshold.setEnabled(false); - // modifyPID.setEnabled(false); + // PIDColour.setEnabled(false); + // abovePIDThreshold.setEnabled(false); + // modifyPID.setEnabled(false); } String sortby = jalview.bin.Cache.getDefault("SORT_ALIGNMENT", "No sort"); @@ -133,247 +139,277 @@ public class AlignFrame } if (Desktop.desktop != null) - { - addServiceListeners(); - setGUINucleotide(viewport.alignment.isNucleotide()); - } - - setMenusFromViewport(viewport); + { + this.setDropTarget(new java.awt.dnd.DropTarget(this, this)); + addServiceListeners(); + setGUINucleotide(viewport.alignment.isNucleotide()); + } + + setMenusFromViewport(viewport); + buildSortByAnnotationScoresMenu(); + if (viewport.wrapAlignment) + { + wrapMenuItem_actionPerformed(null); + } - if (viewport.wrapAlignment) + if (jalview.bin.Cache.getDefault("SHOW_OVERVIEW",false)) { - wrapMenuItem_actionPerformed(null); + this.overviewMenuItem_actionPerformed(null); } - addKeyListener(); + addKeyListener(); } - + /** + * Change the filename and format for the alignment, and + * enable the 'reload' button functionality. + * @param file valid filename + * @param format format of file + */ public void setFileName(String file, String format) { - fileName = file; - currentFileFormat = format; - reload.setEnabled(true); + fileName = file; + currentFileFormat = format; + reload.setEnabled(true); } void addKeyListener() { - addKeyListener(new KeyAdapter() - { - public void keyPressed(KeyEvent evt) + addKeyListener(new KeyAdapter() { - if (viewport.cursorMode - && evt.getKeyCode() >= KeyEvent.VK_0 - && evt.getKeyCode() <= KeyEvent.VK_9) - { - alignPanel.seqPanel.numberPressed(evt.getKeyChar()); - } - - switch (evt.getKeyCode()) + public void keyPressed(KeyEvent evt) { + if (viewport.cursorMode && + ( (evt.getKeyCode() >= KeyEvent.VK_0 && + evt.getKeyCode() <= KeyEvent.VK_9) + || + (evt.getKeyCode() >= KeyEvent.VK_NUMPAD0 && + evt.getKeyCode() <= KeyEvent.VK_NUMPAD9) + ) + && Character.isDigit(evt.getKeyChar())) + alignPanel.seqPanel.numberPressed(evt.getKeyChar()); + + switch (evt.getKeyCode()) + { - case 27: // escape key - deselectAllSequenceMenuItem_actionPerformed(null); + case 27: // escape key + deselectAllSequenceMenuItem_actionPerformed(null); - break; + break; - case KeyEvent.VK_DOWN: - if (viewport.cursorMode) - { - alignPanel.seqPanel.moveCursor(0, 1); - } - else - { + case KeyEvent.VK_DOWN: + if (evt.isAltDown() || !viewport.cursorMode) moveSelectedSequences(false); - } - break; + if (viewport.cursorMode) + alignPanel.seqPanel.moveCursor(0, 1); + break; - case KeyEvent.VK_UP: - if (viewport.cursorMode) - { - alignPanel.seqPanel.moveCursor(0, -1); - } - else - { + case KeyEvent.VK_UP: + if (evt.isAltDown() || !viewport.cursorMode) moveSelectedSequences(true); - } - break; + if (viewport.cursorMode) + alignPanel.seqPanel.moveCursor(0, -1); - case KeyEvent.VK_LEFT: - if (viewport.cursorMode) - { - alignPanel.seqPanel.moveCursor( -1, 0); - } - break; + break; - case KeyEvent.VK_RIGHT: - if (viewport.cursorMode) - { - alignPanel.seqPanel.moveCursor(1, 0); - } - break; + case KeyEvent.VK_LEFT: + if (evt.isAltDown() || !viewport.cursorMode) + slideSequences(false, + alignPanel.seqPanel.getKeyboardNo1()); + else + alignPanel.seqPanel.moveCursor( -1, 0); - case KeyEvent.VK_SPACE: - if (viewport.cursorMode) - { - alignPanel.seqPanel.insertGapAtCursor(evt.isControlDown() - || evt.isShiftDown() - || evt.isAltDown()); - } - break; - case KeyEvent.VK_DELETE: - case KeyEvent.VK_BACK_SPACE: - if (!viewport.cursorMode) - { - cut_actionPerformed(null); - } + break; + + case KeyEvent.VK_RIGHT: + if (evt.isAltDown() || !viewport.cursorMode) + slideSequences(true, + alignPanel.seqPanel.getKeyboardNo1()); else - { - alignPanel.seqPanel.deleteGapAtCursor(evt.isControlDown() - || evt.isShiftDown() - || evt.isAltDown()); - } + alignPanel.seqPanel.moveCursor(1, 0); + break; - break; + case KeyEvent.VK_SPACE: + if (viewport.cursorMode) + { + alignPanel.seqPanel.insertGapAtCursor(evt.isControlDown() + || evt.isShiftDown() + || evt.isAltDown()); + } + break; - case KeyEvent.VK_S: - if (viewport.cursorMode) - { - alignPanel.seqPanel.setCursorRow(); - } - break; - case KeyEvent.VK_C: - if (viewport.cursorMode && !evt.isControlDown()) - { - alignPanel.seqPanel.setCursorColumn(); - } - break; - case KeyEvent.VK_P: - if (viewport.cursorMode) + case KeyEvent.VK_DELETE: + case KeyEvent.VK_BACK_SPACE: + if (!viewport.cursorMode) + { + cut_actionPerformed(null); + } + else { - alignPanel.seqPanel.setCursorPosition(); + alignPanel.seqPanel.deleteGapAtCursor(evt.isControlDown() + || evt.isShiftDown() + || evt.isAltDown()); } - break; - case KeyEvent.VK_ENTER: - case KeyEvent.VK_COMMA: - if (viewport.cursorMode) - { - alignPanel.seqPanel.setCursorRowAndColumn(); - } - break; + break; - case KeyEvent.VK_Q: - if (viewport.cursorMode) - { - alignPanel.seqPanel.setSelectionAreaAtCursor(true); - } - break; - case KeyEvent.VK_M: - if (viewport.cursorMode) - { - alignPanel.seqPanel.setSelectionAreaAtCursor(false); - } - break; + case KeyEvent.VK_S: + if (viewport.cursorMode) + { + alignPanel.seqPanel.setCursorRow(); + } + break; + case KeyEvent.VK_C: + if (viewport.cursorMode && !evt.isControlDown()) + { + alignPanel.seqPanel.setCursorColumn(); + } + break; + case KeyEvent.VK_P: + if (viewport.cursorMode) + { + alignPanel.seqPanel.setCursorPosition(); + } + break; - case KeyEvent.VK_F2: - viewport.cursorMode = !viewport.cursorMode; - statusBar.setText("Keyboard editing mode is " + - (viewport.cursorMode ? "on" : "off")); - if (viewport.cursorMode) - { - alignPanel.seqPanel.seqCanvas.cursorX = viewport.startRes; - alignPanel.seqPanel.seqCanvas.cursorY = viewport.startSeq; - } - alignPanel.seqPanel.seqCanvas.repaint(); - break; + case KeyEvent.VK_ENTER: + case KeyEvent.VK_COMMA: + if (viewport.cursorMode) + { + alignPanel.seqPanel.setCursorRowAndColumn(); + } + break; - case KeyEvent.VK_F1: - try - { - ClassLoader cl = jalview.gui.Desktop.class.getClassLoader(); - java.net.URL url = javax.help.HelpSet.findHelpSet(cl, "help/help"); - javax.help.HelpSet hs = new javax.help.HelpSet(cl, url); + case KeyEvent.VK_Q: + if (viewport.cursorMode) + { + alignPanel.seqPanel.setSelectionAreaAtCursor(true); + } + break; + case KeyEvent.VK_M: + if (viewport.cursorMode) + { + alignPanel.seqPanel.setSelectionAreaAtCursor(false); + } + break; - javax.help.HelpBroker hb = hs.createHelpBroker(); - hb.setCurrentID("home"); - hb.setDisplayed(true); - } - catch (Exception ex) - { - ex.printStackTrace(); - } - break - ; - case KeyEvent.VK_H: - { - boolean toggleSeqs = !evt.isControlDown(); - boolean toggleCols = !evt.isShiftDown(); + case KeyEvent.VK_F2: + viewport.cursorMode = !viewport.cursorMode; + statusBar.setText("Keyboard editing mode is " + + (viewport.cursorMode ? "on" : "off")); + if (viewport.cursorMode) + { + alignPanel.seqPanel.seqCanvas.cursorX = viewport.startRes; + alignPanel.seqPanel.seqCanvas.cursorY = viewport.startSeq; + } + alignPanel.seqPanel.seqCanvas.repaint(); + break; - boolean hide = false; + case KeyEvent.VK_F1: + try + { + ClassLoader cl = jalview.gui.Desktop.class.getClassLoader(); + java.net.URL url = javax.help.HelpSet.findHelpSet(cl, "help/help"); + javax.help.HelpSet hs = new javax.help.HelpSet(cl, url); - SequenceGroup sg = viewport.getSelectionGroup(); - if (toggleSeqs) - { - if (sg != null && sg.getSize() != viewport.alignment.getHeight()) + javax.help.HelpBroker hb = hs.createHelpBroker(); + hb.setCurrentID("home"); + hb.setDisplayed(true); + } + catch (Exception ex) { - hideSelSequences_actionPerformed(null); - hide = true; + ex.printStackTrace(); } + break + ; + case KeyEvent.VK_H: + { + boolean toggleSeqs = !evt.isControlDown(); + boolean toggleCols = !evt.isShiftDown(); + + boolean hide = false; + + SequenceGroup sg = viewport.getSelectionGroup(); + if (toggleSeqs) + { + if (sg != null && sg.getSize() != viewport.alignment.getHeight()) + { + hideSelSequences_actionPerformed(null); + hide = true; + } else if (! (toggleCols && viewport.colSel.getSelected().size() > 0)) { - showAllSeqs_actionPerformed(null); + showAllSeqs_actionPerformed(null); } } - if (toggleCols) - { - if (viewport.colSel.getSelected().size() > 0) + if (toggleCols) { - hideSelColumns_actionPerformed(null); - if (!toggleSeqs) + if (viewport.colSel.getSelected().size() > 0) + { + hideSelColumns_actionPerformed(null); + if (!toggleSeqs) { - viewport.selectionGroup = sg; + viewport.selectionGroup = sg; } } - else if (!hide) + else if (!hide) { - showAllColumns_actionPerformed(null); + showAllColumns_actionPerformed(null); } } - break; - } - case KeyEvent.VK_PAGE_UP: - if (viewport.wrapAlignment) + break; + } + case KeyEvent.VK_PAGE_UP: + if (viewport.wrapAlignment) { - alignPanel.scrollUp(true); + alignPanel.scrollUp(true); } - else + else { - alignPanel.setScrollValues(viewport.startRes, - viewport.startSeq - - viewport.endSeq + viewport.startSeq); + alignPanel.setScrollValues(viewport.startRes, + viewport.startSeq + - viewport.endSeq + viewport.startSeq); } - break; - case KeyEvent.VK_PAGE_DOWN: - if (viewport.wrapAlignment) + break; + case KeyEvent.VK_PAGE_DOWN: + if (viewport.wrapAlignment) { - alignPanel.scrollUp(false); + alignPanel.scrollUp(false); } - else + else { - alignPanel.setScrollValues(viewport.startRes, - viewport.startSeq - + viewport.endSeq - viewport.startSeq); + alignPanel.setScrollValues(viewport.startRes, + viewport.startSeq + + viewport.endSeq - viewport.startSeq); } + break; + } + } + + public void keyReleased(KeyEvent evt) + { + switch(evt.getKeyCode()) + { + case KeyEvent.VK_LEFT: + if (evt.isAltDown() || !viewport.cursorMode) + viewport.firePropertyChange("alignment", null, + viewport.getAlignment().getSequences()); + break; + + case KeyEvent.VK_RIGHT: + if (evt.isAltDown() || !viewport.cursorMode) + viewport.firePropertyChange("alignment", null, + viewport.getAlignment().getSequences()); break; } } - }); + }); } + public void addAlignmentPanel(final AlignmentPanel ap, boolean newPanel) { @@ -385,9 +421,9 @@ public class AlignFrame int aSize = alignPanels.size(); - tabbedPane.setVisible(aSize > 1 || ap.av.viewName != null); + tabbedPane.setVisible(aSize>1 || ap.av.viewName!=null); - if (aSize == 1 && ap.av.viewName == null) + if (aSize == 1 && ap.av.viewName==null) { this.getContentPane().add(ap, BorderLayout.CENTER); } @@ -405,7 +441,7 @@ public class AlignFrame ap.setVisible(false); } - if (newPanel) + if(newPanel) { if (ap.av.padGaps) { @@ -422,10 +458,11 @@ public class AlignFrame gatherViews.setEnabled(true); tabbedPane.setVisible(true); AlignmentPanel first = (AlignmentPanel) alignPanels.firstElement(); - tabbedPane.addTab(first.av.viewName, first); + tabbedPane.addTab(first.av.viewName,first); this.getContentPane().add(tabbedPane, BorderLayout.CENTER); } + public AlignViewport getViewport() { return viewport; @@ -467,17 +504,20 @@ public class AlignFrame public void setGUINucleotide(boolean nucleotide) { - showTranslation.setVisible(nucleotide); - conservationMenuItem.setEnabled(!nucleotide); - modifyConservation.setEnabled(!nucleotide); - + showTranslation.setVisible( nucleotide ); + conservationMenuItem.setEnabled( !nucleotide ); + modifyConservation.setEnabled( !nucleotide ); + //Remember AlignFrame always starts as protein - if (!nucleotide) + if(!nucleotide) { - calculateMenu.remove(calculateMenu.getItemCount() - 2); + calculateMenu.remove(calculateMenu.getItemCount()-2); } + setShowProductsEnabled(); } + + /** * Need to call this method when tabs are selected for multiple views, * or when loading from Jalview2XML.java @@ -510,29 +550,30 @@ public class AlignFrame updateEditMenuBar(); } + Hashtable progressBars; public void setProgressBar(String message, long id) { - if (progressBars == null) + if(progressBars == null) { progressBars = new Hashtable(); } JPanel progressPanel; GridLayout layout = (GridLayout) statusPanel.getLayout(); - if (progressBars.get(new Long(id)) != null) - { - progressPanel = (JPanel) progressBars.get(new Long(id)); - statusPanel.remove(progressPanel); - progressBars.remove(progressPanel); - progressPanel = null; - if (message != null) + if(progressBars.get( new Long(id) )!=null) + { + progressPanel = (JPanel)progressBars.get( new Long(id) ); + statusPanel.remove(progressPanel); + progressBars.remove( progressPanel ); + progressPanel = null; + if(message!=null) { - statusBar.setText(message); + statusBar.setText(message); } - layout.setRows(layout.getRows() - 1); - } + layout.setRows(layout.getRows() - 1); + } else { progressPanel = new JPanel(new BorderLayout(10, 5)); @@ -551,13 +592,24 @@ public class AlignFrame validate(); } - + /** + * + * @return true if any progress bars are still active + */ + public boolean operationInProgress() + { + if (progressBars!=null && progressBars.size()>0) + { + return true; + } + return false; + } /* Added so Castor Mapping file can obtain Jalview Version - */ + */ public String getVersion() { - return jalview.bin.Cache.getProperty("VERSION"); + return jalview.bin.Cache.getProperty("VERSION"); } public FeatureRenderer getFeatureRenderer() @@ -565,6 +617,7 @@ public class AlignFrame return alignPanel.seqPanel.seqCanvas.getFeatureRenderer(); } + public void fetchSequence_actionPerformed(ActionEvent e) { new SequenceFetcher(this); @@ -577,12 +630,12 @@ public class AlignFrame public void reload_actionPerformed(ActionEvent e) { - if (fileName != null) + if(fileName!=null) { - if (currentFileFormat.equals("Jalview")) + if(currentFileFormat.equals("Jalview")) { - JInternalFrame[] frames = Desktop.desktop.getAllFrames(); - for (int i = 0; i < frames.length; i++) + JInternalFrame [] frames = Desktop.desktop.getAllFrames(); + for(int i=0; i-1) + { + currentFileFormat = currentFileFormat.substring(0, currentFileFormat.indexOf(" ")); + } saveAlignment(fileName, currentFileFormat); } } @@ -705,8 +765,8 @@ public class AlignFrame success = new Jalview2XML().SaveAlignment(this, file, shortName); statusBar.setText("Successfully saved to file: " - + fileName + " in " - + format + " format."); + +fileName+" in " + +format +" format."); } else @@ -725,13 +785,14 @@ public class AlignFrame if (reply == JOptionPane.YES_OPTION) { omitHidden = viewport.getViewAsString(false); - } } + } + FormatAdapter f = new FormatAdapter(); - String output = new FormatAdapter().formatSequences( + String output = f.formatSequences( format, - viewport.alignment.getSequencesArray(), - omitHidden); + (Alignment) viewport.alignment, // class cast exceptions will occur in the distant future + omitHidden, f.getCacheSuffixDefault(format), viewport.colSel); if (output == null) { @@ -777,17 +838,17 @@ public class AlignFrame */ protected void outputText_actionPerformed(ActionEvent e) { - String[] omitHidden = null; + String [] omitHidden = null; - if (viewport.hasHiddenColumns) + if(viewport.hasHiddenColumns) { int reply = JOptionPane.showInternalConfirmDialog(Desktop.desktop, "The Alignment contains hidden columns." - + "\nDo you want to output only the visible alignment?", - "Save / Omit Hidden Columns", - JOptionPane.YES_NO_OPTION, JOptionPane.QUESTION_MESSAGE); + +"\nDo you want to output only the visible alignment?", + "Save / Omit Hidden Columns", + JOptionPane.YES_NO_OPTION, JOptionPane.QUESTION_MESSAGE); - if (reply == JOptionPane.YES_OPTION) + if(reply==JOptionPane.YES_OPTION) { omitHidden = viewport.getViewAsString(false); } @@ -799,10 +860,11 @@ public class AlignFrame "Alignment output - " + e.getActionCommand(), 600, 500); + cap.setText(new FormatAdapter().formatSequences( e.getActionCommand(), - viewport.alignment.getSequencesArray(), - omitHidden)); + viewport.alignment, + omitHidden, viewport.colSel)); } /** @@ -812,9 +874,9 @@ public class AlignFrame */ protected void htmlMenuItem_actionPerformed(ActionEvent e) { - new HTMLOutput(viewport, + new HTMLOutput(alignPanel, alignPanel.seqPanel.seqCanvas.getSequenceRenderer(), - alignPanel.seqPanel.seqCanvas.getFeatureRenderer()); + alignPanel.seqPanel.seqCanvas.getFeatureRenderer()); } public void createImageMap(File file, String image) @@ -842,6 +904,7 @@ public class AlignFrame alignPanel.makeEPS(f); } + public void pageSetup_actionPerformed(ActionEvent e) { PrinterJob printJob = PrinterJob.getPrinterJob(); @@ -865,15 +928,18 @@ public class AlignFrame new AnnotationExporter().exportFeatures(alignPanel); } + public void exportAnnotations_actionPerformed(ActionEvent e) { new AnnotationExporter().exportAnnotations( - alignPanel, + alignPanel, viewport.showAnnotation ? viewport.alignment.getAlignmentAnnotation() : null, - viewport.alignment.getGroups() + viewport.alignment.getGroups(), + ((Alignment)viewport.alignment).alignmentProperties ); } + public void associatedData_actionPerformed(ActionEvent e) { // Pick the tree file @@ -895,6 +961,7 @@ public class AlignFrame } + /** * DOCUMENT ME! * @@ -902,23 +969,26 @@ public class AlignFrame */ public void closeMenuItem_actionPerformed(boolean closeAllTabs) { - if (alignPanels != null && alignPanels.size() < 2) + if(alignPanels!=null && alignPanels.size()<2) { closeAllTabs = true; } try { - if (alignPanels != null) + if(alignPanels!=null) { if (closeAllTabs) { for (int i = 0; i < alignPanels.size(); i++) { AlignmentPanel ap = (AlignmentPanel) alignPanels.elementAt(i); + jalview.structure.StructureSelectionManager.getStructureSelectionManager() + .removeStructureViewerListener(ap.seqPanel, null); PaintRefresher.RemoveComponent(ap.seqPanel.seqCanvas); PaintRefresher.RemoveComponent(ap.idPanel.idCanvas); PaintRefresher.RemoveComponent(ap); + ap.av.alignment = null; } } else @@ -929,15 +999,16 @@ public class AlignFrame PaintRefresher.RemoveComponent(alignPanel.seqPanel.seqCanvas); PaintRefresher.RemoveComponent(alignPanel.idPanel.idCanvas); PaintRefresher.RemoveComponent(alignPanel); + viewport.alignment = null; alignPanel = null; viewport = null; tabbedPane.removeTabAt(index); tabbedPane.validate(); - if (index == tabbedPane.getTabCount()) + if(index==tabbedPane.getTabCount()) { - index--; + index --; } this.tabSelectionChanged(index); @@ -947,7 +1018,7 @@ public class AlignFrame if (closeAllTabs) { this.setClosed(true); - } + } } catch (Exception ex) { @@ -955,6 +1026,7 @@ public class AlignFrame } } + /** * DOCUMENT ME! */ @@ -987,9 +1059,10 @@ public class AlignFrame } } + public void addHistoryItem(CommandI command) { - if (command.getSize() > 0) + if(command.getSize()>0) { viewport.historyList.push(command); viewport.redoList.clear(); @@ -999,20 +1072,44 @@ public class AlignFrame } /** + * + * @return alignment objects for all views + */ + AlignmentI[] getViewAlignments() + { + if (alignPanels!=null) + { + Enumeration e = alignPanels.elements(); + AlignmentI[] als = new AlignmentI[alignPanels.size()]; + for (int i=0; e.hasMoreElements(); i++) + { + als[i] = ((AlignmentPanel) e.nextElement()).av.getAlignment(); + } + return als; + } + if (viewport!=null) + { + return new AlignmentI[] { viewport.alignment }; + } + return null; + } + /** * DOCUMENT ME! * * @param e DOCUMENT ME! */ protected void undoMenuItem_actionPerformed(ActionEvent e) { - CommandI command = (CommandI) viewport.historyList.pop(); + if (viewport.historyList.empty()) + return; + CommandI command = (CommandI)viewport.historyList.pop(); viewport.redoList.push(command); - command.undoCommand(); + command.undoCommand(getViewAlignments()); AlignViewport originalSource = getOriginatingSource(command); updateEditMenuBar(); - if (originalSource != null) + if(originalSource!=null) { originalSource.hasHiddenColumns = viewport.colSel.getHiddenColumns() != null; originalSource.firePropertyChange("alignment", @@ -1028,19 +1125,19 @@ public class AlignFrame */ protected void redoMenuItem_actionPerformed(ActionEvent e) { - if (viewport.redoList.size() < 1) + if(viewport.redoList.size()<1) { return; } CommandI command = (CommandI) viewport.redoList.pop(); viewport.historyList.push(command); - command.doCommand(); + command.doCommand(getViewAlignments()); AlignViewport originalSource = getOriginatingSource(command); updateEditMenuBar(); - if (originalSource != null) + if(originalSource!=null) { originalSource.hasHiddenColumns = viewport.colSel.getHiddenColumns() != null; originalSource.firePropertyChange("alignment", @@ -1053,9 +1150,9 @@ public class AlignFrame { AlignViewport originalSource = null; //For sequence removal and addition, we need to fire - //the property change event FROM the viewport where the - //original alignment was altered - AlignmentI al = null; + //the property change event FROM the viewport where the + //original alignment was altered + AlignmentI al=null; if (command instanceof EditCommand) { EditCommand editCommand = (EditCommand) command; @@ -1150,9 +1247,102 @@ public class AlignFrame } } - alignPanel.repaint(); + alignPanel.paintAlignment(true); } + + + + synchronized void slideSequences(boolean right, int size) + { + Vector sg = new Vector(); + if(viewport.cursorMode) + { + sg.addElement(viewport.alignment.getSequenceAt( + alignPanel.seqPanel.seqCanvas.cursorY)); + } + else if(viewport.getSelectionGroup()!=null + && viewport.getSelectionGroup().getSize()!=viewport.alignment.getHeight()) + { + sg = viewport.getSelectionGroup().getSequences( + viewport.hiddenRepSequences); + } + + if(sg.size()<1) + { + return; + } + + Vector invertGroup = new Vector(); + + for (int i = 0; i < viewport.alignment.getHeight(); i++) + { + if(!sg.contains(viewport.alignment.getSequenceAt(i))) + invertGroup.add(viewport.alignment.getSequenceAt(i)); + } + + SequenceI[] seqs1 = new SequenceI[sg.size()]; + for (int i = 0; i < sg.size(); i++) + seqs1[i] = (SequenceI) sg.elementAt(i); + + SequenceI[] seqs2 = new SequenceI[invertGroup.size()]; + for (int i = 0; i < invertGroup.size(); i++) + seqs2[i] = (SequenceI) invertGroup.elementAt(i); + + SlideSequencesCommand ssc; + if (right) + ssc = new SlideSequencesCommand("Slide Sequences", + seqs2, seqs1, size, + viewport.getGapCharacter() + ); + else + ssc = new SlideSequencesCommand("Slide Sequences", + seqs1, seqs2, size, + viewport.getGapCharacter() + ); + + int groupAdjustment = 0; + if (ssc.getGapsInsertedBegin() && right) + { + if (viewport.cursorMode) + alignPanel.seqPanel.moveCursor(size, 0); + else + groupAdjustment = size; + } + else if (!ssc.getGapsInsertedBegin() && !right) + { + if (viewport.cursorMode) + alignPanel.seqPanel.moveCursor( -size, 0); + else + groupAdjustment = -size; + } + + if (groupAdjustment != 0) + { + viewport.getSelectionGroup().setStartRes( + viewport.getSelectionGroup().getStartRes() + groupAdjustment); + viewport.getSelectionGroup().setEndRes( + viewport.getSelectionGroup().getEndRes() + groupAdjustment); + } + + + boolean appendHistoryItem = false; + if(viewport.historyList!=null + && viewport.historyList.size()>0 + && viewport.historyList.peek() instanceof SlideSequencesCommand) + { + appendHistoryItem = ssc.appendSlideCommand( + (SlideSequencesCommand)viewport.historyList.peek()) + ; + } + + if(!appendHistoryItem) + addHistoryItem(ssc); + + repaint(); + } + + /** * DOCUMENT ME! * @@ -1165,8 +1355,8 @@ public class AlignFrame { return; } - - SequenceI[] seqs = viewport.getSelectionAsNewSequence(); + // TODO: preserve the ordering of displayed alignment annotation in any internal paste (particularly sequence associated annotation) + SequenceI [] seqs = viewport.getSelectionAsNewSequence(); String[] omitHidden = null; if (viewport.hasHiddenColumns) @@ -1196,25 +1386,25 @@ public class AlignFrame { er.printStackTrace(); javax.swing.SwingUtilities.invokeLater(new Runnable() - { - public void run() - { - javax.swing.JOptionPane.showInternalMessageDialog(Desktop.desktop, - "Out of memory copying region!!" - + - "\nSee help files for increasing Java Virtual Machine memory." - , "Out of memory", - javax.swing.JOptionPane.WARNING_MESSAGE); - } - }); + { + public void run() + { + javax.swing.JOptionPane.showInternalMessageDialog(Desktop.desktop, + "Out of memory copying region!!" + + + "\nSee help files for increasing Java Virtual Machine memory." + , "Out of memory", + javax.swing.JOptionPane.WARNING_MESSAGE); + } + }); return; } Vector hiddenColumns = null; - if (viewport.hasHiddenColumns) + if(viewport.hasHiddenColumns) { - hiddenColumns = new Vector(); + hiddenColumns =new Vector(); int hiddenOffset = viewport.getSelectionGroup().getStartRes(); for (int i = 0; i < viewport.getColumnSelection().getHiddenColumns().size(); i++) @@ -1224,7 +1414,7 @@ public class AlignFrame hiddenColumns.addElement(new int[] {region[0] - hiddenOffset, - region[1] - hiddenOffset}); + region[1]-hiddenOffset}); } } @@ -1233,7 +1423,7 @@ public class AlignFrame seqs, viewport.alignment.getDataset(), hiddenColumns}; - statusBar.setText("Copied " + seqs.length + " sequences to clipboard."); + statusBar.setText("Copied "+seqs.length+" sequences to clipboard."); } /** @@ -1257,12 +1447,13 @@ public class AlignFrame } /** - * DOCUMENT ME! + * Paste contents of Jalview clipboard * - * @param newAlignment DOCUMENT ME! + * @param newAlignment true to paste to a new alignment, otherwise add to this. */ void paste(boolean newAlignment) { + boolean externalPaste=true; try { Clipboard c = Toolkit.getDefaultToolkit().getSystemClipboard(); @@ -1305,137 +1496,222 @@ public class AlignFrame } SequenceI[] sequences; - - if (Desktop.jalviewClipboard != null) - { - // The clipboard was filled from within Jalview, we must use the sequences - // And dataset from the copied alignment - sequences = (SequenceI[]) Desktop.jalviewClipboard[0]; - } - else - { - sequences = new FormatAdapter().readFile(str, "Paste", format). - getSequencesArray(); - } - + boolean annotationAdded = false; AlignmentI alignment = null; - if (newAlignment) - { - alignment = new Alignment(sequences); - - if (Desktop.jalviewClipboard != null) - { - alignment.setDataset( (Alignment) Desktop.jalviewClipboard[1]); - } - else - { - alignment.setDataset(null); - } - } - else - { - alignment = viewport.getAlignment(); - - //!newAlignment - SequenceI[] newseqs = new SequenceI[sequences.length]; - for (int i = 0; i < sequences.length; i++) - { - newseqs[i] = new Sequence(sequences[i].getName(), - sequences[i].getSequence(), - sequences[i].getStart(), - sequences[i].getEnd()); - - alignment.addSequence(newseqs[i]); - } - - /* - //ADD HISTORY ITEM - */ - addHistoryItem(new EditCommand( - "Add sequences", - EditCommand.PASTE, - newseqs, - 0, - alignment.getWidth(), - alignment) - ); + if(Desktop.jalviewClipboard!=null) + { + // The clipboard was filled from within Jalview, we must use the sequences + // And dataset from the copied alignment + SequenceI[] newseq = (SequenceI[])Desktop.jalviewClipboard[0]; + // be doubly sure that we create *new* sequence objects. + sequences = new SequenceI[newseq.length]; + for (int i=0;i>>This is a fix for the moment, until a better solution is found!!<<< - af.alignPanel.seqPanel.seqCanvas.getFeatureRenderer().transferSettings( - alignPanel.seqPanel.seqCanvas.getFeatureRenderer()); - - if (title.startsWith("Copied sequences")) + if (newDs != null) { - newtitle = title; + newDs.clear(); // tidy up } - else - { - newtitle = newtitle.concat("- from " + title); + if (pastedal.getAlignmentAnnotation()!=null) { + // Add any annotation attached to alignment. + AlignmentAnnotation[] alann = pastedal.getAlignmentAnnotation(); + for (int i=0; i>>This is a fix for the moment, until a better solution is found!!<<< + af.alignPanel.seqPanel.seqCanvas.getFeatureRenderer().transferSettings( + alignPanel.seqPanel.seqCanvas.getFeatureRenderer()); + + // TODO: maintain provenance of an alignment, rather than just make the title a concatenation of operations. + if (!externalPaste) { + if (title.startsWith("Copied sequences")) + { + newtitle = title; + } + else + { + newtitle = newtitle.concat("- from " + title); + } + } else { + newtitle = new String("Pasted sequences"); + } + + Desktop.addInternalFrame(af, newtitle, DEFAULT_WIDTH, + DEFAULT_HEIGHT); - Desktop.addInternalFrame(af, newtitle, DEFAULT_WIDTH, - DEFAULT_HEIGHT); + } - } } catch (Exception ex) { ex.printStackTrace(); - System.out.println("Exception whilst pasting: " + ex); - // could be anything being pasted in here + System.out.println("Exception whilst pasting: "+ex); + // could be anything being pasted in here } + } /** @@ -1471,34 +1747,38 @@ public class AlignFrame seqs.addElement(seq); } - // If the cut affects all sequences, remove highlighted columns - if (sg.getSize() == viewport.alignment.getHeight()) - { - viewport.getColumnSelection().removeElements(sg.getStartRes(), - sg.getEndRes() + 1); - } - SequenceI[] cut = new SequenceI[seqs.size()]; - for (int i = 0; i < seqs.size(); i++) + // If the cut affects all sequences, remove highlighted columns + if (sg.getSize() == viewport.alignment.getHeight()) + { + viewport.getColumnSelection().removeElements(sg.getStartRes(), + sg.getEndRes() + 1); + } + + + SequenceI [] cut = new SequenceI[seqs.size()]; + for(int i=0; i 0) { - if (trimLeft) + if(trimLeft) { column = colSel.getMin(); } @@ -1637,8 +1918,8 @@ public class AlignFrame column = colSel.getMax(); } - SequenceI[] seqs; - if (viewport.getSelectionGroup() != null) + SequenceI [] seqs; + if(viewport.getSelectionGroup()!=null) { seqs = viewport.getSelectionGroup().getSequencesAsArray(viewport. hiddenRepSequences); @@ -1648,30 +1929,32 @@ public class AlignFrame seqs = viewport.alignment.getSequencesArray(); } + TrimRegionCommand trimRegion; - if (trimLeft) + if(trimLeft) { trimRegion = new TrimRegionCommand("Remove Left", - TrimRegionCommand.TRIM_LEFT, - seqs, - column, - viewport.alignment, - viewport.colSel, - viewport.selectionGroup); + TrimRegionCommand.TRIM_LEFT, + seqs, + column, + viewport.alignment, + viewport.colSel, + viewport.selectionGroup); viewport.setStartRes(0); } - else - { - trimRegion = new TrimRegionCommand("Remove Right", - TrimRegionCommand.TRIM_RIGHT, - seqs, - column, - viewport.alignment, - viewport.colSel, - viewport.selectionGroup); - } + else + { + trimRegion = new TrimRegionCommand("Remove Right", + TrimRegionCommand.TRIM_RIGHT, + seqs, + column, + viewport.alignment, + viewport.colSel, + viewport.selectionGroup); + } + + statusBar.setText("Removed "+trimRegion.getSize()+" columns."); - statusBar.setText("Removed " + trimRegion.getSize() + " columns."); addHistoryItem(trimRegion); @@ -1700,7 +1983,7 @@ public class AlignFrame */ public void removeGappedColumnMenuItem_actionPerformed(ActionEvent e) { - int start = 0, end = viewport.alignment.getWidth() - 1; + int start = 0, end = viewport.alignment.getWidth()-1; SequenceI[] seqs; if (viewport.getSelectionGroup() != null) @@ -1715,6 +1998,7 @@ public class AlignFrame seqs = viewport.alignment.getSequencesArray(); } + RemoveGapColCommand removeGapCols = new RemoveGapColCommand("Remove Gapped Columns", seqs, @@ -1723,18 +2007,18 @@ public class AlignFrame addHistoryItem(removeGapCols); - statusBar.setText("Removed " + removeGapCols.getSize() + " empty columns."); + statusBar.setText("Removed "+removeGapCols.getSize()+" empty columns."); //This is to maintain viewport position on first residue //of first sequence SequenceI seq = viewport.alignment.getSequenceAt(0); int startRes = seq.findPosition(viewport.startRes); - // ShiftList shifts; - // viewport.getAlignment().removeGaps(shifts=new ShiftList()); - // edit.alColumnChanges=shifts.getInverse(); - // if (viewport.hasHiddenColumns) - // viewport.getColumnSelection().compensateForEdits(shifts); - viewport.setStartRes(seq.findIndex(startRes) - 1); + // ShiftList shifts; + // viewport.getAlignment().removeGaps(shifts=new ShiftList()); + // edit.alColumnChanges=shifts.getInverse(); + // if (viewport.hasHiddenColumns) + // viewport.getColumnSelection().compensateForEdits(shifts); + viewport.setStartRes(seq.findIndex(startRes)-1); viewport.firePropertyChange("alignment", null, viewport.getAlignment().getSequences()); @@ -1747,7 +2031,7 @@ public class AlignFrame */ public void removeAllGapsMenuItem_actionPerformed(ActionEvent e) { - int start = 0, end = viewport.alignment.getWidth() - 1; + int start = 0, end = viewport.alignment.getWidth()-1; SequenceI[] seqs; if (viewport.getSelectionGroup() != null) @@ -1772,7 +2056,7 @@ public class AlignFrame start, end, viewport.alignment)); - viewport.setStartRes(seq.findIndex(startRes) - 1); + viewport.setStartRes(seq.findIndex(startRes)-1); viewport.firePropertyChange("alignment", null, viewport.getAlignment().getSequences()); @@ -1808,6 +2092,8 @@ public class AlignFrame AlignmentPanel newap = new Jalview2XML().copyAlignPanel(alignPanel, true); + newap.av.gatherViewsHere = false; + if (viewport.viewName == null) { viewport.viewName = "Original"; @@ -1817,33 +2103,33 @@ public class AlignFrame newap.av.redoList = viewport.redoList; int index = Desktop.getViewCount(viewport.getSequenceSetId()); - String newViewName = "View " + index; + String newViewName = "View " +index; Vector comps = (Vector) PaintRefresher.components.get(viewport. getSequenceSetId()); Vector existingNames = new Vector(); - for (int i = 0; i < comps.size(); i++) + for(int i=0; i"); + + float avg = 0; + int min=Integer.MAX_VALUE, max=0; + for(int i=0; imax) + max = size; + if(sizeSequences: "+ viewport.alignment.getHeight()); + contents.append("
Minimum Sequence Length: "+min); + contents.append("
Maximum Sequence Length: "+max); + contents.append("
Average Length: "+(int)avg); + + if (((Alignment)viewport.alignment).getProperties() != null) + { + Hashtable props = ((Alignment)viewport.alignment).getProperties(); + Enumeration en = props.keys(); + contents.append("

"); + while(en.hasMoreElements()) + { + String key = en.nextElement().toString(); + StringBuffer val = new StringBuffer(); + String vals = props.get(key).toString(); + int pos=0, npos; + do { + npos = vals.indexOf("\n",pos); + if (npos==-1) + { + val.append(vals.substring(pos)); + } else { + val.append(vals.substring(pos, npos)); + val.append("
"); + } + pos = npos+1; + } while (npos!=-1); + contents.append(""); + } + contents.append("
"+key+""+val+"
"); + } + editPane.setText(contents.toString()+""); + JInternalFrame frame = new JInternalFrame(); + frame.getContentPane().add(new JScrollPane(editPane)); + + Desktop.instance.addInternalFrame(frame,"Alignment Properties: "+getTitle(),500,400); + } + + /** * DOCUMENT ME! * @@ -2189,6 +2540,7 @@ public class AlignFrame new AnnotationColourChooser(viewport, alignPanel); } + /** * DOCUMENT ME! * @@ -2208,12 +2560,12 @@ public class AlignFrame { int threshold = 0; - if (cs != null) + if(cs!=null) { if (viewport.getAbovePIDThreshold()) { threshold = SliderPanel.setPIDSliderSource(alignPanel, cs, - "Background"); + "Background"); cs.setThreshold(threshold, viewport.getIgnoreGapsConsensus()); @@ -2290,18 +2642,19 @@ public class AlignFrame || cs instanceof PIDColourScheme || cs instanceof Blosum62ColourScheme) { - sg.cs.setThreshold(threshold, - viewport.getIgnoreGapsConsensus()); + sg.cs.setThreshold(threshold, + viewport.getIgnoreGapsConsensus()); - sg.cs.setConsensus(AAFrequency.calculate( - sg.getSequences(viewport.hiddenRepSequences), sg.getStartRes(), - sg.getEndRes() + 1)); - } + sg.cs.setConsensus(AAFrequency.calculate( + sg.getSequences(viewport.hiddenRepSequences), sg.getStartRes(), + sg.getEndRes()+1)); + } else { sg.cs.setThreshold(0, viewport.getIgnoreGapsConsensus()); } + if (viewport.getConservationSelected()) { Conservation c = new Conservation("Group", @@ -2309,7 +2662,7 @@ public class AlignFrame sg.getSequences(viewport. hiddenRepSequences), sg.getStartRes(), - sg.getEndRes() + 1); + sg.getEndRes()+1); c.calculate(); c.verdict(false, viewport.ConsPercGaps); sg.cs.setConservation(c); @@ -2317,16 +2670,19 @@ public class AlignFrame else { sg.cs.setConservation(null); - } } } + } if (alignPanel.getOverviewPanel() != null) { alignPanel.getOverviewPanel().updateOverviewImage(); } - alignPanel.repaint(); + + + + alignPanel.paintAlignment(true); } /** @@ -2336,7 +2692,7 @@ public class AlignFrame */ protected void modifyPID_actionPerformed(ActionEvent e) { - if (viewport.getAbovePIDThreshold() && viewport.globalColourScheme != null) + if (viewport.getAbovePIDThreshold() && viewport.globalColourScheme!=null) { SliderPanel.setPIDSliderSource(alignPanel, viewport.getGlobalColourScheme(), @@ -2352,7 +2708,7 @@ public class AlignFrame */ protected void modifyConservation_actionPerformed(ActionEvent e) { - if (viewport.getConservationSelected() && viewport.globalColourScheme != null) + if (viewport.getConservationSelected() && viewport.globalColourScheme!=null) { SliderPanel.setConservationSlider(alignPanel, viewport.globalColourScheme, @@ -2441,37 +2797,37 @@ public class AlignFrame nextElement().toString()); radioItem.setName("USER_DEFINED"); radioItem.addMouseListener(new MouseAdapter() - { - public void mousePressed(MouseEvent evt) - { - if (evt.isControlDown() || SwingUtilities.isRightMouseButton(evt)) { - radioItem.removeActionListener(radioItem.getActionListeners()[0]); + public void mousePressed(MouseEvent evt) + { + if(evt.isControlDown() || SwingUtilities.isRightMouseButton(evt)) + { + radioItem.removeActionListener(radioItem.getActionListeners()[0]); int option = JOptionPane.showInternalConfirmDialog(jalview.gui. Desktop.desktop, - "Remove from default list?", - "Remove user defined colour", - JOptionPane.YES_NO_OPTION); - if (option == JOptionPane.YES_OPTION) - { + "Remove from default list?", + "Remove user defined colour", + JOptionPane.YES_NO_OPTION); + if(option == JOptionPane.YES_OPTION) + { jalview.gui.UserDefinedColours.removeColourFromDefaults( radioItem.getText()); - colourMenu.remove(radioItem); - } - else - { - radioItem.addActionListener(new ActionListener() - { - public void actionPerformed(ActionEvent evt) - { - userDefinedColour_actionPerformed(evt); + colourMenu.remove(radioItem); } - }); + else + { + radioItem.addActionListener(new ActionListener() + { + public void actionPerformed(ActionEvent evt) + { + userDefinedColour_actionPerformed(evt); + } + }); + } } - } } - }); + }); radioItem.addActionListener(new ActionListener() { public void actionPerformed(ActionEvent evt) @@ -2513,12 +2869,12 @@ public class AlignFrame */ public void sortPairwiseMenuItem_actionPerformed(ActionEvent e) { - SequenceI[] oldOrder = viewport.getAlignment().getSequencesArray(); + SequenceI [] oldOrder = viewport.getAlignment().getSequencesArray(); AlignmentSorter.sortByPID(viewport.getAlignment(), - viewport.getAlignment().getSequenceAt(0)); + viewport.getAlignment().getSequenceAt(0), null); addHistoryItem(new OrderCommand("Pairwise Sort", oldOrder, viewport.alignment)); - alignPanel.repaint(); + alignPanel.paintAlignment(true); } /** @@ -2528,10 +2884,10 @@ public class AlignFrame */ public void sortIDMenuItem_actionPerformed(ActionEvent e) { - SequenceI[] oldOrder = viewport.getAlignment().getSequencesArray(); + SequenceI [] oldOrder = viewport.getAlignment().getSequencesArray(); AlignmentSorter.sortByID(viewport.getAlignment()); addHistoryItem(new OrderCommand("ID Sort", oldOrder, viewport.alignment)); - alignPanel.repaint(); + alignPanel.paintAlignment(true); } /** @@ -2541,13 +2897,12 @@ public class AlignFrame */ public void sortGroupMenuItem_actionPerformed(ActionEvent e) { - SequenceI[] oldOrder = viewport.getAlignment().getSequencesArray(); + SequenceI [] oldOrder = viewport.getAlignment().getSequencesArray(); AlignmentSorter.sortByGroup(viewport.getAlignment()); addHistoryItem(new OrderCommand("Group Sort", oldOrder, viewport.alignment)); - alignPanel.repaint(); + alignPanel.paintAlignment(true); } - /** * DOCUMENT ME! * @@ -2558,6 +2913,7 @@ public class AlignFrame new RedundancyPanel(alignPanel, this); } + /** * DOCUMENT ME! * @@ -2602,13 +2958,14 @@ public class AlignFrame return; } - new PCAPanel(alignPanel); + new PCAPanel(alignPanel); } + public void autoCalculate_actionPerformed(ActionEvent e) { viewport.autoCalculateConsensus = autoCalculate.isSelected(); - if (viewport.autoCalculateConsensus) + if(viewport.autoCalculateConsensus) { viewport.firePropertyChange("alignment", null, @@ -2616,6 +2973,7 @@ public class AlignFrame } } + /** * DOCUMENT ME! * @@ -2716,7 +3074,7 @@ public class AlignFrame return; } - if (viewport.alignment.getHeight() < 2) + if(viewport.alignment.getHeight()<2) { return; } @@ -2726,9 +3084,9 @@ public class AlignFrame title += " from "; - if (viewport.viewName != null) + if(viewport.viewName!=null) { - title += viewport.viewName + " of "; + title+= viewport.viewName+" of "; } title += this.title; @@ -2750,7 +3108,7 @@ public class AlignFrame { public void actionPerformed(ActionEvent e) { - SequenceI[] oldOrder = viewport.getAlignment().getSequencesArray(); + SequenceI [] oldOrder = viewport.getAlignment().getSequencesArray(); // TODO: JBPNote - have to map order entries to curent SequenceI pointers AlignmentSorter.sortBy(viewport.getAlignment(), order); @@ -2758,10 +3116,77 @@ public class AlignFrame addHistoryItem(new OrderCommand(order.getName(), oldOrder, viewport.alignment)); - alignPanel.repaint(); + alignPanel.paintAlignment(true); + } + }); + } + /** + * Add a new sort by annotation score menu item + * @param sort the menu to add the option to + * @param scoreLabel the label used to retrieve scores for each sequence on the alignment + */ + public void addSortByAnnotScoreMenuItem(JMenu sort, final String scoreLabel) + { + final JMenuItem item = new JMenuItem(scoreLabel); + sort.add(item); + item.addActionListener(new java.awt.event.ActionListener() + { + public void actionPerformed(ActionEvent e) + { + SequenceI [] oldOrder = viewport.getAlignment().getSequencesArray(); + AlignmentSorter.sortByAnnotationScore(scoreLabel, viewport.getAlignment());//,viewport.getSelectionGroup()); + addHistoryItem(new OrderCommand("Sort by "+scoreLabel, oldOrder, viewport.alignment)); + alignPanel.paintAlignment(true); } }); } + /** + * last hash for alignment's annotation array - used to minimise cost of rebuild. + */ + protected int _annotationScoreVectorHash; + /** + * search the alignment and rebuild the sort by annotation score submenu + * the last alignment annotation vector hash is stored to minimize + * cost of rebuilding in subsequence calls. + * + */ + public void buildSortByAnnotationScoresMenu() + { + if(viewport.alignment.getAlignmentAnnotation()==null) + { + return; + } + + if (viewport.alignment.getAlignmentAnnotation().hashCode()!=_annotationScoreVectorHash) + { + sortByAnnotScore.removeAll(); + // almost certainly a quicker way to do this - but we keep it simple + Hashtable scoreSorts=new Hashtable(); + AlignmentAnnotation aann[]; + Enumeration sq = viewport.alignment.getSequences().elements(); + while (sq.hasMoreElements()) + { + aann = ((SequenceI) sq.nextElement()).getAnnotation(); + for (int i=0;aann!=null && i0); + scoreSorts.clear(); + + _annotationScoreVectorHash = + viewport.alignment.getAlignmentAnnotation().hashCode(); + } + } /** * Maintain the Order by->Displayed Tree menu. @@ -2780,9 +3205,9 @@ public class AlignFrame getSequenceSetId()); Vector treePanels = new Vector(); int i, iSize = comps.size(); - for (i = 0; i < iSize; i++) + for(i=0; i 1) - { + + if (seqs.size() > 1) + { msa = new SequenceI[seqs.size()]; for (int i = 0; i < seqs.size(); i++) { msa[i] = (SequenceI) seqs.elementAt(i); } - }*/ + }*/ msa = viewport.getAlignmentView(false); } return msa; @@ -2871,7 +3297,7 @@ public class AlignFrame */ AlignmentView gatherSeqOrMsaForSecStrPrediction() { - AlignmentView seqs = null; + AlignmentView seqs = null; if ( (viewport.getSelectionGroup() != null) && (viewport.getSelectionGroup().getSize() > 0)) @@ -2891,7 +3317,6 @@ public class AlignFrame } return seqs; } - /** * DOCUMENT ME! * @@ -2913,33 +3338,41 @@ public class AlignFrame { String choice = chooser.getSelectedFile().getPath(); jalview.bin.Cache.setProperty("LAST_DIRECTORY", choice); - + jalview.io.NewickFile fin = null; try { - jalview.io.NewickFile fin = new jalview.io.NewickFile(choice, + fin = new jalview.io.NewickFile(choice, "File"); viewport.setCurrentTree(ShowNewickTree(fin, choice).getTree()); } catch (Exception ex) { JOptionPane.showMessageDialog(Desktop.desktop, - "Problem reading tree file", ex.getMessage(), + "Problem reading tree file", JOptionPane.WARNING_MESSAGE); ex.printStackTrace(); } + if (fin!=null && fin.hasWarningMessage()) + { + JOptionPane.showMessageDialog(Desktop.desktop, + fin.getWarningMessage(), + "Possible problem with tree file", + JOptionPane.WARNING_MESSAGE); + } } } + public TreePanel ShowNewickTree(NewickFile nf, String title) { - return ShowNewickTree(nf, title, 600, 500, 4, 5); + return ShowNewickTree(nf,title,600,500,4,5); } public TreePanel ShowNewickTree(NewickFile nf, String title, AlignmentView input) { - return ShowNewickTree(nf, title, input, 600, 500, 4, 5); + return ShowNewickTree(nf,title, input, 600,500,4,5); } public TreePanel ShowNewickTree(NewickFile nf, String title, int w, int h, @@ -2947,7 +3380,6 @@ public class AlignFrame { return ShowNewickTree(nf, title, null, w, h, x, y); } - /** * Add a treeviewer for the tree extracted from a newick file object to the current alignment view * @@ -2977,13 +3409,14 @@ public class AlignFrame title, nf, input); - tp.setSize(w, h); + tp.setSize(w,h); - if (x > 0 && y > 0) + if(x>0 && y>0) { - tp.setLocation(x, y); + tp.setLocation(x,y); } + Desktop.addInternalFrame(tp, title, w, h); } } @@ -2991,16 +3424,22 @@ public class AlignFrame { ex.printStackTrace(); } - + return tp; } + /** * Generates menu items and listener event actions for web service clients * */ public void BuildWebServiceMenu() { + // TODO: add support for context dependent disabling of services based on alignment and current selection + // TODO: refactor to allow list of AbstractName/Handler bindings to be stored or retrieved from elsewhere + // TODO: add additional serviceHandle parameter to specify abstract handler class independently of AbstractName + // TODO: add in rediscovery GUI function to restart discoverer + // TODO: group services by location as well as function and/or introduce object broker mechanism. if ( (Discoverer.services != null) && (Discoverer.services.size() > 0)) { @@ -3035,7 +3474,7 @@ public class AlignFrame if (sh.getName().indexOf("lustal") > -1) { // We know that ClustalWS can accept partial alignments for refinement. - final JMenuItem methodR = new JMenuItem(sh.getName() + " Realign"); + final JMenuItem methodR = new JMenuItem(sh.getName()+" Realign"); methodR.addActionListener(new ActionListener() { public void actionPerformed(ActionEvent e) @@ -3080,7 +3519,7 @@ public class AlignFrame { // Sequence profile based prediction new jalview.ws.JPredClient(sh, - title, true, msa, af, true); + title, true, msa, af, true); } } } @@ -3089,7 +3528,7 @@ public class AlignFrame } wsmenu.add(secstrmenu); } - this.webService.removeAll(); + resetWebServiceMenu(); for (int i = 0, j = wsmenu.size(); i < j; i++) { webService.add( (JMenu) wsmenu.get(i)); @@ -3097,175 +3536,289 @@ public class AlignFrame } else { - this.webService.removeAll(); + resetWebServiceMenu(); this.webService.add(this.webServiceNoServices); } - // TODO: add in rediscovery function - // TODO: reduce code redundancy. - // TODO: group services by location as well as function. } - /* public void vamsasStore_actionPerformed(ActionEvent e) - { - JalviewFileChooser chooser = new JalviewFileChooser(jalview.bin.Cache. - getProperty("LAST_DIRECTORY")); - chooser.setFileView(new JalviewFileView()); - chooser.setDialogTitle("Export to Vamsas file"); - chooser.setToolTipText("Export"); + /** + * empty the web service menu and add any ad-hoc functions + * not dynamically discovered. + * + */ + private void resetWebServiceMenu() + { + webService.removeAll(); + // Temporary hack - DBRef Fetcher always top level ws entry. + JMenuItem rfetch = new JMenuItem("Fetch DB References"); + rfetch.setToolTipText("Retrieve and parse uniprot records for the alignment or the currently selected sequences"); + webService.add(rfetch); + rfetch.addActionListener(new ActionListener() { - int value = chooser.showSaveDialog(this); + public void actionPerformed(ActionEvent e) + { + new jalview.ws.DBRefFetcher( + alignPanel.av.getSequenceSelection(), + alignPanel.alignFrame).fetchDBRefs(false); + } - if (value == JalviewFileChooser.APPROVE_OPTION) - { - jalview.io.VamsasDatastore vs = new jalview.io.VamsasDatastore(viewport); - //vs.store(chooser.getSelectedFile().getAbsolutePath() ); - vs.storeJalview( chooser.getSelectedFile().getAbsolutePath(), this); - } - }*/ + }); + } + /* public void vamsasStore_actionPerformed(ActionEvent e) + { + JalviewFileChooser chooser = new JalviewFileChooser(jalview.bin.Cache. + getProperty("LAST_DIRECTORY")); + chooser.setFileView(new JalviewFileView()); + chooser.setDialogTitle("Export to Vamsas file"); + chooser.setToolTipText("Export"); + int value = chooser.showSaveDialog(this); - public void showTranslation_actionPerformed(ActionEvent e) + if (value == JalviewFileChooser.APPROVE_OPTION) + { + jalview.io.VamsasDatastore vs = new jalview.io.VamsasDatastore(viewport); + //vs.store(chooser.getSelectedFile().getAbsolutePath() ); + vs.storeJalview( chooser.getSelectedFile().getAbsolutePath(), this); + } + }*/ + /** + * prototype of an automatically enabled/disabled analysis function + * + */ + protected void setShowProductsEnabled() { - SequenceI[] selection = viewport.getSelectionAsNewSequence(); - String[] seqstring = viewport.getViewAsString(true); - - int s, sSize = selection.length; - SequenceI[] newSeq = new SequenceI[sSize]; + SequenceI [] selection = viewport.getSequenceSelection(); + if (canShowProducts(selection, viewport.getSelectionGroup()!=null, viewport.getAlignment().getDataset())) + { + showProducts.setEnabled(true); + + } else { + showProducts.setEnabled(false); + } + } + /** + * search selection for sequence xRef products and build the + * show products menu. + * @param selection + * @param dataset + * @return true if showProducts menu should be enabled. + */ + public boolean canShowProducts(SequenceI[] selection, boolean isRegionSelection, Alignment dataset) + { + boolean showp=false; + try { + showProducts.removeAll(); + final boolean dna = viewport.getAlignment().isNucleotide(); + final Alignment ds = dataset; + String[] ptypes = CrossRef.findSequenceXrefTypes(dna, selection, dataset); + //Object[] prods = CrossRef.buildXProductsList(viewport.getAlignment().isNucleotide(), selection, dataset, true); + final SequenceI[] sel = selection; + for (int t=0; ptypes!=null && t0) + { + buildSortByAnnotationScoresMenu(); + } + } } class PrintThread @@ -3418,9 +3992,8 @@ class PrintThread AlignmentPanel ap; public PrintThread(AlignmentPanel ap) { - this.ap = ap; + this.ap = ap; } - static PageFormat pf; public void run() {