X-Git-Url: http://source.jalview.org/gitweb/?a=blobdiff_plain;f=src%2Fjalview%2Fappletgui%2FAlignFrame.java;h=ff7646f76e9b245e38e7ad8b9c187b44033c5538;hb=32a72d077d2371f4566688fbd103103d8505b27f;hp=6586a68f3c3f07bd03428c21ce2188812d8a6bd5;hpb=f84a68869b1864eea585ade8ac36939fd88c8a93;p=jalview.git diff --git a/src/jalview/appletgui/AlignFrame.java b/src/jalview/appletgui/AlignFrame.java index 6586a68..ff7646f 100755 --- a/src/jalview/appletgui/AlignFrame.java +++ b/src/jalview/appletgui/AlignFrame.java @@ -61,6 +61,9 @@ public class AlignFrame extends Frame implements ActionListener, viewport = new AlignViewport(al, applet); alignPanel = new AlignmentPanel(this, viewport); + viewport.updateConservation(alignPanel); + viewport.updateConsensus(alignPanel); + annotationPanelMenuItem.setState(viewport.showAnnotation); seqLimits.setState(viewport.showJVSuffix); @@ -114,17 +117,6 @@ public class AlignFrame extends Frame implements ActionListener, alignPanel.scalePanel.addKeyListener(this); alignPanel.annotationPanel.addKeyListener(this); - viewport.addPropertyChangeListener(new java.beans.PropertyChangeListener() - { - public void propertyChange(java.beans.PropertyChangeEvent evt) - { - if (evt.getPropertyName().equals("alignment")) - { - alignmentChanged(); - } - } - }); - if(embedded) { @@ -475,9 +467,9 @@ public void itemStateChanged(ItemEvent evt) else if(source==invertColSel) { viewport.invertColumnSelection(); alignPanel.repaint(); } else if(source==remove2LeftMenuItem) - remove2LeftMenuItem_actionPerformed(); + trimAlignment(true); else if(source==remove2RightMenuItem) - remove2RightMenuItem_actionPerformed(); + trimAlignment(false); else if(source==removeGappedColumnMenuItem) removeGappedColumnMenuItem_actionPerformed(); else if(source==removeAllGapsMenuItem) @@ -664,27 +656,73 @@ public void itemStateChanged(ItemEvent evt) this.dispose(); } - Stack historyList = new Stack(); - Stack redoList = new Stack(); + /** + * DOCUMENT ME! + */ void updateEditMenuBar() { + + if (viewport.historyList.size() > 0) + { + undoMenuItem.setEnabled(true); + CommandI command = (CommandI) viewport.historyList.peek(); + undoMenuItem.setLabel("Undo " + command.getDescription()); + } + else + { + undoMenuItem.setEnabled(false); + undoMenuItem.setLabel("Undo"); + } + + if (viewport.redoList.size() > 0) + { + redoMenuItem.setEnabled(true); + + CommandI command = (CommandI) viewport.redoList.peek(); + redoMenuItem.setLabel("Redo " + command.getDescription()); + } + else + { + redoMenuItem.setEnabled(false); + redoMenuItem.setLabel("Redo"); + } } + public void addHistoryItem(CommandI command) + { + if(command.getSize()>0) + { + viewport.historyList.push(command); + viewport.redoList.removeAllElements(); + updateEditMenuBar(); + viewport.hasHiddenColumns = viewport.colSel.getHiddenColumns() != null; + } + } protected void undoMenuItem_actionPerformed() { + CommandI command = (CommandI)viewport.historyList.pop(); + viewport.redoList.push(command); + command.undoCommand(); + + viewport.hasHiddenColumns = viewport.colSel.getHiddenColumns() != null; + updateEditMenuBar(); + viewport.firePropertyChange("alignment", null, + viewport.getAlignment().getSequences()); } protected void redoMenuItem_actionPerformed() { + CommandI command = (CommandI) viewport.redoList.pop(); + viewport.historyList.push(command); + command.doCommand(); + viewport.hasHiddenColumns = viewport.colSel.getHiddenColumns()!=null; + updateEditMenuBar(); + viewport.firePropertyChange("alignment", null, viewport.getAlignment().getSequences()); } - // used by undo and redo - void restoreHistoryItem(CommandI command) - { - } public void moveSelectedSequences(boolean up) { @@ -836,8 +874,6 @@ public void itemStateChanged(ItemEvent evt) protected void pasteThis_actionPerformed() { - // addHistoryItem(new HistoryItem("Paste Sequences", viewport.alignment, - // HistoryItem.PASTE)); paste(false); } @@ -857,26 +893,16 @@ public void itemStateChanged(ItemEvent evt) String name = st.nextToken(); int start = Integer.parseInt(st.nextToken()); int end = Integer.parseInt(st.nextToken()); - Sequence sequence = new Sequence(name, st.nextToken(), start, end); - - if (!newAlignment) - { - viewport.alignment.addSequence(sequence); - } - else - { - seqs.addElement(sequence); - } + seqs.addElement(new Sequence(name, st.nextToken(), start, end)); + } + SequenceI[] newSeqs = new SequenceI[seqs.size()]; + for (int i = 0; i < seqs.size(); i++) + { + newSeqs[i] = (SequenceI) seqs.elementAt(i); } if (newAlignment) { - SequenceI[] newSeqs = new SequenceI[seqs.size()]; - for (int i = 0; i < seqs.size(); i++) - { - newSeqs[i] = (SequenceI) seqs.elementAt(i); - } - String newtitle = new String("Copied sequences"); if (getTitle().startsWith("Copied sequences")) { @@ -905,6 +931,16 @@ public void itemStateChanged(ItemEvent evt) } else { + //!newAlignment + addHistoryItem(new EditCommand( + "Add sequences", + EditCommand.PASTE, + newSeqs, + 0, + viewport.alignment.getWidth(), + viewport.alignment) + ); + viewport.setEndSeq(viewport.alignment.getHeight()); viewport.alignment.getWidth(); viewport.firePropertyChange("alignment", null, viewport.getAlignment().getSequences()); @@ -924,62 +960,62 @@ public void itemStateChanged(ItemEvent evt) protected void delete_actionPerformed() { - //addHistoryItem(new HistoryItem("Delete Sequences", viewport.alignment, - // HistoryItem.HIDE)); - if (viewport.getSelectionGroup() == null) + + SequenceGroup sg = viewport.getSelectionGroup(); + if (sg == null) { return; } - - SequenceGroup sg = viewport.getSelectionGroup(); - boolean allSequences = false; - if(sg.getSize(false)==viewport.alignment.getHeight()) - allSequences = true; - + Vector seqs = new Vector(); + SequenceI seq; for (int i = 0; i < sg.getSize(false); i++) { - SequenceI seq = sg.getSequenceAt(i); - int index = viewport.getAlignment().findIndex(seq); - seq.deleteChars(sg.getStartRes(), sg.getEndRes() + 1); + seq = sg.getSequenceAt(i); + seqs.addElement(seq); + } - // If the cut affects all sequences, remove highlighted columns - if (allSequences) - { - viewport.getColumnSelection().removeElements(sg.getStartRes(), - sg.getEndRes() + 1); - } + // If the cut affects all sequences, remove highlighted columns + if (sg.getSize(false) == 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) + column = colSel.getMin(); + else + column = colSel.getMax(); - public void removeGappedColumnMenuItem_actionPerformed() - { - } + SequenceI [] seqs; + if(viewport.getSelectionGroup()!=null) + seqs = viewport.getSelectionGroup().getSequencesAsArray(true); + else + seqs = viewport.alignment.getSequencesArray(); - public void removeAllGapsMenuItem_actionPerformed() - { + + TrimRegionCommand trimRegion; + if(trimLeft) + { + trimRegion = new TrimRegionCommand("Remove Left", + 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); + } + + statusBar.setText("Removed "+trimRegion.getSize()+" columns."); + + + addHistoryItem(trimRegion); + + Vector groups = viewport.alignment.getGroups(); + + for (int i = 0; i < groups.size(); i++) + { + SequenceGroup sg = (SequenceGroup) groups.elementAt(i); + + if ( (trimLeft && !sg.adjustForRemoveLeft(column)) + || (!trimLeft && !sg.adjustForRemoveRight(column))) + { + viewport.alignment.deleteGroup(sg); + } + } + + viewport.firePropertyChange("alignment", null, + viewport.getAlignment().getSequences()); + } } - public void alignmentChanged() + + public void removeGappedColumnMenuItem_actionPerformed() { - viewport.alignment.padGaps(); - if(viewport.autocalculateConsensus) + int start = 0, end = viewport.alignment.getWidth()-1; + + SequenceI[] seqs; + if (viewport.getSelectionGroup() != null) { - viewport.updateConsensus(); - viewport.updateConservation(); + seqs = viewport.getSelectionGroup().getSequencesAsArray(true); + start = viewport.getSelectionGroup().getStartRes(); + end = viewport.getSelectionGroup().getEndRes(); } + else + seqs = viewport.alignment.getSequencesArray(); - resetAllColourSchemes(); - if(alignPanel.overviewPanel!=null) - alignPanel.overviewPanel.updateOverviewImage(); - viewport.alignment.adjustSequenceAnnotations(); - alignPanel.repaint(); + RemoveGapColCommand removeGapCols = + new RemoveGapColCommand("Remove Gapped Columns", + seqs, + start, end, + viewport.getGapCharacter()); + + addHistoryItem(removeGapCols); + + 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); + viewport.firePropertyChange("alignment", null, viewport.getAlignment().getSequences()); + } - void resetAllColourSchemes() + public void removeAllGapsMenuItem_actionPerformed() { - ColourSchemeI cs = viewport.globalColourScheme; - if(cs!=null) + int start = 0, end = viewport.alignment.getWidth()-1; + + SequenceI[] seqs; + if (viewport.getSelectionGroup() != null) { - if (cs instanceof ClustalxColourScheme) - { - ( (ClustalxColourScheme) viewport.getGlobalColourScheme()). - resetClustalX(viewport.alignment.getSequences(), - viewport.alignment.getWidth()); - } + seqs = viewport.getSelectionGroup().getSequencesAsArray(true); + start = viewport.getSelectionGroup().getStartRes(); + end = viewport.getSelectionGroup().getEndRes(); + } + else + seqs = viewport.alignment.getSequencesArray(); - cs.setConsensus(viewport.hconsensus); - if (cs.conservationApplied()) - { - Alignment al = (Alignment) viewport.alignment; - Conservation c = new Conservation("All", - ResidueProperties.propHash, 3, - al.getSequences(), 0, - al.getWidth() - 1); - c.calculate(); - c.verdict(false, viewport.ConsPercGaps); + //This is to maintain viewport position on first residue + //of first sequence + SequenceI seq = viewport.alignment.getSequenceAt(0); + int startRes = seq.findPosition(viewport.startRes); - cs.setConservation(c); - } - } + addHistoryItem(new RemoveGapsCommand("Remove Gaps", + seqs, + start, end, + viewport.getGapCharacter())); - int s, sSize = viewport.alignment.getGroups().size(); - for(s=0; s