- // If no manual adjustment to ID column with has been made then adjust
- // width match widest of alignment or annotation id widths
- width = Math.max(alignmentIdWidth, newAnnotationIdWidth);
- }
- else if (newAnnotationIdWidth != annotationIdWidth
- && newAnnotationIdWidth > givenWidth
- && newAnnotationIdWidth > alignmentIdWidth)
- {
- // otherwise if the annotation id width has become larger than the
- // current id width, increase
- width = newAnnotationIdWidth;
- annotationIdWidth = newAnnotationIdWidth;
- }
- // set the width if it's changed
- if (width != ap.av.getIdWidth())
- {
- iwa.setWidth(width);
+ Graphics2D g2d = (Graphics2D) g;
+ Graphics dummy = g2d.create();
+ int newAnnotationIdWidth = drawLabels(dummy, clip, width, false, forGUI,
+ null);
+ dummy.dispose();
+ Dimension d = ap.calculateDefaultAlignmentIdWidth();
+ int alignmentIdWidth = d.width;
+ if (iwa != null && !iwa.manuallyAdjusted())
+ {
+ // If no manual adjustment to ID column with has been made then adjust
+ // width match widest of alignment or annotation id widths
+ boolean allowShrink = Cache.getDefault("ALLOW_SHRINK_ID_WIDTH",
+ false);
+ width = Math.max(alignmentIdWidth, newAnnotationIdWidth);
+ if (clip && width < givenWidth && !allowShrink)
+ {
+ width = givenWidth;
+ }
+ }
+ else if (newAnnotationIdWidth != annotationIdWidth
+ && newAnnotationIdWidth > givenWidth
+ && newAnnotationIdWidth > alignmentIdWidth)
+ {
+ // otherwise if the annotation id width has become larger than the
+ // current id width, increase
+ width = newAnnotationIdWidth;
+ annotationIdWidth = newAnnotationIdWidth;
+ }
+ // set the width if it's changed
+ if (width != ap.av.getIdWidth())
+ {
+ iwa.setWidth(width);
+ }