X-Git-Url: http://source.jalview.org/gitweb/?a=blobdiff_plain;f=src%2Fjalview%2Fappletgui%2FIdPanel.java;h=36c21993161694c1b0379abfe2cfde818c3853ec;hb=c64a7d0a951e5ceee8cce4c8b15f86464e287b12;hp=0042856a913d2df47410a66cbb5dfc92a04bd15a;hpb=b81d4d7d46ea8b1c89df086fb847baab6b69d427;p=jalview.git diff --git a/src/jalview/appletgui/IdPanel.java b/src/jalview/appletgui/IdPanel.java index 0042856..36c2199 100755 --- a/src/jalview/appletgui/IdPanel.java +++ b/src/jalview/appletgui/IdPanel.java @@ -1,46 +1,53 @@ /* - * Jalview - A Sequence Alignment Editor and Viewer (Version 2.7) - * Copyright (C) 2011 J Procter, AM Waterhouse, J Engelhardt, LM Lui, G Barton, M Clamp, S Searle + * Jalview - A Sequence Alignment Editor and Viewer ($$Version-Rel$$) + * Copyright (C) $$Year-Rel$$ 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 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; -import jalview.datamodel.*; -import jalview.util.UrlLink; - public class IdPanel extends Panel implements MouseListener, MouseMotionListener { 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; @@ -73,15 +80,27 @@ 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$"); } } Tooltip tooltip; + @Override public void mouseMoved(MouseEvent e) { int seq = alignPanel.seqPanel.findSeq(e); @@ -124,7 +143,7 @@ public class IdPanel extends Panel implements MouseListener, nl = true; } ; - if (sf[sl].getScore() != Float.NaN && sf[sl].getScore() != 0f) + if (!Float.isNaN(sf[sl].getScore()) && sf[sl].getScore() != 0f) { tooltiptext.append(" Score = "); tooltiptext.append(sf[sl].getScore()); @@ -170,6 +189,7 @@ public class IdPanel extends Panel implements MouseListener, tooltiptext = null; } + @Override public void mouseDragged(MouseEvent e) { mouseDragging = true; @@ -189,6 +209,7 @@ public class IdPanel extends Panel implements MouseListener, alignPanel.paintAlignment(false); } + @Override public void mouseClicked(MouseEvent e) { if (e.getClickCount() < 2) @@ -199,7 +220,7 @@ public class IdPanel extends Panel implements MouseListener, // DEFAULT LINK IS FIRST IN THE LINK LIST int seq = alignPanel.seqPanel.findSeq(e); SequenceI sq = av.getAlignment().getSequenceAt(seq); - if (sq==null) + if (sq == null) { return; } @@ -252,6 +273,7 @@ public class IdPanel extends Panel implements MouseListener, } } + @Override public void mouseEntered(MouseEvent e) { if (scrollThread != null) @@ -260,6 +282,7 @@ public class IdPanel extends Panel implements MouseListener, } } + @Override public void mouseExited(MouseEvent e) { if (av.getWrapAlignment()) @@ -279,6 +302,7 @@ public class IdPanel extends Panel implements MouseListener, } } + @Override public void mousePressed(MouseEvent e) { if (e.getClickCount() > 1) @@ -289,7 +313,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); @@ -297,7 +321,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(); @@ -305,7 +329,7 @@ public class IdPanel extends Panel implements MouseListener, { nlinks.addElement(links.elementAt(l)); } - SequenceFeature sf[] = sq==null ? null: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) @@ -327,7 +351,8 @@ public class IdPanel extends Panel implements MouseListener, } if ((av.getSelectionGroup() == null) - || ((!e.isControlDown() && !e.isShiftDown()) && av + || ((!jalview.util.Platform.isControlDown(e) && !e + .isShiftDown()) && av .getSelectionGroup() != null)) { av.setSelectionGroup(new SequenceGroup()); @@ -351,7 +376,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) @@ -378,11 +403,12 @@ public class IdPanel extends Panel implements MouseListener, for (int i = start; i <= end; i++) { av.getSelectionGroup().addSequence( - av.getAlignment().getSequenceAt(i), false); + av.getAlignment().getSequenceAt(i), i == end); } } + @Override public void mouseReleased(MouseEvent e) { if (scrollThread != null) @@ -437,6 +463,7 @@ public class IdPanel extends Panel implements MouseListener, running = false; } + @Override public void run() { running = true; @@ -477,5 +504,4 @@ public class IdPanel extends Panel implements MouseListener, } } } - }