X-Git-Url: http://source.jalview.org/gitweb/?a=blobdiff_plain;f=src%2Fjalview%2Fappletgui%2FAnnotationLabels.java;h=b6b2b0d38834ded84b4ae715f037c744480a5a39;hb=c19d2a91ca05e052e3408bf5852d88eb5d0608f1;hp=2184851b5699512692429d27c182b0b1a4181428;hpb=811fb76382f3601b35dc08b8c0ceabed049c3326;p=jalview.git
diff --git a/src/jalview/appletgui/AnnotationLabels.java b/src/jalview/appletgui/AnnotationLabels.java
index 2184851..b6b2b0d 100755
--- a/src/jalview/appletgui/AnnotationLabels.java
+++ b/src/jalview/appletgui/AnnotationLabels.java
@@ -1,28 +1,56 @@
/*
- * Jalview - A Sequence Alignment Editor and Viewer (Version 2.6)
- * Copyright (C) 2010 J Procter, AM Waterhouse, G Barton, M Clamp, S Searle
+ * Jalview - A Sequence Alignment Editor and Viewer (Version 2.9.0b2)
+ * Copyright (C) 2015 The Jalview Authors
*
* This file is part of Jalview.
*
* Jalview is free software: you can redistribute it and/or
* modify it under the terms of the GNU General Public License
- * as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version.
- *
+ * as published by the Free Software Foundation, either version 3
+ * of the License, or (at your option) any later version.
+ *
* Jalview is distributed in the hope that it will be useful, but
* WITHOUT ANY WARRANTY; without even the implied warranty
* of MERCHANTABILITY or FITNESS FOR A PARTICULAR
* PURPOSE. See the GNU General Public License for more details.
*
- * You should have received a copy of the GNU General Public License along with Jalview. If not, see .
+ * You should have received a copy of the GNU General Public License
+ * along with Jalview. If not, see .
+ * The Jalview Authors are detailed in the 'AUTHORS' file.
*/
package jalview.appletgui;
-import java.util.*;
-
-import java.awt.*;
-import java.awt.event.*;
-
-import jalview.datamodel.*;
+import jalview.analysis.AlignmentUtils;
+import jalview.datamodel.AlignmentAnnotation;
+import jalview.datamodel.Annotation;
+import jalview.datamodel.SequenceGroup;
+import jalview.datamodel.SequenceI;
+import jalview.util.MessageManager;
+import jalview.util.ParseHtmlBodyAndLinks;
+
+import java.awt.Checkbox;
+import java.awt.CheckboxMenuItem;
+import java.awt.Color;
+import java.awt.Dimension;
+import java.awt.FlowLayout;
+import java.awt.FontMetrics;
+import java.awt.Frame;
+import java.awt.Graphics;
+import java.awt.Image;
+import java.awt.MenuItem;
+import java.awt.Panel;
+import java.awt.PopupMenu;
+import java.awt.event.ActionEvent;
+import java.awt.event.ActionListener;
+import java.awt.event.InputEvent;
+import java.awt.event.ItemEvent;
+import java.awt.event.ItemListener;
+import java.awt.event.MouseEvent;
+import java.awt.event.MouseListener;
+import java.awt.event.MouseMotionListener;
+import java.util.Arrays;
+import java.util.Collections;
+import java.util.Vector;
public class AnnotationLabels extends Panel implements ActionListener,
MouseListener, MouseMotionListener
@@ -64,6 +92,23 @@ public class AnnotationLabels extends Panel implements ActionListener,
this.ap = ap;
this.av = ap.av;
setLayout(null);
+
+ /**
+ * this retrieves the adjustable height glyph from resources. we don't use
+ * it at the moment. java.net.URL url =
+ * getClass().getResource("/images/idwidth.gif"); Image temp = null;
+ *
+ * if (url != null) { temp =
+ * java.awt.Toolkit.getDefaultToolkit().createImage(url); }
+ *
+ * try { MediaTracker mt = new MediaTracker(this); mt.addImage(temp, 0);
+ * mt.waitForID(0); } catch (Exception ex) { }
+ *
+ * BufferedImage bi = new BufferedImage(temp.getHeight(this),
+ * temp.getWidth(this), BufferedImage.TYPE_INT_RGB); Graphics2D g =
+ * (Graphics2D) bi.getGraphics(); g.rotate(Math.toRadians(90));
+ * g.drawImage(temp, 0, -bi.getWidth(this), this); image = (Image) bi;
+ */
addMouseListener(this);
addMouseMotionListener(this);
}
@@ -73,10 +118,13 @@ public class AnnotationLabels extends Panel implements ActionListener,
this.av = av;
}
- public void setScrollOffset(int y)
+ public void setScrollOffset(int y, boolean repaint)
{
scrollOffset = y;
- repaint();
+ if (repaint)
+ {
+ repaint();
+ }
}
/**
@@ -88,7 +136,8 @@ public class AnnotationLabels extends Panel implements ActionListener,
int getSelectedRow(int y)
{
int row = -2;
- AlignmentAnnotation[] aa = ap.av.alignment.getAlignmentAnnotation();
+ AlignmentAnnotation[] aa = ap.av.getAlignment()
+ .getAlignmentAnnotation();
if (aa == null)
{
@@ -115,20 +164,20 @@ public class AnnotationLabels extends Panel implements ActionListener,
public void actionPerformed(ActionEvent evt)
{
- AlignmentAnnotation[] aa = av.alignment.getAlignmentAnnotation();
+ AlignmentAnnotation[] aa = av.getAlignment().getAlignmentAnnotation();
if (evt.getActionCommand().equals(ADDNEW))
{
AlignmentAnnotation newAnnotation = new AlignmentAnnotation("", null,
- new Annotation[ap.av.alignment.getWidth()]);
+ new Annotation[ap.av.getAlignment().getWidth()]);
if (!editLabelDescription(newAnnotation))
{
return;
}
- ap.av.alignment.addAnnotation(newAnnotation);
- ap.av.alignment.setAnnotationIndex(newAnnotation, 0);
+ ap.av.getAlignment().addAnnotation(newAnnotation);
+ ap.av.getAlignment().setAnnotationIndex(newAnnotation, 0);
}
else if (evt.getActionCommand().equals(EDITNAME))
{
@@ -164,6 +213,14 @@ public class AnnotationLabels extends Panel implements ActionListener,
}
}
+ refresh();
+ }
+
+ /**
+ * Adjust size and repaint
+ */
+ protected void refresh()
+ {
ap.annotationPanel.adjustPanelHeight();
setSize(getSize().width, ap.annotationPanel.getSize().height);
ap.validate();
@@ -196,38 +253,116 @@ public class AnnotationLabels extends Panel implements ActionListener,
return true;
}
else
+ {
return false;
+ }
}
+ boolean resizePanel = false;
+
public void mouseMoved(MouseEvent evt)
{
- int row = getSelectedRow(evt.getY() - scrollOffset);
+ resizePanel = evt.getY() < 10 && evt.getX() < 14;
+ int row = getSelectedRow(evt.getY() + scrollOffset);
if (row > -1)
{
+ ParseHtmlBodyAndLinks phb = new ParseHtmlBodyAndLinks(
+ av.getAlignment().getAlignmentAnnotation()[row]
+ .getDescription(true),
+ true, "\n");
if (tooltip == null)
{
- tooltip = new Tooltip(
- ap.av.alignment.getAlignmentAnnotation()[row]
- .getDescription(true),
- this);
+ tooltip = new Tooltip(phb.getNonHtmlContent(), this);
}
else
{
- tooltip.setTip(ap.av.alignment.getAlignmentAnnotation()[row]
- .getDescription(true));
+ tooltip.setTip(phb.getNonHtmlContent());
}
}
else if (tooltip != null)
{
tooltip.setTip("");
}
+ }
+
+ /**
+ * curent drag position
+ */
+ MouseEvent dragEvent = null;
+
+ /**
+ * flag to indicate drag events should be ignored
+ */
+ private boolean dragCancelled = false;
+ /**
+ * clear any drag events in progress
+ */
+ public void cancelDrag()
+ {
+ dragEvent = null;
+ dragCancelled = true;
}
public void mouseDragged(MouseEvent evt)
{
+ if (dragCancelled)
+ {
+ return;
+ }
+ ;
+ dragEvent = evt;
+
+ if (resizePanel)
+ {
+ Dimension d = ap.annotationPanelHolder.getSize(), e = ap.annotationSpaceFillerHolder
+ .getSize(), f = ap.seqPanelHolder.getSize();
+ int dif = evt.getY() - oldY;
+
+ dif /= ap.av.getCharHeight();
+ dif *= ap.av.getCharHeight();
+
+ if ((d.height - dif) > 20 && (f.height + dif) > 20)
+ {
+ ap.annotationPanel.setSize(d.width, d.height - dif);
+ setSize(new Dimension(e.width, d.height - dif));
+ ap.annotationSpaceFillerHolder.setSize(new Dimension(e.width,
+ d.height - dif));
+ ap.annotationPanelHolder.setSize(new Dimension(d.width, d.height
+ - dif));
+ ap.apvscroll.setValues(ap.apvscroll.getValue(), d.height - dif, 0,
+ av.calcPanelHeight());
+ f.height += dif;
+ ap.seqPanelHolder.setPreferredSize(f);
+ ap.setScrollValues(av.getStartRes(), av.getStartSeq());
+ ap.validate();
+ // ap.paintAlignment(true);
+ ap.addNotify();
+ }
+
+ }
+ else
+ {
+ int diff;
+ if ((diff = 6 - evt.getY()) > 0)
+ {
+ // nudge scroll up
+ ap.apvscroll.setValue(ap.apvscroll.getValue() - diff);
+ ap.adjustmentValueChanged(null);
+
+ }
+ else if ((0 < (diff = 6
+ - ap.annotationSpaceFillerHolder.getSize().height
+ + evt.getY())))
+ {
+ // nudge scroll down
+ ap.apvscroll.setValue(ap.apvscroll.getValue() + diff);
+ ap.adjustmentValueChanged(null);
+ }
+ repaint();
+ }
}
public void mouseClicked(MouseEvent evt)
@@ -236,34 +371,132 @@ public class AnnotationLabels extends Panel implements ActionListener,
public void mouseReleased(MouseEvent evt)
{
+ if (!resizePanel && !dragCancelled)
+ {
+ int start = selectedRow;
+
+ int end = getSelectedRow(evt.getY() + scrollOffset);
+
+ if (start > -1 && start != end)
+ {
+ // Swap these annotations
+ AlignmentAnnotation startAA = ap.av.getAlignment()
+ .getAlignmentAnnotation()[start];
+ if (end == -1)
+ {
+ end = ap.av.getAlignment().getAlignmentAnnotation().length - 1;
+ }
+ AlignmentAnnotation endAA = ap.av.getAlignment()
+ .getAlignmentAnnotation()[end];
+
+ ap.av.getAlignment().getAlignmentAnnotation()[end] = startAA;
+ ap.av.getAlignment().getAlignmentAnnotation()[start] = endAA;
+ }
+ }
+ resizePanel = false;
+ dragEvent = null;
+ dragCancelled = false;
+ repaint();
+ ap.annotationPanel.repaint();
}
public void mouseEntered(MouseEvent evt)
{
+ if (evt.getY() < 10 && evt.getX() < 14)
+ {
+ resizePanel = true;
+ repaint();
+ }
}
public void mouseExited(MouseEvent evt)
{
+ dragCancelled = false;
+
+ if (dragEvent == null)
+ {
+ resizePanel = false;
+ }
+ else
+ {
+ if (!resizePanel)
+ {
+ dragEvent = null;
+ }
+ }
+ repaint();
}
public void mousePressed(MouseEvent evt)
{
- selectedRow = getSelectedRow(evt.getY() - scrollOffset);
- AlignmentAnnotation[] aa = ap.av.alignment.getAlignmentAnnotation();
+ oldY = evt.getY();
+ if (resizePanel)
+ {
+ return;
+ }
+ dragCancelled = false;
+ // todo: move below to mouseClicked ?
+ selectedRow = getSelectedRow(evt.getY() + scrollOffset);
+
+ AlignmentAnnotation[] aa = ap.av.getAlignment()
+ .getAlignmentAnnotation();
// DETECT RIGHT MOUSE BUTTON IN AWT
if ((evt.getModifiers() & InputEvent.BUTTON3_MASK) == InputEvent.BUTTON3_MASK)
{
+ PopupMenu popup = new PopupMenu(
+ MessageManager.getString("label.annotations"));
- PopupMenu popup = new PopupMenu("Annotations");
+ MenuItem item = new MenuItem(ADDNEW);
+ item.addActionListener(this);
+ popup.add(item);
+ if (selectedRow < 0)
+ {
+ // this never happens at moment: - see comment on JAL-563
+ if (hasHiddenRows)
+ {
+ item = new MenuItem(SHOWALL);
+ item.addActionListener(this);
+ popup.add(item);
+ }
+ this.add(popup);
+ popup.show(this, evt.getX(), evt.getY());
+ return;
+ }
+ // add the rest if there are actually rows to show
+ item = new MenuItem(EDITNAME);
+ item.addActionListener(this);
+ popup.add(item);
+ item = new MenuItem(HIDE);
+ item.addActionListener(this);
+ popup.add(item);
+
+ /*
+ * Hide all