X-Git-Url: http://source.jalview.org/gitweb/?a=blobdiff_plain;f=src%2Fjalview%2Fgui%2FIdCanvas.java;h=214f218c0294d16a65cecb7111c4c5669c5bf917;hb=e02486484d33e20dedb020a34f31f6024d5720a2;hp=9e64b1ed681b6ddccc903475cba70530bf829fe0;hpb=577f505f54fe343e89f581461e780ea8308c20ec;p=jalview.git diff --git a/src/jalview/gui/IdCanvas.java b/src/jalview/gui/IdCanvas.java index 9e64b1e..214f218 100755 --- a/src/jalview/gui/IdCanvas.java +++ b/src/jalview/gui/IdCanvas.java @@ -1,145 +1,349 @@ +/* + * Jalview - A Sequence Alignment Editor and Viewer + * Copyright (C) 2005 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 + * as published by the Free Software Foundation; either version 2 + * of the License, or (at your option) any later version. + * + * This program 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 this program; if not, write to the Free Software + * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA + */ package jalview.gui; +import jalview.datamodel.*; + import java.awt.*; -import java.awt.Graphics2D.*; +import java.awt.image.*; import javax.swing.*; -import jalview.datamodel.*; -import jalview.analysis.*; + + +/** + * DOCUMENT ME! + * + * @author $author$ + * @version $Revision$ + */ public class IdCanvas extends JPanel { - protected AlignViewport av; + protected AlignViewport av; + protected boolean showScores = true; + protected int maxIdLength = -1; + protected String maxIdStr = null; + BufferedImage image; + Graphics2D gg; + int imgHeight = 0; + boolean fastPaint = false; + java.util.Vector searchResults; + + /** + * Creates a new IdCanvas object. + * + * @param av DOCUMENT ME! + */ + public IdCanvas(AlignViewport av) + { + setLayout(new BorderLayout()); + this.av = av; + PaintRefresher.Register(this, av.alignment); + } - protected boolean showScores = true; + /** + * DOCUMENT ME! + * + * @param gg DOCUMENT ME! + * @param s DOCUMENT ME! + * @param i DOCUMENT ME! + * @param starty DOCUMENT ME! + * @param ypos DOCUMENT ME! + */ + public void drawIdString(Graphics2D gg, SequenceI s, int i, int starty, + int ypos) + { + int charHeight = av.charHeight; - protected int maxIdLength = -1; - protected String maxIdStr = null; + if ((searchResults != null) && searchResults.contains(s)) + { + gg.setColor(Color.black); + gg.fillRect(0, ((i - starty) * charHeight) + ypos, getWidth(), + charHeight); + gg.setColor(Color.white); + } + else if ((av.getSelectionGroup() != null) && + av.getSelectionGroup().sequences.contains(s)) + { + gg.setColor(Color.lightGray); + gg.fillRect(0, ((i - starty) * charHeight) + ypos, getWidth(), + charHeight); + gg.setColor(Color.white); + } + else + { + gg.setColor(s.getColor()); + gg.fillRect(0, ((i - starty) * charHeight) + ypos, getWidth(), + charHeight); + gg.setColor(Color.black); + } - public IdCanvas(AlignViewport av) - { - setLayout(new BorderLayout()); - this.av = av; - PaintRefresher.Register(this); - } - public void drawIdString(Graphics gg,SequenceI s,int i, int starty, int ypos) { - int charHeight = av.getCharHeight(); + gg.drawString( s.getDisplayId(av.getShowJVSuffix()), + 0, (((i - starty + 1) * charHeight) + ypos) - (charHeight / 5)); + } + /** + * DOCUMENT ME! + * + * @param vertical DOCUMENT ME! + */ + public void fastPaint(int vertical) + { + if (gg == null) + { + repaint(); - if (av.getSelectionGroup()!=null && av.getSelectionGroup().sequences.contains(s)) { - gg.setColor(Color.lightGray); - gg.fillRect(0,AlignmentUtil.getPixelHeight(starty,i,charHeight)+ ypos,getWidth(),charHeight); - gg.setColor(Color.white); - } else { - gg.setColor(s.getColor()); - gg.fillRect(0,AlignmentUtil.getPixelHeight(starty,i,charHeight)+ ypos,getWidth(),charHeight); - gg.setColor(Color.black); - } + return; + } - String string = s.getName() + "/" + s.getStart() + "-" + s.getEnd(); + gg.copyArea(0, 0, getWidth(), imgHeight, 0, -vertical * av.charHeight); - gg.drawString(string,0,AlignmentUtil.getPixelHeight(starty,i,charHeight) + ypos + charHeight- (charHeight/5)); + int ss = av.startSeq; + int es = av.endSeq; + int transY = 0; - } + if (vertical > 0) // scroll down + { + ss = es - vertical; - public void paintComponent(Graphics gg) { - AlignmentI al = av.alignment; - int charHeight = av.charHeight; - gg.setFont(av.getFont()); + if (ss < av.startSeq) + { // ie scrolling too fast, more than a page at a time + ss = av.startSeq; + } + else + { + transY = imgHeight - (vertical * av.charHeight); + } + } + else if (vertical < 0) + { + es = ss - vertical; - //Fill in the background - gg.setColor(Color.white); - gg.fillRect(0,0,getWidth(),getHeight()); + if (es > av.endSeq) + { + es = av.endSeq; + } + } - Color currentColor = Color.white; - Color currentTextColor = Color.black; + gg.translate(0, transY); - //Which ids are we printing - int starty = av.getStartSeq(); - int endy = av.endSeq; + drawIds(ss, es); - if (av.getWrapAlignment()) - { - // Draw the rest of the panels - int chunkHeight = (al.getHeight() + 2)*av.charHeight; - int row = av.getStartRes() / av.chunkWidth ; - for(int ypos=2*av.charHeight; - ypos <= getHeight() && row*av.chunkWidth idWidth) - idWidth = fm.stringWidth(str); - i++; - } + // Draw the rest of the panels + for (int ypos = hgap, row = av.startRes; + (ypos <= getHeight()) && (row < av.alignment.getWidth()); + ypos += cHeight, row += rowSize) + { + for (int i = starty; i < av.alignment.getHeight(); i++) + { - return new Dimension(idWidth + 10,getHeight()); - } + SequenceI s = av.alignment.getSequenceAt(i); + gg.setFont(italic); + drawIdString(gg, s, i, 0, ypos); + } - public Dimension getPreferredSize() - { - return getLabelWidth(); - } + if(labels!=null) + { + gg.translate(0, ypos+(av.getAlignment().getHeight() * av.charHeight)); + labels.drawComponent(gg, getWidth()); + gg.translate(0, -ypos-(av.getAlignment().getHeight() * av.charHeight)); + } + } + } + else + { + //Now draw the id strings + int tmp, hiddenIndex = starty; + boolean markHidden = false; + for (int i = starty; i < endy; i++) + { + if (av.hasHiddenRows) + { + tmp = av.adjustForHiddenSeqs(i); + if(hiddenIndex != tmp) + { + hiddenIndex = tmp; + markHidden = true; + } + else + markHidden = false; + + hiddenIndex++; + } + + if(av.hasHiddenRows && av.alignment.getSequenceAt(i).getHiddenSequences()!=null) + { + currentTextColor = Color.blue; + } + else + // Selected sequence colours + if ((searchResults != null) && + searchResults.contains(av.alignment.getSequenceAt(i))) + { + currentColor = Color.black; + currentTextColor = Color.white; + } + else if ((av.getSelectionGroup() != null) && + av.getSelectionGroup().sequences.contains( + av.alignment.getSequenceAt(i))) + { + currentColor = Color.lightGray; + currentTextColor = Color.black; + } + else + { + currentColor = av.alignment.getSequenceAt(i).getColor(); + currentTextColor = Color.black; + } + + gg.setColor(currentColor); + + gg.fillRect(0, (i - starty) * av.charHeight, getWidth(), + av.charHeight); + + if (markHidden) + { + gg.setColor(Color.blue); + // gg.drawLine(0, (i-starty)*av.charHeight, getWidth(),(i-starty)*av.charHeight); + gg.fillPolygon(new int[] { getWidth() - av.charHeight, + getWidth() - av.charHeight, + getWidth() }, + new int[] + { + (i-starty)*av.charHeight -av.charHeight/4, + (i-starty)*av.charHeight +av.charHeight/4, + (i-starty)*av.charHeight + }, 3); + + } + + gg.setColor(currentTextColor); + + String string = av.alignment.getSequenceAt(i).getDisplayId( av.getShowJVSuffix()); + + gg.drawString(string, 0, + (((i - starty) * av.charHeight) + av.charHeight) - + (av.charHeight / 5)); + } + // add a border + // gg.setColor(Color.cyan); + // gg.fillRect(getWidth() - 4, 0, 4, getHeight()); + } + } + + /** + * DOCUMENT ME! + * + * @param found DOCUMENT ME! + */ + public void setHighlighted(java.util.Vector found) + { + searchResults = found; + repaint(); + } }