X-Git-Url: http://source.jalview.org/gitweb/?a=blobdiff_plain;f=src%2Fjalview%2Fgui%2FIdPanel.java;h=d80c4b86144bc03388f143e62c974c1afaea856c;hb=50a8dcccc09f983c21f0c9a8a3653c379c348a4b;hp=4efef459777a53d992f6b4a8572c02fde8ec6b9b;hpb=588042b69abf8e60bcc950b24c283933c7dd422f;p=jalview.git diff --git a/src/jalview/gui/IdPanel.java b/src/jalview/gui/IdPanel.java index 4efef45..d80c4b8 100755 --- a/src/jalview/gui/IdPanel.java +++ b/src/jalview/gui/IdPanel.java @@ -1,6 +1,6 @@ /* * Jalview - A Sequence Alignment Editor and Viewer - * Copyright (C) 2005 AM Waterhouse, J Procter, G Barton, M Clamp, S Searle + * 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 @@ -24,9 +24,15 @@ import javax.swing.*; import jalview.datamodel.*; +/** + * DOCUMENT ME! + * + * @author $author$ + * @version $Revision$ + */ public class IdPanel extends JPanel implements MouseListener, - MouseMotionListener + MouseMotionListener, MouseWheelListener { protected IdCanvas idCanvas; protected AlignViewport av; @@ -37,6 +43,12 @@ public class IdPanel 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; @@ -46,29 +58,74 @@ public class IdPanel 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)); + if (seq > -1 && seq < av.alignment.getHeight()) + { + SequenceI sequence = av.alignment.getSequenceAt(seq); + StringBuffer tip = new StringBuffer(""); + tip.append(sequence.getDisplayId(true)); + if (sequence.getDescription() != null) + { + tip.append("
"); + tip.append(sequence.getDescription()); - public void mouseDragged(MouseEvent e) - { - mouseDragging = true; + //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) + { + tip.append("
" + features[i].featureGroup + + " " + features[i].getType() + " " + + features[i].description); + } + } + } + tip.append("
"); + } - int y = e.getY(); + DBRefEntry[] dbrefs = sequence.getDatasetSequence().getDBRef(); + if (dbrefs != null) + { + tip.append(""); + for (int i = 0; i < dbrefs.length; i++) + { + tip.append("
"); + tip.append(dbrefs[i].getSource() + " " + + dbrefs[i].getAccessionId()); + } + tip.append("
"); + } - if (av.getWrapAlignment()) - { - y -= (2 * av.charHeight); + tip.append(""); + setToolTipText(tip.toString()); } + } - int seq = av.getIndex(y); + /** + * DOCUMENT ME! + * + * @param e DOCUMENT ME! + */ + public void mouseDragged(MouseEvent e) + { + mouseDragging = true; - if (seq < 0) - { - return; - } + int seq = Math.max(0, alignPanel.seqPanel.findSeq(e)); if (seq < lastid) { @@ -80,42 +137,77 @@ public class IdPanel } lastid = seq; - alignPanel.repaint(); + alignPanel.paintAlignment(true); + } + + public void mouseWheelMoved(MouseWheelEvent e) + { + e.consume(); + if (e.getWheelRotation() > 0) + { + alignPanel.scrollUp(false); + } + else + { + alignPanel.scrollUp(true); + } } + /** + * DOCUMENT ME! + * + * @param e DOCUMENT ME! + */ public void mouseClicked(MouseEvent e) { - if (e.getClickCount() == 2) + if (e.getClickCount() < 2) { - int y = e.getY(); + return; + } - if (av.getWrapAlignment()) - { - y -= (2 * av.charHeight); - } + java.util.Vector links = Preferences.sequenceURLLinks; + if (links == null || links.size() < 1) + { + return; + } - int seq = av.getIndex(y); - String id = av.getAlignment().getSequenceAt(seq).getName(); + int seq = alignPanel.seqPanel.findSeq(e); - try - { - jalview.util.BrowserLauncher.openURL( - "http://srs.ebi.ac.uk/srs7bin/cgi-bin/wgetz?-e+[swall-id:" + - id + "]+-vn+2"); - } - 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"); + //DEFAULT LINK IS FIRST IN THE LINK LIST - //ex.printStackTrace(); - } + 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(url); + } + catch (Exception ex) + { + 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(); } } + /** + * DOCUMENT ME! + * + * @param e DOCUMENT ME! + */ public void mouseEntered(MouseEvent e) { if (scrollThread != null) @@ -124,6 +216,11 @@ public class IdPanel } } + /** + * DOCUMENT ME! + * + * @param e DOCUMENT ME! + */ public void mouseExited(MouseEvent e) { if (av.getWrapAlignment()) @@ -143,6 +240,11 @@ public class IdPanel } } + /** + * DOCUMENT ME! + * + * @param e DOCUMENT ME! + */ public void mousePressed(MouseEvent e) { if (e.getClickCount() == 2) @@ -150,57 +252,26 @@ public class IdPanel return; } - int y = e.getY(); - - if (av.getWrapAlignment()) - { - y -= (2 * av.charHeight); - } - - int seq = av.getIndex(y); - - if (seq == -1) - { - return; - } + int seq = alignPanel.seqPanel.findSeq(e); 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); - - return; - } - - 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); - - for (int i = 0; i < sg.getSize(); i++) - { - selection.addSequence(sg.getSequenceAt(i)); - } - - av.setSelectionGroup(selection); + (Sequence) av.getAlignment().getSequenceAt(seq), + Preferences.sequenceURLLinks); + pop.show(this, e.getX(), e.getY()); return; } if ( (av.getSelectionGroup() == null) || - (!e.isControlDown() && (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); } - av.getSelectionGroup().setStartRes(0); - av.getSelectionGroup().setEndRes(av.alignment.getWidth() - 1); - if (e.isShiftDown() && (lastid != -1)) { selectSeqs(lastid, seq); @@ -210,19 +281,40 @@ public class IdPanel selectSeq(seq); } - alignPanel.repaint(); + alignPanel.paintAlignment(true); } + /** + * DOCUMENT ME! + * + * @param seq DOCUMENT ME! + */ void selectSeq(int seq) { lastid = seq; SequenceI pickedSeq = av.getAlignment().getSequenceAt(seq); - av.getSelectionGroup().addOrRemove(pickedSeq); + av.getSelectionGroup().addOrRemove(pickedSeq, true); } + /** + * DOCUMENT ME! + * + * @param start DOCUMENT ME! + * @param end DOCUMENT ME! + */ void selectSeqs(int start, int end) { + if (av.getSelectionGroup() == null) + { + return; + } + + if (end >= av.getAlignment().getHeight()) + { + end = av.getAlignment().getHeight() - 1; + } + lastid = start; if (end < start) @@ -235,10 +327,16 @@ public class IdPanel for (int i = start; i <= end; i++) { - av.getSelectionGroup().addSequence(av.getAlignment().getSequenceAt(i)); + av.getSelectionGroup().addSequence(av.getAlignment().getSequenceAt(i), + true); } } + /** + * DOCUMENT ME! + * + * @param e DOCUMENT ME! + */ public void mouseReleased(MouseEvent e) { if (scrollThread != null) @@ -247,9 +345,14 @@ public class IdPanel } mouseDragging = false; - PaintRefresher.Refresh(this); + PaintRefresher.Refresh(this, av.getSequenceSetId()); } + /** + * DOCUMENT ME! + * + * @param found DOCUMENT ME! + */ public void highlightSearchResults(java.util.Vector found) { idCanvas.setHighlighted(found); @@ -318,7 +421,7 @@ public class IdPanel running = false; } - alignPanel.repaint(); + alignPanel.paintAlignment(true); try {