X-Git-Url: http://source.jalview.org/gitweb/?a=blobdiff_plain;f=src%2Fjalview%2Fgui%2FSequenceRenderer.java;h=e36160a939d13b843aa20a86dbad19a2116a7115;hb=04651a0a92ea1b6d9ce590a77ade2b90f446d949;hp=896fda5a7c916879d9775e8f65371050c0e3c672;hpb=588042b69abf8e60bcc950b24c283933c7dd422f;p=jalview.git diff --git a/src/jalview/gui/SequenceRenderer.java b/src/jalview/gui/SequenceRenderer.java index 896fda5..e36160a 100755 --- a/src/jalview/gui/SequenceRenderer.java +++ b/src/jalview/gui/SequenceRenderer.java @@ -18,237 +18,321 @@ */ package jalview.gui; -import java.awt.*; - import jalview.datamodel.*; + import jalview.schemes.*; +import java.awt.*; + + +/** + * DOCUMENT ME! + * + * @author $author$ + * @version $Revision$ + */ public class SequenceRenderer { - AlignViewport av; - FontMetrics fm; - boolean renderGaps = true; - SequenceGroup currentSequenceGroup = null; - SequenceGroup[] allGroups = null; - Color resBoxColour; - Graphics graphics; - - public SequenceRenderer(AlignViewport av) - { - this.av = av; - } - - public void renderGaps(boolean b) - { - renderGaps = b; - } - - public Color getResidueBoxColour(ColourSchemeI cs, SequenceI seq, int i) - { - getBoxColour(cs, seq, i); - - return resBoxColour; - } - - void getBoxColour(ColourSchemeI cs, SequenceI seq, int i) - { - if (cs != null) + AlignViewport av; + FontMetrics fm; + boolean renderGaps = true; + SequenceGroup currentSequenceGroup = null; + SequenceGroup[] allGroups = null; + Color resBoxColour; + Graphics graphics; + + /** + * Creates a new SequenceRenderer object. + * + * @param av DOCUMENT ME! + */ + public SequenceRenderer(AlignViewport av) { - resBoxColour = cs.findColour(seq.getSequence(i, i + 1), i); + this.av = av; } - else + + /** + * DOCUMENT ME! + * + * @param b DOCUMENT ME! + */ + public void renderGaps(boolean b) { - resBoxColour = Color.white; + renderGaps = b; } - } - - public void drawSequence(Graphics g, SequenceI seq, SequenceGroup[] sg, - int start, int end, int x1, int y1, int width, - int height) - { - allGroups = sg; - - graphics = g; - drawBoxes(seq, start, end, x1, y1, (int) width, height); - - fm = g.getFontMetrics(); - drawText(seq, start, end, x1, y1, (int) width, height); - } - - public void drawBoxes(SequenceI seq, int start, int end, int x1, int y1, - int width, int height) - { - int i = start; - int length = seq.getLength(); - - int curStart = -1; - int curWidth = width; + /** + * DOCUMENT ME! + * + * @param cs DOCUMENT ME! + * @param seq DOCUMENT ME! + * @param i DOCUMENT ME! + * + * @return DOCUMENT ME! + */ + public Color getResidueBoxColour(ColourSchemeI cs, SequenceI seq, int i) + { + getBoxColour(cs, seq, i); - Color tempColour = null; + return resBoxColour; + } - while ( (i <= end) && (i < length)) + /** + * DOCUMENT ME! + * + * @param cs DOCUMENT ME! + * @param seq DOCUMENT ME! + * @param i DOCUMENT ME! + */ + void getBoxColour(ColourSchemeI cs, SequenceI seq, int i) { - if (inCurrentSequenceGroup(i)) - { - if (currentSequenceGroup.getDisplayBoxes()) + if (cs != null) { - getBoxColour(currentSequenceGroup.cs, seq, i); + resBoxColour = cs.findColour(seq.getSequence(i, i + 1), i); } else { - resBoxColour = Color.white; - } - } - else if (av.getShowBoxes()) - { - getBoxColour(av.getGlobalColourScheme(), seq, i); - } - else - { - resBoxColour = Color.white; - } - - if (resBoxColour != tempColour) - { - if (tempColour != null) - { - graphics.fillRect(x1 + (width * (curStart - start)), y1, - curWidth, height); + resBoxColour = Color.white; } + } + + /** + * DOCUMENT ME! + * + * @param g DOCUMENT ME! + * @param seq DOCUMENT ME! + * @param sg DOCUMENT ME! + * @param start DOCUMENT ME! + * @param end DOCUMENT ME! + * @param x1 DOCUMENT ME! + * @param y1 DOCUMENT ME! + * @param width DOCUMENT ME! + * @param height DOCUMENT ME! + */ + public void drawSequence(Graphics g, SequenceI seq, SequenceGroup[] sg, + int start, int end, int x1, int y1, int width, int height) + { + allGroups = sg; - graphics.setColor(resBoxColour); + graphics = g; - curStart = i; - curWidth = width; - tempColour = resBoxColour; - } - else - { - curWidth += width; - } + drawBoxes(seq, start, end, x1, y1, (int) width, height); - i++; + fm = g.getFontMetrics(); + drawText(seq, start, end, x1, y1, (int) width, height); } - graphics.fillRect(x1 + (width * (curStart - start)), y1, curWidth, - height); - } + /** + * DOCUMENT ME! + * + * @param seq DOCUMENT ME! + * @param start DOCUMENT ME! + * @param end DOCUMENT ME! + * @param x1 DOCUMENT ME! + * @param y1 DOCUMENT ME! + * @param width DOCUMENT ME! + * @param height DOCUMENT ME! + */ + public void drawBoxes(SequenceI seq, int start, int end, int x1, int y1, + int width, int height) + { + int i = start; + int length = seq.getLength(); - public void drawText(SequenceI seq, int start, int end, int x1, int y1, - int width, int height) - { - int pady = height / 5; - int charOffset = 0; - char s; + int curStart = -1; + int curWidth = width; - // Need to find the sequence position here. - String sequence = seq.getSequence(); + Color tempColour = null; - for (int i = start; i <= end; i++) - { - graphics.setColor(Color.black); - - if (i < sequence.length()) - { - s = sequence.charAt(i); - } - else - { - s = ' '; - } - - if (!renderGaps && jalview.util.Comparison.isGap(s)) - { - continue; - } - - if (inCurrentSequenceGroup(i)) - { - if (!currentSequenceGroup.getDisplayText()) + while ((i <= end) && (i < length)) { - continue; + if (inCurrentSequenceGroup(i)) + { + if (currentSequenceGroup.getDisplayBoxes()) + { + getBoxColour(currentSequenceGroup.cs, seq, i); + } + else + { + resBoxColour = Color.white; + } + } + else if (av.getShowBoxes()) + { + getBoxColour(av.getGlobalColourScheme(), seq, i); + } + else + { + resBoxColour = Color.white; + } + + if (resBoxColour != tempColour) + { + if (tempColour != null) + { + graphics.fillRect(x1 + (width * (curStart - start)), y1, + curWidth, height); + } + + graphics.setColor(resBoxColour); + + curStart = i; + curWidth = width; + tempColour = resBoxColour; + } + else + { + curWidth += width; + } + + i++; } - if (currentSequenceGroup.getColourText()) + graphics.fillRect(x1 + (width * (curStart - start)), y1, curWidth, + height); + } + + /** + * DOCUMENT ME! + * + * @param seq DOCUMENT ME! + * @param start DOCUMENT ME! + * @param end DOCUMENT ME! + * @param x1 DOCUMENT ME! + * @param y1 DOCUMENT ME! + * @param width DOCUMENT ME! + * @param height DOCUMENT ME! + */ + public void drawText(SequenceI seq, int start, int end, int x1, int y1, + int width, int height) + { + int pady = height / 5; + int charOffset = 0; + char s; + + // Need to find the sequence position here. + String sequence = seq.getSequence(); + + for (int i = start; i <= end; i++) { - getBoxColour(currentSequenceGroup.cs, seq, i); - graphics.setColor(resBoxColour.darker()); + graphics.setColor(Color.black); + + if (i < sequence.length()) + { + s = sequence.charAt(i); + } + else + { + s = ' '; + } + + if (!renderGaps && jalview.util.Comparison.isGap(s)) + { + continue; + } + + if (inCurrentSequenceGroup(i)) + { + if (!currentSequenceGroup.getDisplayText()) + { + continue; + } + + if (currentSequenceGroup.getColourText()) + { + getBoxColour(currentSequenceGroup.cs, seq, i); + graphics.setColor(resBoxColour.darker()); + } + } + else + { + if (!av.getShowText()) + { + continue; + } + + if (av.getColourText()) + { + getBoxColour(av.getGlobalColourScheme(), seq, i); + + if (av.getShowBoxes()) + { + graphics.setColor(resBoxColour.darker()); + } + else + { + graphics.setColor(resBoxColour); + } + } + } + + charOffset = (width - fm.charWidth(s)) / 2; + graphics.drawString(String.valueOf(s), + charOffset + x1 + (width * (i - start)), (y1 + height) - pady); } - } - else - { - if (!av.getShowText()) + } + + /** + * DOCUMENT ME! + * + * @param res DOCUMENT ME! + * + * @return DOCUMENT ME! + */ + boolean inCurrentSequenceGroup(int res) + { + if (allGroups == null) { - continue; + return false; } - if (av.getColourText()) + for (int i = 0; i < allGroups.length; i++) { - getBoxColour(av.getGlobalColourScheme(), seq, i); - - if (av.getShowBoxes()) - { - graphics.setColor(resBoxColour.darker()); - } - else - { - graphics.setColor(resBoxColour); - } - } - } + if ((allGroups[i].getStartRes() <= res) && + (allGroups[i].getEndRes() >= res)) + { + currentSequenceGroup = allGroups[i]; - charOffset = (width - fm.charWidth(s)) / 2; - graphics.drawString(String.valueOf(s), - charOffset + x1 + (width * (i - start)), - (y1 + height) - pady); - } - } + return true; + } + } - boolean inCurrentSequenceGroup(int res) - { - if (allGroups == null) - { - return false; + return false; } - for (int i = 0; i < allGroups.length; i++) + /** + * DOCUMENT ME! + * + * @param seq DOCUMENT ME! + * @param start DOCUMENT ME! + * @param end DOCUMENT ME! + * @param x1 DOCUMENT ME! + * @param y1 DOCUMENT ME! + * @param width DOCUMENT ME! + * @param height DOCUMENT ME! + */ + public void drawHighlightedText(SequenceI seq, int start, int end, int x1, + int y1, int width, int height) { - if ( (allGroups[i].getStartRes() <= res) && - (allGroups[i].getEndRes() >= res)) - { - currentSequenceGroup = allGroups[i]; - - return true; - } - } + int pady = height / 5; + int charOffset = 0; + graphics.setColor(Color.BLACK); + graphics.fillRect(x1, y1, width * (end - start + 1), height); + graphics.setColor(Color.white); - return false; - } + char s = '~'; - public void drawHighlightedText(SequenceI seq, int start, int end, int x1, - int y1, int width, int height) - { - int pady = height / 5; - int charOffset = 0; - graphics.setColor(Color.BLACK); - graphics.fillRect(x1, y1, width * (end - start + 1), height); - graphics.setColor(Color.white); - - char s = '~'; - - // Need to find the sequence position here. - for (int i = start; i <= end; i++) - { - if (i < seq.getLength()) - { - s = seq.getSequence().charAt(i); - } - - charOffset = (width - fm.charWidth(s)) / 2; - graphics.drawString(String.valueOf(s), - charOffset + x1 + (width * (i - start)), - (y1 + height) - pady); + // Need to find the sequence position here. + for (int i = start; i <= end; i++) + { + if (i < seq.getLength()) + { + s = seq.getSequence().charAt(i); + } + + charOffset = (width - fm.charWidth(s)) / 2; + graphics.drawString(String.valueOf(s), + charOffset + x1 + (width * (i - start)), (y1 + height) - pady); + } } - } }