X-Git-Url: http://source.jalview.org/gitweb/?a=blobdiff_plain;f=src%2Fjalview%2Fgui%2FIdPanel.java;h=38912fddc6e9f67e13e51db923fc7a43f628f597;hb=153dd62dc91da13ae732600e6ea55ddbe15eab39;hp=4741974d1ebf2a626c9b16daa55c7f61dc041f06;hpb=5d01e85b903f9ce67b2b4a32e9e7a02f57d9f2e9;p=jalview.git
diff --git a/src/jalview/gui/IdPanel.java b/src/jalview/gui/IdPanel.java
index 4741974..38912fd 100755
--- a/src/jalview/gui/IdPanel.java
+++ b/src/jalview/gui/IdPanel.java
@@ -1,25 +1,26 @@
/*
- * Jalview - A Sequence Alignment Editor and Viewer
- * Copyright (C) 2007 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
- * as published by the Free Software Foundation; either version 2
- * of the License, or (at your option) any later version.
- *
- * This program 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 this program; if not, write to the Free Software
- * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA
+ * Jalview - A Sequence Alignment Editor and Viewer (Version 2.6)
+ * Copyright (C) 2010 J Procter, AM Waterhouse, G Barton, M Clamp, S Searle
+ *
+ * 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.
+ *
+ * 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 .
*/
package jalview.gui;
import java.awt.*;
import java.awt.event.*;
+import java.util.Vector;
+
import javax.swing.*;
import jalview.datamodel.*;
@@ -27,34 +28,44 @@ import jalview.util.UrlLink;
/**
* DOCUMENT ME!
- *
+ *
* @author $author$
* @version $Revision$
*/
-public class IdPanel
- extends JPanel implements MouseListener,
- MouseMotionListener, MouseWheelListener
+public class IdPanel extends JPanel implements MouseListener,
+ MouseMotionListener, MouseWheelListener
{
protected IdCanvas idCanvas;
+
protected AlignViewport av;
+
protected AlignmentPanel alignPanel;
+
ScrollThread scrollThread = null;
+
+ String linkImageURL;
+
int offy;
+
// int width;
int lastid = -1;
+
boolean mouseDragging = false;
/**
* Creates a new IdPanel object.
- *
- * @param av DOCUMENT ME!
- * @param parent DOCUMENT ME!
+ *
+ * @param av
+ * DOCUMENT ME!
+ * @param parent
+ * DOCUMENT ME!
*/
public IdPanel(AlignViewport av, AlignmentPanel parent)
{
this.av = av;
alignPanel = parent;
idCanvas = new IdCanvas(av);
+ linkImageURL = getClass().getResource("/images/link.gif").toString();
setLayout(new BorderLayout());
add(idCanvas, BorderLayout.CENTER);
addMouseListener(this);
@@ -65,12 +76,14 @@ public class IdPanel
/**
* DOCUMENT ME!
- *
- * @param e DOCUMENT ME!
+ *
+ * @param e
+ * DOCUMENT ME!
*/
public void mouseMoved(MouseEvent e)
{
- int seq = Math.max(0, alignPanel.seqPanel.findSeq(e));
+ SeqPanel sp = alignPanel.seqPanel;
+ int seq = Math.max(0, sp.findSeq(e));
String tmp;
if (seq > -1 && seq < av.alignment.getHeight())
{
@@ -82,12 +95,12 @@ public class IdPanel
if (sequence.getDescription() != null)
{
tmp = sequence.getDescription();
- tip.append("
"+tmp);
+ tip.append("
" + tmp);
maxWidth = Math.max(maxWidth, tmp.length());
}
DBRefEntry[] dbrefs = sequence.getDatasetSequence().getDBRef();
- if (dbrefs != null)
+ if (av.isShowDbRefs() && dbrefs != null)
{
for (int i = 0; i < dbrefs.length; i++)
{
@@ -98,41 +111,44 @@ public class IdPanel
}
}
-
- //ADD NON POSITIONAL SEQUENCE INFO
- SequenceFeature[] features = sequence.getDatasetSequence().
- getSequenceFeatures();
- if (features != null)
+ // ADD NON POSITIONAL SEQUENCE INFO
+ SequenceFeature[] features = sequence.getDatasetSequence()
+ .getSequenceFeatures();
+ SequenceFeature[] tfeat = new SequenceFeature[1];
+ if (av.isShowNpFeats() && features != null)
{
for (int i = 0; i < features.length; i++)
{
if (features[i].begin == 0 && features[i].end == 0)
{
- tmp = features[i].featureGroup
- + " " + features[i].getType() + " " +
- features[i].description;
- tip.append("
" + tmp);
- maxWidth = Math.max(maxWidth, tmp.length());
+ int sz = -tip.length();
+ tfeat[0] = features[i];
+ sp.appendFeatures(tip, linkImageURL, 0, tfeat,
+ sp.seqCanvas.fr.minmax);
+ sz += tip.length();
+ maxWidth = Math.max(maxWidth, sz);
}
}
}
- if(maxWidth > 60)
+ if (maxWidth > 60)
{
- tip.insert(0, "
");
+ tip.insert(0, "");
}
tip.append("