/*
* 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
*/
package jalview.gui;
import java.awt.*;
import java.awt.event.*;
import javax.swing.*;
import jalview.datamodel.*;
/**
* DOCUMENT ME!
*
* @author $author$
* @version $Revision$
*/
public class IdPanel
extends JPanel implements MouseListener,
MouseMotionListener, MouseWheelListener
{
protected IdCanvas idCanvas;
protected AlignViewport av;
protected AlignmentPanel alignPanel;
ScrollThread scrollThread = null;
int offy;
int width;
int lastid = -1;
boolean mouseDragging = false;
/**
* Creates a new IdPanel object.
*
* @param av DOCUMENT ME!
* @param parent DOCUMENT ME!
*/
public IdPanel(AlignViewport av, AlignmentPanel parent)
{
this.av = av;
alignPanel = parent;
idCanvas = new IdCanvas(av);
setLayout(new BorderLayout());
add(idCanvas, BorderLayout.CENTER);
addMouseListener(this);
addMouseMotionListener(this);
addMouseWheelListener(this);
ToolTipManager.sharedInstance().registerComponent(this);
}
/**
* DOCUMENT ME!
*
* @param e DOCUMENT ME!
*/
public void mouseMoved(MouseEvent e)
{
int seq = Math.max(0, alignPanel.seqPanel.findSeq(e));
String tmp;
if (seq > -1 && seq < av.alignment.getHeight())
{
SequenceI sequence = av.alignment.getSequenceAt(seq);
StringBuffer tip = new StringBuffer();
int maxWidth = 0;
if (sequence.getDescription() != null)
{
tmp = sequence.getDescription();
tip.append(tmp);
maxWidth = Math.max(maxWidth, tmp.length());
}
DBRefEntry[] dbrefs = sequence.getDatasetSequence().getDBRef();
if (dbrefs != null)
{
tip.append("");
for (int i = 0; i < dbrefs.length; i++)
{
tip.append("
");
tmp = dbrefs[i].getSource() + " " + dbrefs[i].getAccessionId();
tip.append(tmp);
maxWidth = Math.max(maxWidth, tmp.length());
}
tip.append("");
}
//ADD NON POSITIONAL SEQUENCE INFO
SequenceFeature[] features = sequence.getDatasetSequence().
getSequenceFeatures();
if (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());
}
}
}
if(maxWidth > 60)
{
tip.insert(0, "
"); tip.append(" |