X-Git-Url: http://source.jalview.org/gitweb/?a=blobdiff_plain;f=src%2Fjalview%2Fgui%2FIdPanel.java;h=d1dc11de476c5f625a93841ea5d7a5aee3ee8b87;hb=621a628afc1f6ee7a2778b9d0ae2729b88fe5bfd;hp=4efef459777a53d992f6b4a8572c02fde8ec6b9b;hpb=588042b69abf8e60bcc950b24c283933c7dd422f;p=jalview.git
diff --git a/src/jalview/gui/IdPanel.java b/src/jalview/gui/IdPanel.java
index 4efef45..d1dc11d 100755
--- a/src/jalview/gui/IdPanel.java
+++ b/src/jalview/gui/IdPanel.java
@@ -18,316 +18,449 @@
*/
package jalview.gui;
+import jalview.datamodel.*;
+
import java.awt.*;
import java.awt.event.*;
+
import javax.swing.*;
-import jalview.datamodel.*;
-public class IdPanel
- extends JPanel implements MouseListener,
+/**
+ * DOCUMENT ME!
+ *
+ * @author $author$
+ * @version $Revision$
+ */
+public class IdPanel extends JPanel implements MouseListener,
MouseMotionListener
{
- protected IdCanvas idCanvas;
- protected AlignViewport av;
- protected AlignmentPanel alignPanel;
- ScrollThread scrollThread = null;
- int offy;
- int width;
- int lastid = -1;
- boolean mouseDragging = false;
-
- 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);
- }
-
- public void mouseMoved(MouseEvent e)
- {
- }
-
- public void mouseDragged(MouseEvent e)
- {
- mouseDragging = true;
-
- int y = e.getY();
-
- if (av.getWrapAlignment())
+ 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)
{
- y -= (2 * av.charHeight);
+ this.av = av;
+ alignPanel = parent;
+ idCanvas = new IdCanvas(av);
+ setLayout(new BorderLayout());
+ add(idCanvas, BorderLayout.CENTER);
+ addMouseListener(this);
+ addMouseMotionListener(this);
+ ToolTipManager.sharedInstance().registerComponent(this);
}
- int seq = av.getIndex(y);
-
- if (seq < 0)
+ /**
+ * DOCUMENT ME!
+ *
+ * @param e DOCUMENT ME!
+ */
+ public void mouseMoved(MouseEvent e)
{
- return;
+ int y = e.getY();
+
+ if (av.getWrapAlignment())
+ {
+ y = getWrappedY(y);
+ }
+
+ final int seq = av.getIndex(y);
+ if(seq!=-1)
+ {
+ SequenceI sequence = av.alignment.getSequenceAt(seq);
+ StringBuffer tip = new StringBuffer("");
+ tip.append(sequence.getDisplayId(true));
+ if (av.alignment.getSequenceAt(seq).getDescription() != null)
+ {
+ tip.append("
");
+ tip.append(av.alignment.getSequenceAt(seq).getDescription());
+
+ //ADD NON POSITIONAL SEQUENCE INFO
+ SequenceFeature [] features = sequence.getDatasetSequence().getSequenceFeatures();
+ if(features!=null)
+ {
+ for(int i=0; i"+features[i].featureGroup
+ +" "+ features[i].getType()+" "+features[i].description);
+ }
+ }
+ }
+
+ tip.append(" |
");
+ }
+ tip.append("");
+ setToolTipText(tip.toString());
+ }
}
- if (seq < lastid)
+
+ int getWrappedY(int y)
{
- selectSeqs(lastid - 1, seq);
+ int hgap = av.charHeight;
+ if (av.scaleAboveWrapped)
+ hgap += av.charHeight;
+
+ return y - hgap;
}
- else if (seq > lastid)
+
+
+ /**
+ * DOCUMENT ME!
+ *
+ * @param e DOCUMENT ME!
+ */
+ public void mouseDragged(MouseEvent e)
{
- selectSeqs(lastid + 1, seq);
+ mouseDragging = true;
+
+ int y = e.getY();
+
+ if (av.getWrapAlignment())
+ {
+ y = getWrappedY(y);
+ }
+
+ int seq = av.getIndex(y);
+
+ if (seq < 0)
+ {
+ return;
+ }
+
+ if (seq < lastid)
+ {
+ selectSeqs(lastid - 1, seq);
+ }
+ else if (seq > lastid)
+ {
+ selectSeqs(lastid + 1, seq);
+ }
+
+ lastid = seq;
+ alignPanel.repaint();
}
- lastid = seq;
- alignPanel.repaint();
- }
- public void mouseClicked(MouseEvent e)
- {
- if (e.getClickCount() == 2)
+ /**
+ * DOCUMENT ME!
+ *
+ * @param e DOCUMENT ME!
+ */
+ public void mouseClicked(MouseEvent e)
{
+ if (e.getClickCount() < 2)
+ return;
+
+ java.util.Vector links = Preferences.sequenceURLLinks;
+ if (links == null || links.size() < 1)
+ return;
+
int y = e.getY();
if (av.getWrapAlignment())
{
- y -= (2 * av.charHeight);
+ y = getWrappedY(y);
}
+ //DEFAULT LINK IS FIRST IN THE LINK LIST
int seq = av.getIndex(y);
+ if(seq==-1)
+ return;
+
String id = av.getAlignment().getSequenceAt(seq).getName();
+ if (id.indexOf("|") > -1)
+ id = id.substring(id.lastIndexOf("|") + 1);
+
+
+ String url = links.elementAt(0).toString();
+ url = url.substring(url.indexOf("|")+1);
+
+ int index = url.indexOf("$SEQUENCE_ID$");
+ url = url.substring(0, index)+ id + url.substring(index+13);
try
{
- jalview.util.BrowserLauncher.openURL(
- "http://srs.ebi.ac.uk/srs7bin/cgi-bin/wgetz?-e+[swall-id:" +
- id + "]+-vn+2");
+ jalview.util.BrowserLauncher.openURL(url);
}
catch (Exception ex)
{
- // TODO: JBPNote : state dependent error message for real browserLaunch problems rather than unix misconfiguration.
- System.err.println(ex.getMessage() +
- "\nUnixers: Try adding this jalview.browser property line \n" +
- "in your jalview.properties file (/usr/local/bin/firefox is an exanmple browser path):\n" +
- "jalview.browser=/usr/local/bin/firefox\n");
-
- //ex.printStackTrace();
+ JOptionPane.showInternalMessageDialog(Desktop.desktop,
+ "Unixers: Couldn't find default web browser."
+ +"\nAdd the full path to your browser in Preferences.",
+ "Web browser not found", JOptionPane.WARNING_MESSAGE );
+ ex.printStackTrace();
}
}
- }
-
- public void mouseEntered(MouseEvent e)
- {
- if (scrollThread != null)
- {
- scrollThread.running = false;
- }
- }
- public void mouseExited(MouseEvent e)
- {
- if (av.getWrapAlignment())
+ /**
+ * DOCUMENT ME!
+ *
+ * @param e DOCUMENT ME!
+ */
+ public void mouseEntered(MouseEvent e)
{
- return;
+ if (scrollThread != null)
+ {
+ scrollThread.running = false;
+ }
}
- if (mouseDragging && (e.getY() < 0) && (av.getStartSeq() > 0))
+ /**
+ * DOCUMENT ME!
+ *
+ * @param e DOCUMENT ME!
+ */
+ public void mouseExited(MouseEvent e)
{
- scrollThread = new ScrollThread(true);
- }
+ if (av.getWrapAlignment())
+ {
+ return;
+ }
- if (mouseDragging && (e.getY() >= getHeight()) &&
- (av.alignment.getHeight() > av.getEndSeq()))
- {
- scrollThread = new ScrollThread(false);
- }
- }
+ if (mouseDragging && (e.getY() < 0) && (av.getStartSeq() > 0))
+ {
+ scrollThread = new ScrollThread(true);
+ }
- public void mousePressed(MouseEvent e)
- {
- if (e.getClickCount() == 2)
- {
- return;
+ if (mouseDragging && (e.getY() >= getHeight()) &&
+ (av.alignment.getHeight() > av.getEndSeq()))
+ {
+ scrollThread = new ScrollThread(false);
+ }
}
- int y = e.getY();
-
- if (av.getWrapAlignment())
+ /**
+ * DOCUMENT ME!
+ *
+ * @param e DOCUMENT ME!
+ */
+ public void mousePressed(MouseEvent e)
{
- y -= (2 * av.charHeight);
- }
-
- int seq = av.getIndex(y);
+ if (e.getClickCount() == 2)
+ {
+ return;
+ }
- if (seq == -1)
- {
- return;
- }
+ int y = e.getY();
- if (javax.swing.SwingUtilities.isRightMouseButton(e))
- {
- jalview.gui.PopupMenu pop = new jalview.gui.PopupMenu(alignPanel,
- (Sequence) av.getAlignment().getSequenceAt(seq));
- pop.show(this, e.getX(), y);
+ if (av.getWrapAlignment())
+ {
+ y = getWrappedY(y);
+ }
- return;
- }
+ int seq = av.getIndex(y);
- if (!e.isControlDown() && !e.isShiftDown() &&
- (av.alignment.findGroup(av.alignment.getSequenceAt(seq)) != null))
- {
- SequenceGroup selection = new SequenceGroup();
- SequenceGroup sg = av.alignment.findGroup(av.alignment.getSequenceAt(
- seq));
- selection.setStartRes(0);
- selection.setEndRes(av.alignment.getWidth() - 1);
+ if (seq == -1)
+ {
+ return;
+ }
- for (int i = 0; i < sg.getSize(); i++)
- {
- selection.addSequence(sg.getSequenceAt(i));
- }
+ if (javax.swing.SwingUtilities.isRightMouseButton(e))
+ {
+ jalview.gui.PopupMenu pop = new jalview.gui.PopupMenu(alignPanel,
+ (Sequence) av.getAlignment().getSequenceAt(seq),
+ Preferences.sequenceURLLinks);
+ pop.show(this, e.getX(), y);
- av.setSelectionGroup(selection);
+ return;
+ }
- return;
- }
+ /* if (!e.isControlDown() && !e.isShiftDown() &&
+ (av.alignment.findGroup(av.alignment.getSequenceAt(seq)) != null))
+ {
+ System.out.println("no modifiers");
+ SequenceGroup selection = new SequenceGroup();
+ SequenceGroup sg = av.alignment.findGroup(av.alignment.getSequenceAt(
+ seq));
+ selection.setStartRes(0);
+ selection.setEndRes(av.alignment.getWidth() - 1);
- if ( (av.getSelectionGroup() == null) ||
- (!e.isControlDown() && (av.getSelectionGroup() != null)))
- {
- av.setSelectionGroup(new SequenceGroup());
- }
+ for (int i = 0; i < sg.getSize(); i++)
+ {
+ selection.addSequence(sg.getSequenceAt(i), true);
+ }
- av.getSelectionGroup().setStartRes(0);
- av.getSelectionGroup().setEndRes(av.alignment.getWidth() - 1);
+ av.setSelectionGroup(selection);
- if (e.isShiftDown() && (lastid != -1))
- {
- selectSeqs(lastid, seq);
- }
- else
- {
- selectSeq(seq);
- }
+ return;
+ }*/
- alignPanel.repaint();
- }
+ if ((av.getSelectionGroup() == null) ||
+ ((!e.isControlDown() && !e.isShiftDown()) && av.getSelectionGroup() != null))
+ {
+ av.setSelectionGroup(new SequenceGroup());
+ av.getSelectionGroup().setStartRes(0);
+ av.getSelectionGroup().setEndRes(av.alignment.getWidth() - 1);
+ }
- void selectSeq(int seq)
- {
- lastid = seq;
- SequenceI pickedSeq = av.getAlignment().getSequenceAt(seq);
- av.getSelectionGroup().addOrRemove(pickedSeq);
- }
- void selectSeqs(int start, int end)
- {
- lastid = start;
+ if (e.isShiftDown() && (lastid != -1))
+ {
+ selectSeqs(lastid, seq);
+ }
+ else
+ {
+ selectSeq(seq);
+ }
- if (end < start)
- {
- int tmp = start;
- start = end;
- end = tmp;
- lastid = end;
+ alignPanel.repaint();
}
- for (int i = start; i <= end; i++)
+ /**
+ * DOCUMENT ME!
+ *
+ * @param seq DOCUMENT ME!
+ */
+ void selectSeq(int seq)
{
- av.getSelectionGroup().addSequence(av.getAlignment().getSequenceAt(i));
- }
- }
+ lastid = seq;
- public void mouseReleased(MouseEvent e)
- {
- if (scrollThread != null)
- {
- scrollThread.running = false;
+ SequenceI pickedSeq = av.getAlignment().getSequenceAt(seq);
+ av.getSelectionGroup().addOrRemove(pickedSeq, true);
}
- mouseDragging = false;
- PaintRefresher.Refresh(this);
- }
-
- public void highlightSearchResults(java.util.Vector found)
- {
- idCanvas.setHighlighted(found);
-
- if (found == null)
+ /**
+ * DOCUMENT ME!
+ *
+ * @param start DOCUMENT ME!
+ * @param end DOCUMENT ME!
+ */
+ void selectSeqs(int start, int end)
{
- return;
- }
-
- int index = av.alignment.findIndex( (SequenceI) found.get(0));
+ if(av.getSelectionGroup()==null)
+ return;
- // do we need to scroll the panel?
- if ( (av.getStartSeq() > index) || (av.getEndSeq() < index))
- {
- alignPanel.setScrollValues(av.getStartRes(), index);
- }
- }
+ lastid = start;
- // this class allows scrolling off the bottom of the visible alignment
- class ScrollThread
- extends Thread
- {
- boolean running = false;
- boolean up = true;
+ if (end < start)
+ {
+ int tmp = start;
+ start = end;
+ end = tmp;
+ lastid = end;
+ }
- public ScrollThread(boolean up)
- {
- this.up = up;
- start();
+ for (int i = start; i <= end; i++)
+ {
+ av.getSelectionGroup().addSequence(av.getAlignment().getSequenceAt(i),
+ true);
+ }
}
- public void stopScrolling()
+ /**
+ * DOCUMENT ME!
+ *
+ * @param e DOCUMENT ME!
+ */
+ public void mouseReleased(MouseEvent e)
{
- running = false;
+ if (scrollThread != null)
+ {
+ scrollThread.running = false;
+ }
+
+ mouseDragging = false;
+ PaintRefresher.Refresh(av.alignment);
}
- public void run()
+ /**
+ * DOCUMENT ME!
+ *
+ * @param found DOCUMENT ME!
+ */
+ public void highlightSearchResults(java.util.Vector found)
{
- running = true;
+ idCanvas.setHighlighted(found);
- while (running)
- {
- if (alignPanel.scrollUp(up))
+ if (found == null)
{
- // scroll was ok, so add new sequence to selection
- int seq = av.getStartSeq();
-
- if (!up)
- {
- seq = av.getEndSeq();
- }
+ return;
+ }
- if (seq < lastid)
- {
- selectSeqs(lastid - 1, seq);
- }
- else if (seq > lastid)
- {
- selectSeqs(lastid + 1, seq);
- }
+ int index = av.alignment.findIndex((SequenceI) found.get(0));
- lastid = seq;
- }
- else
+ // do we need to scroll the panel?
+ if ((av.getStartSeq() > index) || (av.getEndSeq() < index))
{
- running = false;
+ alignPanel.setScrollValues(av.getStartRes(), index);
}
+ }
- alignPanel.repaint();
+ // this class allows scrolling off the bottom of the visible alignment
+ class ScrollThread extends Thread
+ {
+ boolean running = false;
+ boolean up = true;
+
+ public ScrollThread(boolean up)
+ {
+ this.up = up;
+ start();
+ }
- try
+ public void stopScrolling()
{
- Thread.sleep(100);
+ running = false;
}
- catch (Exception ex)
+
+ public void run()
{
+ running = true;
+
+ while (running)
+ {
+ if (alignPanel.scrollUp(up))
+ {
+ // scroll was ok, so add new sequence to selection
+ int seq = av.getStartSeq();
+
+ if (!up)
+ {
+ seq = av.getEndSeq();
+ }
+
+ if (seq < lastid)
+ {
+ selectSeqs(lastid - 1, seq);
+ }
+ else if (seq > lastid)
+ {
+ selectSeqs(lastid + 1, seq);
+ }
+
+ lastid = seq;
+ }
+ else
+ {
+ running = false;
+ }
+
+ alignPanel.repaint();
+
+ try
+ {
+ Thread.sleep(100);
+ }
+ catch (Exception ex)
+ {
+ }
+ }
}
- }
}
- }
}