f8d4a7651a5843d1c0bfa90cdb7da7582615c263 kate Thu Aug 9 13:47:29 2018 -0700 Add filter to hide interactions lacking one or both ends in the window. Helpful for busy/noisy datasets. refs #21109 diff --git src/hg/lib/interactUi.c src/hg/lib/interactUi.c index 804c57dc..5ae8967 100644 --- src/hg/lib/interactUi.c +++ src/hg/lib/interactUi.c @@ -1,80 +1,100 @@ /* interact track controls */ /* Copyright (C) 2018 The Regents of the University of California * See README in this or parent directory for licensing information. */ #include "cheapcgi.h" #include "cart.h" #include "hui.h" #include "trackDb.h" #include "interactUi.h" boolean isPopup = FALSE; boolean interactUiDirectional(struct trackDb *tdb) /* Determine if interactions are directional */ { return trackDbSettingClosestToHomeOn(tdb, INTERACT_DIRECTIONAL); } void interactUiMinScore(struct cart *cart, char *track, struct trackDb *tdb) /* Minimum score */ { char buffer[1024]; safef(buffer, sizeof buffer, "%s.%s", tdb->track, INTERACT_MINSCORE); int minScore = cartUsualInt(cart, buffer, 0); printf("Minimum score: "); cgiMakeIntVar(buffer, minScore, 0); } void interactUiTrackHeight(struct cart *cart, char *track, struct trackDb *tdb) /* Input box to change track height */ { // track height control char buffer[1024]; int min, max, deflt, current; cartTdbFetchMinMaxPixels(cart, tdb, INTERACT_MINHEIGHT, INTERACT_MAXHEIGHT, atoi(INTERACT_DEFHEIGHT), &min, &max, &deflt, ¤t); safef(buffer, sizeof buffer, "%s.%s", track, INTERACT_HEIGHT); printf("

Track height: "); cgiMakeIntVar(buffer, current, 3); printf(" pixels (range: %d to %d, default: %d)", min, max, deflt); } void interactUiDrawMode(struct cart *cart, char *track, struct trackDb *tdb) /* Radio buttons to select drawing mode */ - { char *drawMode = cartUsualStringClosestToHome(cart, tdb, isNameAtParentLevel(tdb, track), INTERACT_DRAW, INTERACT_DRAW_DEFAULT); char cartVar[1024]; puts("Draw mode: "); safef(cartVar, sizeof(cartVar), "%s.%s", track, INTERACT_DRAW); cgiMakeRadioButton(cartVar, INTERACT_DRAW_CURVE , sameString(INTERACT_DRAW_CURVE, drawMode)); printf(" %s ", "curve"); cgiMakeRadioButton(cartVar, INTERACT_DRAW_ELLIPSE, sameString(INTERACT_DRAW_ELLIPSE, drawMode)); printf(" %s ", "ellipse"); cgiMakeRadioButton(cartVar, INTERACT_DRAW_LINE, sameString(INTERACT_DRAW_LINE, drawMode)); printf(" %s ", "rectangle"); } +void interactUiEndpointFilter(struct cart *cart, char *track, struct trackDb *tdb) +/* Radio buttons to allow excluding items lacking endpoints in window */ +{ +char *endsVisible = cartUsualStringClosestToHome(cart, tdb, isNameAtParentLevel(tdb, track), + INTERACT_ENDS_VISIBLE, INTERACT_ENDS_VISIBLE_DEFAULT); +char cartVar[1024]; +puts("

Show interactions: "); +//puts("

Exclude interactions: "); +safef(cartVar, sizeof(cartVar), "%s.%s", track, INTERACT_ENDS_VISIBLE); +cgiMakeRadioButton(cartVar, INTERACT_ENDS_VISIBLE_ANY, sameString(INTERACT_ENDS_VISIBLE_ANY, endsVisible)); +printf(" %s ", "all"); +//printf(" %s ", "none"); +cgiMakeRadioButton(cartVar, INTERACT_ENDS_VISIBLE_ONE, sameString(INTERACT_ENDS_VISIBLE_ONE, endsVisible)); +printf(" %s ", "at least one end"); +//printf(" %s ", "only one end"); +cgiMakeRadioButton(cartVar, INTERACT_ENDS_VISIBLE_TWO , sameString(INTERACT_ENDS_VISIBLE_TWO, endsVisible)); +printf(" %s ", "both ends in window"); +//printf(" %s ", "no ends in window"); +} + void interactCfgUi(char *database, struct cart *cart, struct trackDb *tdb, char *track, char *title, boolean boxed) /* Configure interact track type */ { if (cartVarExists(cart, "ajax")) isPopup = TRUE; boxed = cfgBeginBoxAndTitle(tdb, boxed, title); if (startsWith("big", tdb->type)) labelCfgUi(database, cart, tdb); //printf("\n\n
", //isPopup ? 75 : 100, boxed ?" width='100%'":""); interactUiMinScore(cart, track, tdb); +interactUiEndpointFilter(cart, track, tdb); interactUiTrackHeight(cart, track, tdb); puts("
"); interactUiDrawMode(cart, track, tdb); //puts("\n
\n"); cfgEndBox(boxed); }