3bdd753973190ec7e64d85a90ab912b9a7c37489 angie Fri Sep 4 13:45:27 2020 -0700 Move leftLabelWidth parameters out of hgTracks global variables into trackLayout lib (for use by hgPhyloPlace). refs #25943 diff --git src/hg/lib/trackLayout.c src/hg/lib/trackLayout.c index 019d218..cb7e331 100644 --- src/hg/lib/trackLayout.c +++ src/hg/lib/trackLayout.c @@ -1,77 +1,89 @@ /* trackLayout - this controls the dimensions of the graphic * for the genome browser. Also used for the genome view. */ /* Copyright (C) 2014 The Regents of the University of California * See README in this or parent directory for licensing information. */ #include "common.h" #include "memgfx.h" #include "cart.h" #include "hgConfig.h" #include "hCommon.h" #include "trackLayout.h" void trackLayoutSetPicWidth(struct trackLayout *tl, char *s) /* Set pixel width from ascii string. */ { int maxWidth = MAX_DISPLAY_PIXEL_WIDTH; char *maxDisplayPixelWidth = cfgOptionDefault("maxDisplayPixelWidth", NULL); if (isNotEmpty(maxDisplayPixelWidth)) maxWidth = sqlUnsigned(maxDisplayPixelWidth); if (s != NULL && isdigit(s[0])) { tl->picWidth = atoi(s); #ifdef LOWELAB if (tl->picWidth > 60000) tl->picWidth = 60000; #else if (tl->picWidth > maxWidth) tl->picWidth = maxWidth; #endif if (tl->picWidth < 320) tl->picWidth = 320; } tl->trackWidth = tl->picWidth - tl->leftLabelWidth; } boolean trackLayoutInclFontExtras() /* Check if fonts.extra is set to use "yes" in the config. This enables * extra fonts and related options that are not part of the public browser */ { static boolean first = TRUE; static boolean enabled = FALSE; if (first) { char *val = cfgOptionDefault("fonts.extra", NULL); if (val != NULL) enabled = sameString(val, "yes"); first = FALSE; } return enabled; } void trackLayoutInit(struct trackLayout *tl, struct cart *cart) /* Initialize layout around small font and a picture about 600 pixels * wide, but this can be overridden by cart. */ { char *fontType = "medium"; boolean fontExtras = trackLayoutInclFontExtras(); if (fontExtras) fontType = cartUsualString(cart, "fontType", fontType); tl->textFont = cartUsualString(cart, textFontVar, cfgOptionDefault("freeTypeFont","Helvetica")); tl->textSize = mgFontSizeBackwardsCompatible(cartUsualString(cart, textSizeVar, cfgOptionDefault(textSizeVar,"small"))); MgFont *font = mgFontForSizeAndStyle(tl->textSize, fontType); tl->font = font; tl->mWidth = mgFontStringWidth(font, "M"); tl->nWidth = mgFontStringWidth(font, "n"); tl->fontHeight = mgFontLineHeight(font); tl->barbHeight = tl->fontHeight/4; tl->barbSpacing = (tl->fontHeight+1)/2; tl->picWidth = hgDefaultPixWidth; trackLayoutSetPicWidth(tl, cartOptionalString(cart, "pix")); +// label width, but don't exceed 1/2 of image +tl->leftLabelWidthChars = cartUsualInt(cart, leftLabelWidthVar, leftLabelWidthDefaultChars); +if (tl->leftLabelWidthChars < 2) + tl->leftLabelWidthChars = leftLabelWidthDefaultChars; +tl->leftLabelWidth = tl->leftLabelWidthChars*tl->nWidth + trackTabWidth + 3; +int maxLabelWidth = 0.5*tl->picWidth; +if (tl->leftLabelWidth > maxLabelWidth) + { + // overflow, force to 1/2 width + tl->leftLabelWidthChars = maxLabelWidth/tl->nWidth; + tl->leftLabelWidth = tl->leftLabelWidthChars * tl->nWidth; + } }