use of suffix string (filename.blc#suffixstring) to read a specified iteration from...
[jalview.git] / src / jalview / appletgui / AnnotationLabels.java
index 48cea13..a952f9d 100755 (executable)
@@ -1,6 +1,6 @@
 /*\r
  * Jalview - A Sequence Alignment Editor and Viewer\r
- * Copyright (C) 2006 AM Waterhouse, J Procter, G Barton, M Clamp, S Searle\r
+ * Copyright (C) 2007 AM Waterhouse, J Procter, G Barton, M Clamp, S Searle\r
  *\r
  * This program is free software; you can redistribute it and/or\r
  * modify it under the terms of the GNU General Public License\r
 \r
 package jalview.appletgui;\r
 \r
+import java.util.*;\r
+\r
 import java.awt.*;\r
 import java.awt.event.*;\r
-import java.util.Vector;\r
 \r
 import jalview.datamodel.*;\r
 \r
@@ -34,15 +35,16 @@ public class AnnotationLabels
   AlignViewport av;\r
   boolean resizing = false;\r
   int oldY, mouseX;\r
-  static String ADDNEW = "Add new row";\r
-  static String HIDE = "Hide this row";\r
-  static String DELETE = "Delete this row";\r
-  static String SHOWALL = "Show all hidden rows";\r
+\r
+  static String ADDNEW = "Add New Row";\r
+  static String EDITNAME = "Edit Label/Description";\r
+  static String HIDE = "Hide This Row";\r
+  static String SHOWALL = "Show All Hidden Rows";\r
   static String OUTPUT_TEXT = "Show Values In Textbox";\r
   static String COPYCONS_SEQ = "Copy Consensus Sequence";\r
 \r
-  int selectedRow = 0;\r
   int scrollOffset = 0;\r
+  int selectedRow = -1;\r
 \r
   Tooltip tooltip;\r
 \r
@@ -56,10 +58,9 @@ public class AnnotationLabels
   }\r
 \r
   public AnnotationLabels(AlignViewport av)\r
-{\r
-  this.av = av;\r
-}\r
-\r
+  {\r
+    this.av = av;\r
+  }\r
 \r
   public void setScrollOffset(int y)\r
   {\r
@@ -67,13 +68,15 @@ public class AnnotationLabels
     repaint();\r
   }\r
 \r
-  void getSelectedRow(int y)\r
+  int getSelectedRow(int y)\r
   {\r
-    selectedRow = -1;\r
+    int row = -1;\r
     AlignmentAnnotation[] aa = ap.av.alignment.getAlignmentAnnotation();\r
 \r
-    if(aa==null)\r
-      return;\r
+    if (aa == null)\r
+    {\r
+      return row;\r
+    }\r
 \r
     int height = 0;\r
     for (int i = 0; i < aa.length; i++)\r
@@ -86,17 +89,37 @@ public class AnnotationLabels
       height += aa[i].height;\r
       if (y < height)\r
       {\r
-        selectedRow = i;\r
+        row = i;\r
         break;\r
       }\r
     }\r
+\r
+    return row;\r
   }\r
 \r
   public void actionPerformed(ActionEvent evt)\r
   {\r
     AlignmentAnnotation[] aa = av.alignment.getAlignmentAnnotation();\r
 \r
-    if (evt.getActionCommand().equals(HIDE))\r
+    if (evt.getActionCommand().equals(ADDNEW))\r
+    {\r
+      AlignmentAnnotation newAnnotation = new AlignmentAnnotation("",\r
+          null,\r
+          new Annotation[ap.av.alignment.getWidth()]);\r
+\r
+      if (!editLabelDescription(newAnnotation))\r
+      {\r
+        return;\r
+      }\r
+\r
+      ap.av.alignment.addAnnotation(newAnnotation);\r
+      ap.av.alignment.setAnnotationIndex(newAnnotation, 0);\r
+    }\r
+    else if (evt.getActionCommand().equals(EDITNAME))\r
+    {\r
+      editLabelDescription(aa[selectedRow]);\r
+    }\r
+    else if (evt.getActionCommand().equals(HIDE))\r
     {\r
       aa[selectedRow].visible = false;\r
     }\r
@@ -119,34 +142,60 @@ public class AnnotationLabels
     }\r
     else if (evt.getActionCommand().equals(COPYCONS_SEQ))\r
     {\r
-      SequenceI cons=av.getConsensusSeq();\r
-      if (cons!=null)\r
+      SequenceI cons = av.getConsensusSeq();\r
+      if (cons != null)\r
+      {\r
         copy_annotseqtoclipboard(cons);\r
+      }\r
 \r
     }\r
     ap.annotationPanel.adjustPanelHeight();\r
     setSize(getSize().width, ap.annotationPanel.getSize().height);\r
     ap.validate();\r
-    ap.repaint();\r
+    ap.paintAlignment(true);\r
+  }\r
+\r
+  boolean editLabelDescription(AlignmentAnnotation annotation)\r
+  {\r
+    EditNameDialog dialog = new EditNameDialog(\r
+        annotation.label,\r
+        annotation.description,\r
+        "       Annotation Label",\r
+        "Annotation Description",\r
+        ap.alignFrame,\r
+        "Edit Annotation Name / Description",\r
+        500, 100);\r
+\r
+    if (dialog.accept)\r
+    {\r
+      annotation.label = dialog.getName();\r
+      annotation.description = dialog.getDescription();\r
+      repaint();\r
+      return true;\r
+    }\r
+    else\r
+      return false;\r
+\r
   }\r
 \r
   public void mouseMoved(MouseEvent evt)\r
   {\r
-    getSelectedRow(evt.getY() - scrollOffset);\r
+    int row = getSelectedRow(evt.getY() - scrollOffset);\r
 \r
-    if (selectedRow > -1)\r
+    if (row > -1)\r
     {\r
       if (tooltip == null)\r
+      {\r
         tooltip = new Tooltip(ap.av.alignment.\r
-                                          getAlignmentAnnotation()[selectedRow].\r
-                                          description,\r
-                                          this);\r
+                              getAlignmentAnnotation()[row].\r
+                              description,\r
+                              this);\r
+      }\r
       else\r
+      {\r
         tooltip.setTip(ap.av.alignment.\r
-                     getAlignmentAnnotation()[selectedRow].description);\r
-\r
-      tooltip.repaint();\r
-\r
+                       getAlignmentAnnotation()[row].description);\r
+      }\r
     }\r
     else if (tooltip != null)\r
     {\r
@@ -157,33 +206,47 @@ public class AnnotationLabels
 \r
   public void mouseDragged(MouseEvent evt)\r
   {}\r
+\r
   public void mouseClicked(MouseEvent evt)\r
   {}\r
+\r
   public void mouseReleased(MouseEvent evt)\r
   {}\r
+\r
   public void mouseEntered(MouseEvent evt)\r
   {}\r
+\r
   public void mouseExited(MouseEvent evt)\r
   {}\r
+\r
   public void mousePressed(MouseEvent evt)\r
   {\r
+    selectedRow = getSelectedRow(evt.getY() - scrollOffset);\r
+\r
     AlignmentAnnotation[] aa = ap.av.alignment.getAlignmentAnnotation();\r
 \r
-    PopupMenu pop = new PopupMenu("Annotations");\r
-    MenuItem item = new MenuItem(HIDE);\r
+    PopupMenu popup = new PopupMenu("Annotations");\r
+\r
+    MenuItem item = new MenuItem(ADDNEW);\r
+    item.addActionListener(this);\r
+    popup.add(item);\r
+    item = new MenuItem(EDITNAME);\r
     item.addActionListener(this);\r
-    pop.add(item);\r
+    popup.add(item);\r
+    item = new MenuItem(HIDE);\r
+    item.addActionListener(this);\r
+    popup.add(item);\r
     item = new MenuItem(SHOWALL);\r
     item.addActionListener(this);\r
-    pop.add(item);\r
-    this.add(pop);\r
+    popup.add(item);\r
+    this.add(popup);\r
     item = new MenuItem(OUTPUT_TEXT);\r
     item.addActionListener(this);\r
-    pop.add(item);\r
+    popup.add(item);\r
 \r
-    if (aa[selectedRow].label.equals("Consensus"))\r
+    if (aa[selectedRow] == ap.av.consensus)\r
     {\r
-      pop.addSeparator();\r
+      popup.addSeparator();\r
       final CheckboxMenuItem cbmi = new CheckboxMenuItem(\r
           "Ignore Gaps In Consensus",\r
           ap.av.getIgnoreGapsConsensus());\r
@@ -193,50 +256,54 @@ public class AnnotationLabels
         public void itemStateChanged(ItemEvent e)\r
         {\r
           ap.av.setIgnoreGapsConsensus(cbmi.getState());\r
-          ap.repaint();\r
+          ap.paintAlignment(true);\r
         }\r
       });\r
-      pop.add(cbmi);\r
-      final MenuItem cpcons=new MenuItem(COPYCONS_SEQ);\r
-      cpcons.addActionListener(this);\r
-      pop.add(cpcons);\r
+      popup.add(cbmi);\r
+      item = new MenuItem(COPYCONS_SEQ);\r
+      item.addActionListener(this);\r
+      popup.add(item);\r
     }\r
 \r
-     pop.show(this, evt.getX(), evt.getY());\r
+    popup.show(this, evt.getX(), evt.getY());\r
 \r
   }\r
-/**\r
-     * DOCUMENT ME!\r
-     *\r
-     * @param e DOCUMENT ME!\r
-     */\r
-    protected void copy_annotseqtoclipboard(SequenceI sq)\r
+\r
+  /**\r
+   * DOCUMENT ME!\r
+   *\r
+   * @param e DOCUMENT ME!\r
+   */\r
+  protected void copy_annotseqtoclipboard(SequenceI sq)\r
+  {\r
+    if (sq == null || sq.getLength() < 1)\r
     {\r
-      if (sq==null || sq.getLength()<1)\r
-        return;\r
-      jalview.appletgui.AlignFrame.copiedSequences = new StringBuffer();\r
-      jalview.appletgui.AlignFrame.copiedSequences.append(sq.getName() + "\t" +\r
-          sq.getStart() + "\t" +\r
-          sq.getEnd() + "\t" +\r
-          sq.getSequenceAsString() + "\n");\r
-      if (av.hasHiddenColumns)\r
+      return;\r
+    }\r
+    jalview.appletgui.AlignFrame.copiedSequences = new StringBuffer();\r
+    jalview.appletgui.AlignFrame.copiedSequences.append(sq.getName() + "\t" +\r
+        sq.getStart() + "\t" +\r
+        sq.getEnd() + "\t" +\r
+        sq.getSequenceAsString() + "\n");\r
+    if (av.hasHiddenColumns)\r
+    {\r
+      jalview.appletgui.AlignFrame.copiedHiddenColumns = new Vector();\r
+      for (int i = 0; i < av.getColumnSelection().getHiddenColumns().size(); i++)\r
       {\r
-        jalview.appletgui.AlignFrame.copiedHiddenColumns=new Vector();\r
-        for(int i=0; i<av.getColumnSelection().getHiddenColumns().size(); i++)\r
-        {\r
-          int[] region = (int[])\r
-              av.getColumnSelection().getHiddenColumns().elementAt(i);\r
+        int[] region = (int[])\r
+            av.getColumnSelection().getHiddenColumns().elementAt(i);\r
 \r
-          jalview.appletgui.AlignFrame.copiedHiddenColumns.addElement(new int[]{region[0],\r
-                            region[1]});\r
-        }\r
+        jalview.appletgui.AlignFrame.copiedHiddenColumns.addElement(new int[]\r
+            {region[0],\r
+            region[1]});\r
       }\r
     }\r
+  }\r
 \r
-    public void update(Graphics g)\r
-    {\r
-      paint(g);\r
-    }\r
+  public void update(Graphics g)\r
+  {\r
+    paint(g);\r
+  }\r
 \r
   public void paint(Graphics g)\r
   {\r
@@ -247,7 +314,7 @@ public class AnnotationLabels
     }\r
 \r
     drawComponent(image.getGraphics(), w);\r
-    g.drawImage(image,0,0,this);\r
+    g.drawImage(image, 0, 0, this);\r
   }\r
 \r
   public void drawComponent(Graphics g, int width)\r
@@ -275,14 +342,14 @@ public class AnnotationLabels
 \r
         x = width - fm.stringWidth(aa[i].label) - 3;\r
 \r
-        if (aa[i].graph>0)\r
+        if (aa[i].graph > 0)\r
         {\r
           y += (aa[i].height / 3);\r
         }\r
 \r
         g.drawString(aa[i].label, x, y);\r
 \r
-        if (aa[i].graph>0)\r
+        if (aa[i].graph > 0)\r
         {\r
           y += (2 * aa[i].height / 3);\r
         }\r