X-Git-Url: http://source.jalview.org/gitweb/?a=blobdiff_plain;f=src%2Fjalview%2Fgui%2FPopupMenu.java;h=3481a3103dd6cecc052a2a7198940f8e55ffe637;hb=174230b4233d9ce80f94527768d2cd2f76da11ab;hp=311421140d1a0dfce80dd3c4b09162f813b7fa7d;hpb=0201d2b630e06a75fd9522f24863e9cecf8810fd;p=jalview.git diff --git a/src/jalview/gui/PopupMenu.java b/src/jalview/gui/PopupMenu.java index 3114211..3481a31 100755 --- a/src/jalview/gui/PopupMenu.java +++ b/src/jalview/gui/PopupMenu.java @@ -1,6 +1,6 @@ /* * Jalview - A Sequence Alignment Editor and Viewer - * Copyright (C) 2005 AM Waterhouse, J Procter, G Barton, M Clamp, S Searle + * Copyright (C) 2006 AM Waterhouse, J Procter, G Barton, M Clamp, S Searle * * This program is free software; you can redistribute it and/or * modify it under the terms of the GNU General Public License @@ -32,6 +32,9 @@ import java.awt.event.*; import javax.swing.*; +import java.util.Vector; +import jalview.io.FormatAdapter; + /** * DOCUMENT ME! @@ -68,14 +71,25 @@ public class PopupMenu extends JPopupMenu JCheckBoxMenuItem showBoxes = new JCheckBoxMenuItem(); JCheckBoxMenuItem showText = new JCheckBoxMenuItem(); JCheckBoxMenuItem showColourText = new JCheckBoxMenuItem(); - - /** + JMenu editMenu = new JMenu(); + JMenuItem cut = new JMenuItem(); + JMenuItem copy = new JMenuItem(); + JMenuItem upperCase = new JMenuItem(); + JMenuItem lowerCase = new JMenuItem(); + JMenuItem toggle = new JMenuItem(); + JMenu pdbMenu = new JMenu(); + JMenuItem pdbFromFile = new JMenuItem(); + JMenuItem enterPDB = new JMenuItem(); + JMenuItem discoverPDB = new JMenuItem(); + JMenu outputMenu = new JMenu(); + + /** * Creates a new PopupMenu object. * * @param ap DOCUMENT ME! * @param seq DOCUMENT ME! */ - public PopupMenu(final AlignmentPanel ap, Sequence seq) + public PopupMenu(final AlignmentPanel ap, Sequence seq, Vector links) { /////////////////////////////////////////////////////////// // If this is activated from the sequence panel, the user may want to @@ -101,6 +115,22 @@ public class PopupMenu extends JPopupMenu colours.add(PIDColour); colours.add(BLOSUM62Colour); + for (int i = 0; i < jalview.io.FormatAdapter.WRITEABLE_FORMATS.length; i++) + { + JMenuItem item = new JMenuItem( jalview.io.FormatAdapter.WRITEABLE_FORMATS[i] ); + + item.addActionListener(new java.awt.event.ActionListener() + { + public void actionPerformed(ActionEvent e) + { + outputText_actionPerformed(e); + } + }); + + outputMenu.add(item); + } + + try { jbInit(); @@ -111,28 +141,97 @@ public class PopupMenu extends JPopupMenu } - if ((seq != null) - && seq.getDatasetSequence().getPDBId() != null) + if (seq != null) { - java.util.Enumeration e = seq.getDatasetSequence().getPDBId().elements(); - while(e.hasMoreElements()) + int start = Math.max(sequence.getName().length()-15, 0); + sequenceMenu.setText(sequence.getName().substring(start)); + + JMenuItem menuItem; + if( seq.getDatasetSequence().getPDBId() != null) { - final PDBEntry pdb = (PDBEntry)e.nextElement(); + java.util.Enumeration e = seq.getDatasetSequence().getPDBId(). + elements(); - JMenuItem pdbMenuItem = new JMenuItem(); - pdbMenuItem.setText("View PDB entry: "+pdb.getId()); - pdbMenuItem.addActionListener(new java.awt.event.ActionListener() + while (e.hasMoreElements()) { + final PDBEntry pdb = (PDBEntry) e.nextElement(); + + menuItem = new JMenuItem(); + menuItem.setText("View PDB entry: " + pdb.getId()); + menuItem.addActionListener(new java.awt.event.ActionListener() + { public void actionPerformed(ActionEvent e) { new PDBViewer(pdb, sequence, ap.seqPanel.seqCanvas); } + }); + sequenceMenu.add(menuItem); + } + } + + menuItem = new JMenuItem("Hide Sequences"); + menuItem.addActionListener(new java.awt.event.ActionListener() + { + public void actionPerformed(ActionEvent e) + { + hideSequences(false); + } + }); + add(menuItem); + + if(ap.av.getSelectionGroup() !=null + && ap.av.getSelectionGroup().getSize(false)>1) + { + menuItem = new JMenuItem("Represent Group with " + seq.getName()); + menuItem.addActionListener(new java.awt.event.ActionListener() + { + public void actionPerformed(ActionEvent e) + { + hideSequences(true); + } }); - sequenceMenu.add(pdbMenuItem); + sequenceMenu.add(menuItem); + } + + if (ap.av.hasHiddenRows) + { + final int index = ap.av.alignment.findIndex(seq); + + if (ap.av.adjustForHiddenSeqs(index) - + ap.av.adjustForHiddenSeqs(index - 1) > 1) + { + menuItem = new JMenuItem("Reveal Sequences"); + menuItem.addActionListener(new ActionListener() + { + public void actionPerformed(ActionEvent e) + { + ap.av.showSequence(index); + if (ap.overviewPanel != null) + ap.overviewPanel.updateOverviewImage(); + } + }); + add(menuItem); + } + + menuItem = new JMenuItem("Reveal All"); + menuItem.addActionListener(new ActionListener() + { + public void actionPerformed(ActionEvent e) + { + ap.av.showAllHiddenSeqs(); + if (ap.overviewPanel != null) + ap.overviewPanel.updateOverviewImage(); + } + }); + + add(menuItem); } + } + + SequenceGroup sg = ap.av.getSelectionGroup(); if (sg != null) @@ -197,38 +296,48 @@ public class PopupMenu extends JPopupMenu showColourText.setSelected(sg.getColourText()); showBoxes.setSelected(sg.getDisplayBoxes()); } + else + { + groupMenu.setVisible(false); + editMenu.setVisible(false); + } if (!ap.av.alignment.getGroups().contains(sg)) { unGroupMenuItem.setVisible(false); } - else - { - groupMenu.insertSeparator(3); - } + if (seq == null) { sequenceMenu.setVisible(false); + pdbMenu.setVisible(false); } - else - { - java.util.Vector links = Preferences.sequenceURLLinks; + if(links != null && links.size()>0) + { JMenu linkMenu = new JMenu("Link"); JMenuItem item; for(int i=0; i-1) - id = id.substring(id.lastIndexOf("|")+1); - - final String url = link.substring(link.indexOf("|")+1, link.indexOf("$SEQUENCE_ID$")) - + id + - link.substring(link.indexOf("$SEQUENCE_ID$") + 13); + if (link.indexOf("$SEQUENCE_ID$") > -1) + { + String id = seq.getName(); + if (id.indexOf("|") > -1) + id = id.substring(id.lastIndexOf("|") + 1); + + url = link.substring(link.indexOf("|") + 1, + link.indexOf("$SEQUENCE_ID$")) + + id + + link.substring(link.indexOf("$SEQUENCE_ID$") + 13); + } + else + url = link.substring(link.lastIndexOf("|")+1); item.addActionListener(new java.awt.event.ActionListener() @@ -241,10 +350,14 @@ public class PopupMenu extends JPopupMenu linkMenu.add(item); } - add(linkMenu); + if(sequence!=null) + sequenceMenu.add(linkMenu); + else + add(linkMenu); } } + /** * DOCUMENT ME! * @@ -253,7 +366,7 @@ public class PopupMenu extends JPopupMenu private void jbInit() throws Exception { groupMenu.setText("Group"); - groupMenu.setText("Define"); + groupMenu.setText("Selection"); groupName.setText("Name"); groupName.addActionListener(new java.awt.event.ActionListener() { @@ -263,7 +376,7 @@ public class PopupMenu extends JPopupMenu } }); sequenceMenu.setText("Sequence"); - sequenceName.setText("Edit Name/Desciption"); + sequenceName.setText("Edit Name/Description"); sequenceName.addActionListener(new java.awt.event.ActionListener() { public void actionPerformed(ActionEvent e) @@ -324,20 +437,89 @@ public class PopupMenu extends JPopupMenu showColourText_actionPerformed(e); } }); - add(groupMenu); - add(sequenceMenu); - groupMenu.add(groupName); - groupMenu.addSeparator(); - groupMenu.add(unGroupMenuItem); + editMenu.setText("Edit"); + cut.setText("Cut"); + cut.addActionListener(new ActionListener() + { + public void actionPerformed(ActionEvent e) + { + cut_actionPerformed(e); + } + }); + upperCase.setText("To Upper Case"); + upperCase.addActionListener(new ActionListener() + { + public void actionPerformed(ActionEvent e) + { + upperCase_actionPerformed(e); + } + }); + copy.setText("Copy"); + copy.addActionListener(new ActionListener() + { + public void actionPerformed(ActionEvent e) + { + copy_actionPerformed(e); + } + }); + lowerCase.setText("To Lower Case"); + lowerCase.addActionListener(new ActionListener() + { + public void actionPerformed(ActionEvent e) + { + lowerCase_actionPerformed(e); + } + }); + toggle.setText("Toggle Case"); + toggle.addActionListener(new ActionListener() + { + public void actionPerformed(ActionEvent e) + { + toggle_actionPerformed(e); + } + }); + pdbMenu.setText("Associate Structure with Sequence"); + pdbFromFile.setText("From File"); + pdbFromFile.addActionListener(new ActionListener() + { + public void actionPerformed(ActionEvent e) + { + pdbFromFile_actionPerformed(e); + } + }); + enterPDB.setText("Enter PDB Id"); + enterPDB.addActionListener(new ActionListener() + { + public void actionPerformed(ActionEvent e) + { + enterPDB_actionPerformed(e); + } + }); + discoverPDB.setText("Discover PDB ids"); + discoverPDB.addActionListener(new ActionListener() + { + public void actionPerformed(ActionEvent e) + { + discoverPDB_actionPerformed(e); + } + }); + outputMenu.setText("Output to Textbox..."); + add(groupMenu); + + add(sequenceMenu); + groupMenu.add(editMenu); + groupMenu.add(outputMenu); + groupMenu.addSeparator(); + groupMenu.add(groupName); + groupMenu.add(unGroupMenuItem); groupMenu.add(colourMenu); - groupMenu.addSeparator(); - groupMenu.add(showBoxes); + groupMenu.add(showBoxes); groupMenu.add(showText); groupMenu.add(showColourText); - groupMenu.addSeparator(); - groupMenu.add(outline); + groupMenu.add(outline); sequenceMenu.add(sequenceName); - colourMenu.add(noColourmenuItem); + sequenceMenu.add(pdbMenu); + colourMenu.add(noColourmenuItem); colourMenu.add(clustalColour); colourMenu.add(BLOSUM62Colour); colourMenu.add(PIDColour); @@ -375,7 +557,15 @@ public class PopupMenu extends JPopupMenu colourMenu.addSeparator(); colourMenu.add(abovePIDColour); colourMenu.add(conservationMenuItem); - noColourmenuItem.setText("None"); + editMenu.add(copy); + editMenu.add(cut); + editMenu.add(upperCase); + editMenu.add(lowerCase); + editMenu.add(toggle); + pdbMenu.add(pdbFromFile); + pdbMenu.add(enterPDB); + pdbMenu.add(discoverPDB); + noColourmenuItem.setText("None"); noColourmenuItem.addActionListener(new java.awt.event.ActionListener() { public void actionPerformed(ActionEvent e) @@ -509,7 +699,7 @@ public class PopupMenu extends JPopupMenu protected void clustalColour_actionPerformed(ActionEvent e) { SequenceGroup sg = getGroup(); - sg.cs = new ClustalxColourScheme(sg.sequences, + sg.cs = new ClustalxColourScheme(sg.getSequences(true), ap.av.alignment.getWidth()); refresh(); } @@ -615,7 +805,8 @@ public class PopupMenu extends JPopupMenu if (abovePIDColour.isSelected()) { - sg.cs.setConsensus(AAFrequency.calculate(sg.sequences, 0, + sg.cs.setConsensus(AAFrequency.calculate( + sg.getSequences(true), 0, ap.av.alignment.getWidth())); int threshold = SliderPanel.setPIDSliderSource(ap, sg.cs, @@ -661,7 +852,7 @@ public class PopupMenu extends JPopupMenu { SequenceGroup sg = getGroup(); sg.cs = new PIDColourScheme(); - sg.cs.setConsensus(AAFrequency.calculate(sg.sequences, 0, + sg.cs.setConsensus(AAFrequency.calculate(sg.getSequences(true), 0, ap.av.alignment.getWidth())); refresh(); } @@ -677,7 +868,7 @@ public class PopupMenu extends JPopupMenu sg.cs = new Blosum62ColourScheme(); - sg.cs.setConsensus(AAFrequency.calculate(sg.sequences, 0, + sg.cs.setConsensus(AAFrequency.calculate(sg.getSequences(true), 0, ap.av.alignment.getWidth())); refresh(); @@ -708,7 +899,8 @@ public class PopupMenu extends JPopupMenu if (conservationMenuItem.isSelected()) { Conservation c = new Conservation("Group", - ResidueProperties.propHash, 3, sg.sequences, 0, + ResidueProperties.propHash, 3, + sg.getSequences(true), 0, ap.av.alignment.getWidth()); c.calculate(); @@ -763,9 +955,9 @@ public class PopupMenu extends JPopupMenu SequenceGroup sg = getGroup(); StringBuffer sb = new StringBuffer(); - for (int i = 0; i < sg.sequences.size(); i++) + for (int i = 0; i < sg.getSize(false); i++) { - Sequence tmp = (Sequence) sg.sequences.get(i); + Sequence tmp = (Sequence) sg.getSequences(false).elementAt(i); sb.append(tmp.getSequence(sg.getStartRes(), sg.getEndRes() + 1)); sb.append("\n"); } @@ -928,4 +1120,174 @@ public class PopupMenu extends JPopupMenu ex.printStackTrace(); } } + + void hideSequences(boolean representGroup) + { + SequenceGroup sg = ap.av.getSelectionGroup(); + if(sg==null || sg.getSize(false)<1) + { + ap.av.hideSequence(sequence); + return; + } + + int index = 0; + while(index < sg.getSize(false)) + { + if(representGroup && sg.getSequenceAt(index)!=sequence) + { + sequence.addHiddenSequence(sg.getSequenceAt(index)); + ap.av.hideSequence(sg.getSequenceAt(index)); + } + else if(!representGroup) + { + ap.av.hideSequence(sg.getSequenceAt(index)); + } + index ++; + } + + ap.av.setSelectionGroup(null); + } + + public void copy_actionPerformed(ActionEvent e) + { + ap.alignFrame.copy_actionPerformed(null); + } + + public void cut_actionPerformed(ActionEvent e) + { + ap.alignFrame.cut_actionPerformed(null); + } + + public void upperCase_actionPerformed(ActionEvent e) + { + SequenceGroup sg = ap.av.getSelectionGroup(); + if(sg==null) + return; + + for(int g=0; g 0) + { + PDBEntry entry = new PDBEntry(); + entry.setId(id); + sequence.getDatasetSequence() + .addPDBId(entry); + } + } + + public void discoverPDB_actionPerformed(ActionEvent e) + { + new jalview.io.DBRefFetcher( + ap.av.getAlignment(), ap.alignFrame).fetchDBRefs(false); + } }