X-Git-Url: http://source.jalview.org/gitweb/?a=blobdiff_plain;f=src%2Fjalview%2Fgui%2FAnnotationLabels.java;h=c7fd4fe8683e19611afd20f55b9ae47af59f0df2;hb=62a585da2d97f93123b5482f2b5846fdac3bd97f;hp=533b22c7f714fa061e5dfb466c73ddf96dee5583;hpb=ddc7f53dd8398442e2025d11330fa8dfe2f8dd35;p=jalview.git diff --git a/src/jalview/gui/AnnotationLabels.java b/src/jalview/gui/AnnotationLabels.java index 533b22c..c7fd4fe 100755 --- a/src/jalview/gui/AnnotationLabels.java +++ b/src/jalview/gui/AnnotationLabels.java @@ -1,13 +1,13 @@ /* - * 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 2.8) + * Copyright (C) 2012 J Procter, AM Waterhouse, LM Lui, J Engelhardt, 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 * 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 @@ -29,6 +29,7 @@ import javax.swing.*; import jalview.datamodel.*; import jalview.io.*; +import jalview.util.MessageManager; /** * DOCUMENT ME! @@ -816,18 +817,32 @@ public class AnnotationLabels extends JPanel implements MouseListener, RenderingHints.VALUE_ANTIALIAS_ON); } - drawComponent(g2, width); + drawComponent(g2, true, width); } /** - * DOCUMENT ME! + * Draw the full set of annotation Labels for the alignment at the given cursor * - * @param g - * DOCUMENT ME! + * @param g Graphics2D instance (needed for font scaling) + * @param width Width for scaling labels + * */ public void drawComponent(Graphics g, int width) { + drawComponent(g, false, width); + } + + private final boolean debugRedraw = false; + /** + * Draw the full set of annotation Labels for the alignment at the given cursor + * + * @param g Graphics2D instance (needed for font scaling) + * @param clip - true indicates that only current visible area needs to be rendered + * @param width Width for scaling labels + */ + public void drawComponent(Graphics g, boolean clip, int width) + { if (av.getFont().getSize() < 10) { g.setFont(font); @@ -843,7 +858,7 @@ public class AnnotationLabels extends JPanel implements MouseListener, g.translate(0, scrollOffset); g.setColor(Color.black); - + AlignmentAnnotation[] aa = av.getAlignment().getAlignmentAnnotation(); int fontHeight = g.getFont().getSize(); int y = 0; @@ -853,22 +868,54 @@ public class AnnotationLabels extends JPanel implements MouseListener, Font baseFont = g.getFont(); FontMetrics baseMetrics = fm; int ofontH = fontHeight; - boolean visible = true; + int sOffset=0; + int visHeight = 0; + int[] visr = (ap!=null && ap.annotationPanel!=null) ? ap.annotationPanel.getVisibleVRange() : null; + if (clip && visr!=null){ + sOffset = visr[0]; + visHeight = visr[1]; + } + boolean visible = true,before=false,after=false; if (aa != null) { hasHiddenRows = false; + int olY=0; for (int i = 0; i < aa.length; i++) { visible = true; - g.setColor(Color.black); - if (!aa[i].visible) { hasHiddenRows = true; continue; } - + olY=y; y += aa[i].height; + if (clip) {if (yvisHeight) + { + + if (!after) + { + if (debugRedraw) { + System.out.println("Scroll offset: "+sOffset+" after vis: "+i); + } + after=true; + } + // don't draw what isn't visible + continue; + }} + g.setColor(Color.black); offset = -aa[i].height / 2; @@ -885,6 +932,7 @@ public class AnnotationLabels extends JPanel implements MouseListener, if (aa[i].graphGroup > -1) { int groupSize = 0; + // TODO: JAL-1291 revise rendering model so the graphGroup map is computed efficiently for all visible labels for (int gg = 0; gg < aa.length; gg++) { if (aa[gg].graphGroup == aa[i].graphGroup) @@ -923,7 +971,7 @@ public class AnnotationLabels extends JPanel implements MouseListener, { x = width - fm.stringWidth(aa[gg].label) - 3; g.drawString(aa[gg].label, x, y - graphExtras); - + if (aa[gg]._linecolour != null) { @@ -960,10 +1008,10 @@ public class AnnotationLabels extends JPanel implements MouseListener, dragEvent.getY() - scrollOffset); } - if ((aa == null) || (aa.length < 1)) + if (!av.wrapAlignment && ((aa == null) || (aa.length < 1))) { - g.drawString("Right click", 2, 8); - g.drawString("to add annotation", 2, 18); + g.drawString(MessageManager.getString("label.right_click"), 2, 8); + g.drawString(MessageManager.getString("label.to_add_annotation"), 2, 18); } } }