X-Git-Url: http://source.jalview.org/gitweb/?a=blobdiff_plain;ds=sidebyside;f=src%2Fjalview%2Fgui%2FSeqPanel.java;h=4fac4fc091b43aa9df612eff8d589395defd2508;hb=aa213924876640ba82e866da5a750d9cdaa816d2;hp=b8902bd0b18aeb1b44b5f863ccdccb9fdad4fdef;hpb=d053a3c980cf4318b9a19a255f9fc870e74de989;p=jalview.git diff --git a/src/jalview/gui/SeqPanel.java b/src/jalview/gui/SeqPanel.java index b8902bd..4fac4fc 100644 --- a/src/jalview/gui/SeqPanel.java +++ b/src/jalview/gui/SeqPanel.java @@ -1,23 +1,24 @@ /* * 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 - * + * * 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 + * 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. - * - * 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 + * + * 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 . */ package jalview.gui; import java.util.*; +import java.util.List; import java.awt.*; import java.awt.event.*; @@ -26,12 +27,13 @@ import javax.swing.*; import jalview.commands.*; import jalview.datamodel.*; +import jalview.io.SequenceAnnotationReport; import jalview.schemes.*; import jalview.structure.*; /** * DOCUMENT ME! - * + * * @author $author$ * @version $Revision: 1.130 $ */ @@ -86,7 +88,7 @@ public class SeqPanel extends JPanel implements MouseListener, StringBuffer keyboardNo2; java.net.URL linkImageURL; - + private final SequenceAnnotationReport seqARep; StringBuffer tooltipText = new StringBuffer(""); String tmpString; @@ -97,7 +99,7 @@ public class SeqPanel extends JPanel implements MouseListener, /** * Creates a new SeqPanel object. - * + * * @param avp * DOCUMENT ME! * @param p @@ -106,6 +108,7 @@ public class SeqPanel extends JPanel implements MouseListener, public SeqPanel(AlignViewport av, AlignmentPanel ap) { linkImageURL = getClass().getResource("/images/link.gif"); + seqARep=new SequenceAnnotationReport(linkImageURL.toString()); ToolTipManager.sharedInstance().registerComponent(this); ToolTipManager.sharedInstance().setInitialDelay(0); ToolTipManager.sharedInstance().setDismissDelay(10000); @@ -297,7 +300,7 @@ public class SeqPanel extends JPanel implements MouseListener, void setCursorPosition() { - SequenceI sequence = (Sequence) av.getAlignment().getSequenceAt( + SequenceI sequence = av.getAlignment().getSequenceAt( seqCanvas.cursorY); seqCanvas.cursorX = sequence.findIndex(getKeyboardNo1() - 1); @@ -392,7 +395,7 @@ public class SeqPanel extends JPanel implements MouseListener, void setSelectionAreaAtCursor(boolean topLeft) { - SequenceI sequence = (Sequence) av.getAlignment().getSequenceAt( + SequenceI sequence = av.getAlignment().getSequenceAt( seqCanvas.cursorY); if (av.getSelectionGroup() != null) @@ -482,7 +485,7 @@ public class SeqPanel extends JPanel implements MouseListener, editSequence(false, false, seqCanvas.cursorX); endEditing(); } - + void insertNucAtCursor(boolean group,String nuc){ groupEditing = group; startseq = seqCanvas.cursorY; @@ -534,10 +537,11 @@ public class SeqPanel extends JPanel implements MouseListener, /** * DOCUMENT ME! - * + * * @param evt * DOCUMENT ME! */ + @Override public void mouseReleased(MouseEvent evt) { mouseDragging = false; @@ -554,10 +558,11 @@ public class SeqPanel extends JPanel implements MouseListener, /** * DOCUMENT ME! - * + * * @param evt * DOCUMENT ME! */ + @Override public void mousePressed(MouseEvent evt) { lastMousePress = evt.getPoint(); @@ -607,6 +612,7 @@ public class SeqPanel extends JPanel implements MouseListener, String lastMessage; + @Override public void mouseOverSequence(SequenceI sequence, int index, int pos) { String tmp = sequence.hashCode() + " " + index + " " + pos; @@ -619,6 +625,7 @@ public class SeqPanel extends JPanel implements MouseListener, lastMessage = tmp; } + @Override public void highlightSequence(SearchResults results) { if (av.followHighlight) @@ -631,6 +638,7 @@ public class SeqPanel extends JPanel implements MouseListener, seqCanvas.highlightSearchResults(results); } + @Override public void updateColours(SequenceI seq, int index) { System.out.println("update the seqPanel colours"); @@ -639,10 +647,11 @@ public class SeqPanel extends JPanel implements MouseListener, /** * DOCUMENT ME! - * + * * @param evt * DOCUMENT ME! */ + @Override public void mouseMoved(MouseEvent evt) { if (editingSeqs) @@ -706,7 +715,7 @@ public class SeqPanel extends JPanel implements MouseListener, SequenceFeature[] features = findFeaturesAtRes( sequence.getDatasetSequence(), rpos = sequence.findPosition(res)); - appendFeatures(tooltipText, linkImageURL.toString(), rpos, features, + seqARep.appendFeatures(tooltipText, rpos, features, this.ap.seqPanel.seqCanvas.fr.minmax); } if (tooltipText.length() == 6) // @@ -752,151 +761,12 @@ public class SeqPanel extends JPanel implements MouseListener, return lastp = p; } - /** - * appends the features at rpos to the given stringbuffer ready for display in - * a tooltip - * - * @param tooltipText2 - * @param linkImageURL - * @param rpos - * @param features - * TODO refactor to Jalview 'utilities' somehow. - */ - public void appendFeatures(StringBuffer tooltipText2, - String linkImageURL, int rpos, SequenceFeature[] features) - { - appendFeatures(tooltipText2, linkImageURL, rpos, features, null); - } - - public void appendFeatures(StringBuffer tooltipText2, String string, - int rpos, SequenceFeature[] features, Hashtable minmax) - { - String tmpString; - if (features != null) - { - for (int i = 0; i < features.length; i++) - { - if (features[i].getType().equals("disulfide bond")) - { - if (features[i].getBegin() == rpos - || features[i].getEnd() == rpos) - { - if (tooltipText2.length() > 6) - { - tooltipText2.append("
"); - } - tooltipText2.append("disulfide bond " + features[i].getBegin() - + ":" + features[i].getEnd()); - if (features[i].links != null) - { - tooltipText2.append(" "); - } - } - } - else - { - if (tooltipText2.length() > 6) - { - tooltipText2.append("
"); - } - // TODO: remove this hack to display link only features - boolean linkOnly = features[i].getValue("linkonly") != null; - if (!linkOnly) - { - tooltipText2.append(features[i].getType() + " "); - if (rpos != 0) - { - // we are marking a positional feature - tooltipText2.append(features[i].begin); - } - if (features[i].begin != features[i].end) - { - tooltipText2.append(" " + features[i].end); - } - - if (features[i].getDescription() != null - && !features[i].description.equals(features[i] - .getType())) - { - tmpString = features[i].getDescription(); - String tmp2up=tmpString.toUpperCase(); - int startTag = tmp2up.indexOf(""); - if (startTag > -1) - { - tmpString = tmpString.substring(startTag + 6); - tmp2up = tmp2up.substring(startTag+6); - } - int endTag = tmp2up.indexOf(""); - if (endTag > -1) - { - tmpString = tmpString.substring(0, endTag); - tmp2up = tmp2up.substring(0, endTag); - } - endTag = tmp2up.indexOf(""); - if (endTag > -1) - { - tmpString = tmpString.substring(0, endTag); - } - - if (startTag > -1) - { - tooltipText2.append("; " + tmpString); - } - else - { - if (tmpString.indexOf("<") > -1 - || tmpString.indexOf(">") > -1) - { - // The description does not specify html is to - // be used, so we must remove < > symbols - tmpString = tmpString.replaceAll("<", "<"); - tmpString = tmpString.replaceAll(">", ">"); - - tooltipText2.append("; "); - tooltipText2.append(tmpString); - - } - else - { - tooltipText2.append("; " + tmpString); - } - } - } - // check score should be shown - if (features[i].getScore() != Float.NaN) - { - float[][] rng = (minmax == null) ? null : ((float[][]) minmax - .get(features[i].getType())); - if (rng != null && rng[0] != null && rng[0][0] != rng[0][1]) - { - tooltipText2.append(" Score=" + features[i].getScore()); - } - } - if (features[i].getValue("status") != null) - { - String status = features[i].getValue("status").toString(); - if (status.length() > 0) - { - tooltipText2.append("; (" + features[i].getValue("status") - + ")"); - } - } - } - if (features[i].links != null) - { - tooltipText2.append(" "); - } - - } - } - } - } String lastTooltip; /** * Set status message in alignment panel - * + * * @param sequence * aligned sequence object * @param res @@ -944,10 +814,11 @@ public class SeqPanel extends JPanel implements MouseListener, /** * DOCUMENT ME! - * + * * @param evt * DOCUMENT ME! */ + @Override public void mouseDragged(MouseEvent evt) { if (mouseWheelPressed) @@ -1101,7 +972,7 @@ public class SeqPanel extends JPanel implements MouseListener, // but the sequence represents a group if (sg == null) { - if (av.isHiddenRepSequence(seq)) + if (!av.isHiddenRepSequence(seq)) { endEditing(); return; @@ -1163,12 +1034,12 @@ public class SeqPanel extends JPanel implements MouseListener, if (groupEditing) { - Vector vseqs = sg.getSequences(av.getHiddenRepSequences()); + List vseqs = sg.getSequences(av.getHiddenRepSequences()); int g, groupSize = vseqs.size(); SequenceI[] groupSeqs = new SequenceI[groupSize]; for (g = 0; g < groupSeqs.length; g++) { - groupSeqs[g] = (SequenceI) vseqs.elementAt(g); + groupSeqs[g] = vseqs.get(g); } // drag to right @@ -1424,10 +1295,11 @@ public class SeqPanel extends JPanel implements MouseListener, /** * DOCUMENT ME! - * + * * @param e * DOCUMENT ME! */ + @Override public void mouseEntered(MouseEvent e) { if (oldSeq < 0) @@ -1444,10 +1316,11 @@ public class SeqPanel extends JPanel implements MouseListener, /** * DOCUMENT ME! - * + * * @param e * DOCUMENT ME! */ + @Override public void mouseExited(MouseEvent e) { if (av.getWrapAlignment()) @@ -1461,6 +1334,7 @@ public class SeqPanel extends JPanel implements MouseListener, } } + @Override public void mouseClicked(MouseEvent evt) { SequenceGroup sg = null; @@ -1495,23 +1369,35 @@ public class SeqPanel extends JPanel implements MouseListener, } } + @Override public void mouseWheelMoved(MouseWheelEvent e) { e.consume(); if (e.getWheelRotation() > 0) { - ap.scrollUp(false); + if (e.isShiftDown()) + { + ap.scrollRight(true); + + } else { + ap.scrollUp(false); + } } else { - ap.scrollUp(true); + if (e.isShiftDown()) + { + ap.scrollRight(false); + } else { + ap.scrollUp(true); + } } // TODO Update tooltip for new position. } /** * DOCUMENT ME! - * + * * @param evt * DOCUMENT ME! */ @@ -1536,7 +1422,7 @@ public class SeqPanel extends JPanel implements MouseListener, return; } - SequenceI sequence = (Sequence) av.getAlignment().getSequenceAt(seq); + SequenceI sequence = av.getAlignment().getSequenceAt(seq); if ((sequence == null) || (res > sequence.getLength())) { @@ -1656,7 +1542,7 @@ public class SeqPanel extends JPanel implements MouseListener, /** * DOCUMENT ME! - * + * * @param evt * DOCUMENT ME! */ @@ -1673,9 +1559,8 @@ public class SeqPanel extends JPanel implements MouseListener, { if (stretchGroup.cs instanceof ClustalxColourScheme) { - ((ClustalxColourScheme) stretchGroup.cs).resetClustalX( - stretchGroup.getSequences(av.getHiddenRepSequences()), - stretchGroup.getWidth()); + ((ClustalxColourScheme) stretchGroup.cs).alignmentChanged( + stretchGroup,av.getHiddenRepSequences()); } if (stretchGroup.cs.conservationApplied()) @@ -1700,7 +1585,7 @@ public class SeqPanel extends JPanel implements MouseListener, /** * DOCUMENT ME! - * + * * @param evt * DOCUMENT ME! */ @@ -1857,6 +1742,7 @@ public class SeqPanel extends JPanel implements MouseListener, running = false; } + @Override public void run() { running = true; @@ -1899,6 +1785,7 @@ public class SeqPanel extends JPanel implements MouseListener, /** * modify current selection according to a received message. */ + @Override public void selection(SequenceGroup seqsel, ColumnSelection colsel, SelectionSource source) {