X-Git-Url: http://source.jalview.org/gitweb/?a=blobdiff_plain;f=src%2Fjalview%2Fappletgui%2FIdPanel.java;h=eba52d562a8f820bd2d21acdeff62994ba6aab1a;hb=17e77c3f2949a0729322b4a8d907f3f34b6a9914;hp=a7a20edf0108c068829d922ef416517408400216;hpb=8a6fa9ea9900d0f106529c3f6283e7f9d76dd2cb;p=jalview.git diff --git a/src/jalview/appletgui/IdPanel.java b/src/jalview/appletgui/IdPanel.java index a7a20ed..eba52d5 100755 --- a/src/jalview/appletgui/IdPanel.java +++ b/src/jalview/appletgui/IdPanel.java @@ -1,28 +1,40 @@ /* - * 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) + * 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.awt.*; -import java.awt.event.*; -import java.util.Vector; - -import jalview.datamodel.*; +import jalview.datamodel.Sequence; +import jalview.datamodel.SequenceFeature; +import jalview.datamodel.SequenceGroup; +import jalview.datamodel.SequenceI; import jalview.util.UrlLink; +import jalview.viewmodel.AlignmentViewport; + +import java.awt.BorderLayout; +import java.awt.Panel; +import java.awt.event.InputEvent; +import java.awt.event.MouseEvent; +import java.awt.event.MouseListener; +import java.awt.event.MouseMotionListener; +import java.util.List; +import java.util.Vector; public class IdPanel extends Panel implements MouseListener, MouseMotionListener @@ -30,16 +42,12 @@ public class IdPanel extends Panel implements MouseListener, protected IdCanvas idCanvas; - protected AlignViewport av; + protected AlignmentViewport av; protected AlignmentPanel alignPanel; ScrollThread scrollThread = null; - int offy; - - int width; - int lastid = -1; boolean mouseDragging = false; @@ -72,10 +80,21 @@ public class IdPanel extends Panel implements MouseListener, } } + { + // upgrade old SRS link + int srsPos = links + .indexOf("SRS|http://srs.ebi.ac.uk/srsbin/cgi-bin/wgetz?-newId+(([uniprot-all:$SEQUENCE_ID$]))+-view+SwissEntry"); + if (srsPos > -1) + { + links.setElementAt( + "EMBL-EBI Search|http://www.ebi.ac.uk/ebisearch/search.ebi?db=allebi&query=$SEQUENCE_ID$", + srsPos); + } + } if (links.size() < 1) { links = new java.util.Vector(); - links.addElement("SRS|http://srs.ebi.ac.uk/srsbin/cgi-bin/wgetz?-newId+(([uniprot-all:$SEQUENCE_ID$]))+-view+SwissEntry"); + links.addElement("EMBL-EBI Search|http://www.ebi.ac.uk/ebisearch/search.ebi?db=allebi&query=$SEQUENCE_ID$"); } } @@ -89,61 +108,62 @@ public class IdPanel extends Panel implements MouseListener, // look for non-pos features StringBuffer tooltiptext = new StringBuffer(); - - if (sequence.getDescription() != null) + if (sequence != null) { - tooltiptext.append(sequence.getDescription()); - tooltiptext.append("\n"); - } + if (sequence.getDescription() != null) + { + tooltiptext.append(sequence.getDescription()); + tooltiptext.append("\n"); + } - SequenceFeature sf[] = sequence.getSequenceFeatures(); - for (int sl = 0; sf != null && sl < sf.length; sl++) - { - if (sf[sl].begin == sf[sl].end && sf[sl].begin == 0) + SequenceFeature sf[] = sequence.getSequenceFeatures(); + for (int sl = 0; sf != null && sl < sf.length; sl++) { - boolean nl = false; - if (sf[sl].getFeatureGroup() != null) - { - tooltiptext.append(sf[sl].getFeatureGroup()); - nl = true; - } - ; - if (sf[sl].getType() != null) - { - tooltiptext.append(" "); - tooltiptext.append(sf[sl].getType()); - nl = true; - } - ; - if (sf[sl].getDescription() != null) - { - tooltiptext.append(" "); - tooltiptext.append(sf[sl].getDescription()); - nl = true; - } - ; - if (sf[sl].getScore() != Float.NaN && sf[sl].getScore() != 0f) - { - tooltiptext.append(" Score = "); - tooltiptext.append(sf[sl].getScore()); - nl = true; - } - ; - if (sf[sl].getStatus() != null && sf[sl].getStatus().length() > 0) - { - tooltiptext.append(" ("); - tooltiptext.append(sf[sl].getStatus()); - tooltiptext.append(")"); - nl = true; - } - ; - if (nl) + if (sf[sl].begin == sf[sl].end && sf[sl].begin == 0) { - tooltiptext.append("\n"); + boolean nl = false; + if (sf[sl].getFeatureGroup() != null) + { + tooltiptext.append(sf[sl].getFeatureGroup()); + nl = true; + } + ; + if (sf[sl].getType() != null) + { + tooltiptext.append(" "); + tooltiptext.append(sf[sl].getType()); + nl = true; + } + ; + if (sf[sl].getDescription() != null) + { + tooltiptext.append(" "); + tooltiptext.append(sf[sl].getDescription()); + nl = true; + } + ; + if (!Float.isNaN(sf[sl].getScore()) && sf[sl].getScore() != 0f) + { + tooltiptext.append(" Score = "); + tooltiptext.append(sf[sl].getScore()); + nl = true; + } + ; + if (sf[sl].getStatus() != null && sf[sl].getStatus().length() > 0) + { + tooltiptext.append(" ("); + tooltiptext.append(sf[sl].getStatus()); + tooltiptext.append(")"); + nl = true; + } + ; + if (nl) + { + tooltiptext.append("\n"); + } } } } - if (tooltiptext.length() == 0) { // nothing to display - so clear tooltip if one is visible @@ -196,7 +216,12 @@ public class IdPanel extends Panel implements MouseListener, // DEFAULT LINK IS FIRST IN THE LINK LIST int seq = alignPanel.seqPanel.findSeq(e); - String id = av.getAlignment().getSequenceAt(seq).getName(); + SequenceI sq = av.getAlignment().getSequenceAt(seq); + if (sq == null) + { + return; + } + String id = sq.getName(); String target = null; String url = null; @@ -266,7 +291,7 @@ public class IdPanel extends Panel implements MouseListener, } if (mouseDragging && e.getY() >= getSize().height - && av.alignment.getHeight() > av.getEndSeq()) + && av.getAlignment().getHeight() > av.getEndSeq()) { scrollThread = new ScrollThread(false); } @@ -282,7 +307,7 @@ public class IdPanel extends Panel implements MouseListener, int y = e.getY(); if (av.getWrapAlignment()) { - y -= 2 * av.charHeight; + y -= 2 * av.getCharHeight(); } int seq = alignPanel.seqPanel.findSeq(e); @@ -290,6 +315,7 @@ public class IdPanel extends Panel implements MouseListener, if ((e.getModifiers() & InputEvent.BUTTON3_MASK) == InputEvent.BUTTON3_MASK) { Sequence sq = (Sequence) av.getAlignment().getSequenceAt(seq); + // build a new links menu based on the current links + any non-positional // features Vector nlinks = new Vector(); @@ -297,7 +323,7 @@ public class IdPanel extends Panel implements MouseListener, { nlinks.addElement(links.elementAt(l)); } - SequenceFeature sf[] = sq.getSequenceFeatures(); + SequenceFeature sf[] = sq == null ? null : sq.getSequenceFeatures(); for (int sl = 0; sf != null && sl < sf.length; sl++) { if (sf[sl].begin == sf[sl].end && sf[sl].begin == 0) @@ -324,7 +350,7 @@ public class IdPanel extends Panel implements MouseListener, { av.setSelectionGroup(new SequenceGroup()); av.getSelectionGroup().setStartRes(0); - av.getSelectionGroup().setEndRes(av.alignment.getWidth() - 1); + av.getSelectionGroup().setEndRes(av.getAlignment().getWidth() - 1); } if (e.isShiftDown() && lastid != -1) @@ -343,7 +369,7 @@ public class IdPanel extends Panel implements MouseListener, { lastid = seq; SequenceI pickedSeq = av.getAlignment().getSequenceAt(seq); - av.getSelectionGroup().addOrRemove(pickedSeq, false); + av.getSelectionGroup().addOrRemove(pickedSeq, true); } void selectSeqs(int start, int end) @@ -363,11 +389,14 @@ public class IdPanel extends Panel implements MouseListener, end = tmp; lastid = end; } - + if (av.getSelectionGroup() == null) + { + av.setSelectionGroup(new SequenceGroup()); + } for (int i = start; i <= end; i++) { av.getSelectionGroup().addSequence( - av.getAlignment().getSequenceAt(i), false); + av.getAlignment().getSequenceAt(i), i == end); } } @@ -386,18 +415,20 @@ public class IdPanel extends Panel implements MouseListener, mouseDragging = false; PaintRefresher.Refresh(this, av.getSequenceSetId()); + // always send selection message when mouse is released + av.sendSelection(); } - public void highlightSearchResults(java.util.Vector found) + public void highlightSearchResults(List list) { - idCanvas.setHighlighted(found); + idCanvas.setHighlighted(list); - if (found == null) + if (list == null) { return; } - int index = av.alignment.findIndex((SequenceI) found.elementAt(0)); + int index = av.getAlignment().findIndex(list.get(0)); // do we need to scroll the panel? if (av.getStartSeq() > index || av.getEndSeq() < index) @@ -442,7 +473,7 @@ public class IdPanel extends Panel implements MouseListener, { selectSeqs(lastid - 1, seq); } - else if (seq > lastid && seq < av.alignment.getHeight()) + else if (seq > lastid && seq < av.getAlignment().getHeight()) { selectSeqs(lastid + 1, seq); } @@ -464,5 +495,4 @@ public class IdPanel extends Panel implements MouseListener, } } } - }