X-Git-Url: http://source.jalview.org/gitweb/?a=blobdiff_plain;f=src%2Fjalview%2Frenderer%2FScaleRenderer.java;h=dc3272ff84decd7d8a0a499230a2850cbe870d58;hb=b7cb4c78d9d787e918c9d88f917a41642dd90a7a;hp=830a84050b7499e428f1e384f0d494027248dceb;hpb=90bc387e8e4fb4436a545fadd6ebeb1a23282a69;p=jalview.git diff --git a/src/jalview/renderer/ScaleRenderer.java b/src/jalview/renderer/ScaleRenderer.java index 830a840..dc3272f 100644 --- a/src/jalview/renderer/ScaleRenderer.java +++ b/src/jalview/renderer/ScaleRenderer.java @@ -21,9 +21,11 @@ package jalview.renderer; import jalview.api.AlignViewportI; +import jalview.datamodel.HiddenColumns; import jalview.datamodel.SequenceI; import java.util.ArrayList; +import java.util.Iterator; import java.util.List; /** @@ -83,12 +85,16 @@ public class ScaleRenderer int refSp = 0; int refStartI = 0; int refEndI = -1; + + HiddenColumns hc = av.getAlignment().getHiddenColumns(); + if (refSeq != null) { // find bounds and set origin appropriately - // locate first visible position for this sequence - refSp = av.getAlignment().getHiddenColumns() - .locateVisibleStartOfSequence(refSeq); + // locate first residue in sequence which is not hidden + Iterator it = hc.iterator(); + int index = refSeq.firstResidueOutsideIterator(it); + refSp = hc.absoluteToVisibleColumn(index); refStartI = refSeq.findIndex(refSeq.getStart()) - 1; @@ -114,14 +120,12 @@ public class ScaleRenderer { if (refSeq == null) { - iadj = av.getAlignment().getHiddenColumns() - .adjustForHiddenColumns(i - 1) + 1; + iadj = hc.visibleToAbsoluteColumn(i - 1) + 1; string = String.valueOf(iadj); } else { - iadj = av.getAlignment().getHiddenColumns() - .adjustForHiddenColumns(i - 1); + iadj = hc.visibleToAbsoluteColumn(i - 1); refN = refSeq.findPosition(iadj); // TODO show bounds if position is a gap // - ie L--R -> "1L|2R" for