X-Git-Url: http://source.jalview.org/gitweb/?a=blobdiff_plain;ds=sidebyside;f=src%2Fjalview%2Fappletgui%2FAnnotationLabels.java;h=7bf438fba9fcb75c1716eef8924a8d2d8bc58822;hb=1b1a1007c534a02fdbae76df0c084f215c7c4c21;hp=3ef61e65efa3822c7b67b0a1152138ab30e4b29a;hpb=de468b0bf50850a89c6a8a7acfa4ff5b689ffed1;p=jalview.git diff --git a/src/jalview/appletgui/AnnotationLabels.java b/src/jalview/appletgui/AnnotationLabels.java index 3ef61e6..7bf438f 100755 --- a/src/jalview/appletgui/AnnotationLabels.java +++ b/src/jalview/appletgui/AnnotationLabels.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 @@ -21,37 +21,38 @@ package jalview.appletgui; import java.awt.*; import java.awt.event.*; +import java.util.Vector; import jalview.datamodel.*; public class AnnotationLabels - extends Panel implements ActionListener + extends Panel implements ActionListener, MouseListener, MouseMotionListener { + Image image; boolean active = false; AlignmentPanel ap; AlignViewport av; boolean resizing = false; int oldY, mouseX; - static String ADDNEW = "Add new row"; + static String EDITNAME = "Edit label/description"; static String HIDE = "Hide this row"; static String DELETE = "Delete this row"; static String SHOWALL = "Show all hidden rows"; static String OUTPUT_TEXT = "Show Values In Textbox"; + static String COPYCONS_SEQ = "Copy Consensus Sequence"; + int selectedRow = 0; int scrollOffset = 0; + Tooltip tooltip; + public AnnotationLabels(AlignmentPanel ap) { this.ap = ap; this.av = ap.av; setLayout(null); - addMouseListener(new MouseAdapter() - { - public void mousePressed(MouseEvent evt) - { - doMousePressed(evt); - } - }); + addMouseListener(this); + addMouseMotionListener(this); } public AnnotationLabels(AlignViewport av) @@ -66,10 +67,52 @@ public class AnnotationLabels repaint(); } + void getSelectedRow(int y) + { + selectedRow = -1; + AlignmentAnnotation[] aa = ap.av.alignment.getAlignmentAnnotation(); + + if(aa==null) + return; + + int height = 0; + for (int i = 0; i < aa.length; i++) + { + if (!aa[i].visible) + { + continue; + } + + height += aa[i].height; + if (y < height) + { + selectedRow = i; + break; + } + } + } + public void actionPerformed(ActionEvent evt) { AlignmentAnnotation[] aa = av.alignment.getAlignmentAnnotation(); + if(evt.getActionCommand().equals(EDITNAME)) + { + EditNameDialog dialog = new EditNameDialog( + aa[selectedRow].label, + aa[selectedRow].description, + " Annotation Label", + "Annotation Description", + ap, + "Edit Annotation Name / Description"); + + if (dialog.accept) + { + aa[selectedRow].label = dialog.getName(); + aa[selectedRow].description = dialog.getDescription(); + repaint(); + } + } if (evt.getActionCommand().equals(HIDE)) { aa[selectedRow].visible = false; @@ -83,7 +126,7 @@ public class AnnotationLabels } else if (evt.getActionCommand().equals(OUTPUT_TEXT)) { - CutAndPasteTransfer cap = new CutAndPasteTransfer(false, ap.alignFrame.applet); + CutAndPasteTransfer cap = new CutAndPasteTransfer(false, ap.alignFrame); Frame frame = new Frame(); frame.add(cap); jalview.bin.JalviewLite.addFrame(frame, @@ -91,35 +134,61 @@ public class AnnotationLabels aa[selectedRow].label, 500, 100); cap.setText(aa[selectedRow].toString()); } + else if (evt.getActionCommand().equals(COPYCONS_SEQ)) + { + SequenceI cons=av.getConsensusSeq(); + if (cons!=null) + copy_annotseqtoclipboard(cons); + } ap.annotationPanel.adjustPanelHeight(); setSize(getSize().width, ap.annotationPanel.getSize().height); ap.validate(); ap.repaint(); } - public void doMousePressed(MouseEvent evt) + public void mouseMoved(MouseEvent evt) { - int y = evt.getY() - scrollOffset; - AlignmentAnnotation[] aa = ap.av.alignment.getAlignmentAnnotation(); - int height = 0; - for (int i = 0; i < aa.length; i++) - { - if (!aa[i].visible) - { - continue; - } + getSelectedRow(evt.getY() - scrollOffset); - height += aa[i].height; - if (y < height) - { - selectedRow = i; - break; - } + if (selectedRow > -1) + { + if (tooltip == null) + tooltip = new Tooltip(ap.av.alignment. + getAlignmentAnnotation()[selectedRow]. + description, + this); + else + tooltip.setTip(ap.av.alignment. + getAlignmentAnnotation()[selectedRow].description); + } + else if (tooltip != null) + { + tooltip.setTip(""); } + } + + public void mouseDragged(MouseEvent evt) + {} + public void mouseClicked(MouseEvent evt) + {} + public void mouseReleased(MouseEvent evt) + {} + public void mouseEntered(MouseEvent evt) + {} + public void mouseExited(MouseEvent evt) + {} + public void mousePressed(MouseEvent evt) + { + AlignmentAnnotation[] aa = ap.av.alignment.getAlignmentAnnotation(); + PopupMenu pop = new PopupMenu("Annotations"); - MenuItem item = new MenuItem(HIDE); + + MenuItem item = new MenuItem(EDITNAME); + item.addActionListener(this); + pop.add(item); + item = new MenuItem(HIDE); item.addActionListener(this); pop.add(item); item = new MenuItem(SHOWALL); @@ -130,7 +199,7 @@ public class AnnotationLabels item.addActionListener(this); pop.add(item); - if (aa[selectedRow].label.equals("Consensus")) + if (aa[selectedRow]==ap.av.consensus) { pop.addSeparator(); final CheckboxMenuItem cbmi = new CheckboxMenuItem( @@ -146,20 +215,63 @@ public class AnnotationLabels } }); pop.add(cbmi); + final MenuItem cpcons=new MenuItem(COPYCONS_SEQ); + cpcons.addActionListener(this); + pop.add(cpcons); } pop.show(this, evt.getX(), evt.getY()); } +/** + * DOCUMENT ME! + * + * @param e DOCUMENT ME! + */ + protected void copy_annotseqtoclipboard(SequenceI sq) + { + if (sq==null || sq.getLength()<1) + return; + jalview.appletgui.AlignFrame.copiedSequences = new StringBuffer(); + jalview.appletgui.AlignFrame.copiedSequences.append(sq.getName() + "\t" + + sq.getStart() + "\t" + + sq.getEnd() + "\t" + + sq.getSequenceAsString() + "\n"); + if (av.hasHiddenColumns) + { + jalview.appletgui.AlignFrame.copiedHiddenColumns=new Vector(); + for(int i=0; i