[GRASS-SVN] r60087 - grass/trunk/display/d.legend

svn_grass at osgeo.org svn_grass at osgeo.org
Sun May 4 18:27:48 PDT 2014


Author: hamish
Date: 2014-05-04 18:27:48 -0700 (Sun, 04 May 2014)
New Revision: 60087

Modified:
   grass/trunk/display/d.legend/d.legend.html
   grass/trunk/display/d.legend/main.c
Log:
replace funny text scaling parameter with absolute font size.
Bug: D_text_size() does not respect GRASS_TEXT_SIZE. Is the solution to
  test for the enviro var and not call D_text_size() at all if it exists?
  or is it better to put that in the lib fn itself?


Modified: grass/trunk/display/d.legend/d.legend.html
===================================================================
--- grass/trunk/display/d.legend/d.legend.html	2014-05-04 23:53:07 UTC (rev 60086)
+++ grass/trunk/display/d.legend/d.legend.html	2014-05-05 01:27:48 UTC (rev 60087)
@@ -1,82 +1,76 @@
 <h2>DESCRIPTION</h2>
 
 <em>d.legend</em> displays a legend for a user-specified
-raster map layer in the active frame on the graphics
-monitor.  
+raster map layer in the active frame on the graphics monitor.  
 <p>
-The user can run <em>d.legend</em> either non-interactively
-or interactively.  If the user specifies the name of a
-raster <b>map</b> layer on the command line, the program
-will run non-interactively.  Default legend text
-<b>color</b> and position will be used unless
-the user specifies other values on the command line.
+The legend's default size is based on the dimensions of the
+active frame, specifically its height.  <em>d.legend</em> will only
+obscure those portions of the active frame that directly underlie the legend.
 
-<p>
-Alternately, the user can simply type <b>d.legend</b> on the command line; 
-in this case, the program will prompt the user for parameter values 
-using the standard GRASS GUI interface.
 
 <h2>NOTES</h2>
 
-The legend's default size is based on the dimensions of the
-active frame, specifically its height.  <em>d.legend</em> will only
-obscure those portions of the active frame that directly underlie the legend.
-<p>When using the mouse or <b>at</b> to size & place the legend, a user may
+When using the <b>at</b> to size & place the legend, a user may
 create a horizontal legend by making the box wider than it is tall.
-<p>Raster maps based on floating point values will display smoothed, from greatest
+<p>
+Raster maps based on floating point values will display smoothed, from greatest
 to smallest value, while categorial raster maps will display in order, from
 top to bottom. Horizontal legends will always be smoothed. If the box is defined
 with inverted y-values or an inverted <b>range</b>, the legend will automatically
 flip. If this is not the desired result, the <b>-f</b> flag may be used to flip
 it back.
-<p>If the user attempts to display a very long legend in a relatively short 
+<p>
+If the user attempts to display a very long legend in a relatively short 
 display frame, the legend may appear in unreadably small text, or even revert
 to a smooth gradient legend. Use the <b>lines</b>, <b>thin</b>, <b>use</b>, <b>range</b>,
 and/or <b>-n</b> options to reduce the number of categories to be displayed,
 or the <b>-s</b> flag to force a smooth gradient legend. 
-Additionally the fonts for smoothed floating point legends
-can be scaled by a scale factor <b>fontscale</b>, to adjust the automatically computed size of the legend font.
-<p>The <b>lines</b> option will display the first number of categories, as defined
+<p>
+The <b>lines</b> option will display the first number of categories, as defined
 by <em>value</em>, contained in the raster map. When used with the <b>-n</b> flag,
 it takes on a new meaning: "up to category #". When used with both
 <b>thin</b> and the <b>-n</b> flag, its meaning becomes more obscure. When
 using <b>lines</b>, auto-scaled text similar to "4 of 16 categories" will be placed at 
 the bottom of the legend.
-<p>The <b>thin</b> option sets the thinning factor. For raster maps with a 0th
+<p>
+The <b>thin</b> option sets the thinning factor. For raster maps with a 0th
 category, <b>thin=</b><em>10</em> gives cats [0,10,20,...]. For raster maps 
 starting at category 1, <b>thin=</b><em>10</em> gives cats [1,11,21,...].
-<p>The <b>use</b> option lets the user create a legend made up of arbitrary category
+<p>
+The <b>use</b> option lets the user create a legend made up of arbitrary category
 values. e.g. <b>use=</b><em>1000,100,10,0,-10,-100,-1000</em>
-<p>The <b>range</b> option lets the user define the minimum and maximum categories
+<p>
+The <b>range</b> option lets the user define the minimum and maximum categories
 to be used in the legend. It may also be used to define the limits of a smooth
 gradient legend created from a raster containing floating point values. Note
 the color scale will remain faithful to the category values as defined with
 <em><a href="r.colors.html">r.colors</a></em>, and the <b>range</b> may be
 extended to the limits defined by the <em><a href="r.colors.html">r.colors</a></em>
 color map.
-<p>The flag <b>-n</b> is useful for categorial maps, as it suppresses the
+<p>
+The flag <b>-n</b> is useful for categorial maps, as it suppresses the
 drawing of non-existing categories (otherwise the full range is shown).
-<p>Vertical legends produced with <em>d.legend</em> will place text labels to the
+<p>
+Vertical legends produced with <em>d.legend</em> will place text labels to the
 right of the legend box, horizontal legends will place text below. This text
 will be auto-scaled to fit within the frame, reducing the size of the legend
-if necessary. Legends positioned with the mouse or with the <b>at</b> option
+if necessary. Legends positioned with the <b>at</b> option
 will not auto-scale text, in order to provide more control to the user.
-Smaller text may be obtained in this case by reducing the
-height of the box. The <b>-c</b> and <b>-v</b> flags may be used to suppress the
-display of category numbers and labels respectively, or used together to 
-suppress all text of categorial raster maps.
-<p>The text produced from floating-point raster maps will automatically create
+Smaller text may be obtained in this case by reducing the height of the box
+or by using the <b>fontsize</b> option. The <b>-c</b> and <b>-v</b> flags may
+be used to suppress the display of category numbers and labels respectively,
+or used together to suppress all text of categorial raster maps.
+<p>
+The text produced from floating-point raster maps will automatically create
 output with a meaningful number of significant digits. For very small values,
 numbers will be expressed in scientific notation, e.g. "1.7e-9".
-<p>Legends placed with the mouse are not saved to the display window's history
-for automatic redraw. By setting the Debug level to 1 (see 
-<em><a href="g.gisenv.html">g.gisenv</a></em>) the corresponding <b>at</b>
-setting can be determined.
-<p>Note that old scripts which relied on setting <b>lines</b> greater than the
+<p>
+Note that old scripts which relied on setting <b>lines</b> greater than the
 number of categories to scale the legend may no longer produce the desired
 output, although the auto-scaling should still produce something that looks 
 good in this case.
 
+
 <h2>SEE ALSO</h2>
 
 <em>
@@ -86,14 +80,13 @@
 <a href="d.font.html">d.font</a>,
 <a href="d.grid.html">d.grid</a>,
 <a href="d.rast.html">d.rast</a>,
-<!-- <a href="d.rast.labels.html">d.rast.labels</a>, -->
 <a href="d.rast.leg.html">d.rast.leg</a>,
 <a href="d.text.html">d.text</a>,
 <a href="d.vect.thematic.html">d.vect.thematic</a>,
-<!--<a href="d.what.rast.html">d.what.rast</a>,-->
 <a href="r.reclass.html">r.reclass</a>
 </em>
 
+
 <h2>AUTHORS</h2>
 Bill Brown, U.S. Army Construction Engineering Research Laboratories
 <br>Late 2002: Rewrite of much of the code. Hamish Bowman,

Modified: grass/trunk/display/d.legend/main.c
===================================================================
--- grass/trunk/display/d.legend/main.c	2014-05-04 23:53:07 UTC (rev 60086)
+++ grass/trunk/display/d.legend/main.c	2014-05-05 01:27:48 UTC (rev 60087)
@@ -1,11 +1,10 @@
-/* d.legend a.k.a d.leg.thin
- *
+/*
  * MODULE:      d.legend
  *
  *              Based on the old d.leg.thin, which replaced an even older
  *              module called "d.legend".
  *
- * PURPOSE:     Draw a graphical legend for a raster on the display mon
+ * PURPOSE:     Draw a graphical legend for a raster on the display monitor
  *
  * AUTHORS:
  *      Original version:
@@ -17,7 +16,7 @@
  *      Late 2002: Rewrite of much of the code:
  *         Hamish Bowman, Otago University, New Zealand
  *
- * COPYRIGHT:   (c) 2006 The GRASS Development Team
+ * COPYRIGHT:   (c) 2006-2014 by The GRASS Development Team
  *
  *              This program is free software under the GNU General Public
  *              License (>=v2). Read the file COPYING that comes with GRASS
@@ -58,7 +57,9 @@
     struct Categories cats;
     struct Colors colors;
     struct GModule *module;
-    struct Option *opt_input, *opt_color, *opt_lines, *opt_thin, *opt_labelnum, *opt_at, *opt_use, *opt_range, *opt_font, *opt_path, *opt_charset, *opt_fontscale;
+    struct Option *opt_input, *opt_color, *opt_lines, *opt_thin,
+		  *opt_labelnum, *opt_at, *opt_use, *opt_range,
+		  *opt_font, *opt_path, *opt_charset, *opt_fontsize;
     struct Flag *hidestr, *hidenum, *hidenodata, *smooth, *flipit, *size;
     struct Range range;
     struct FPRange fprange;
@@ -75,7 +76,7 @@
     double UserRangeMin, UserRangeMax, UserRangeTemp;
     double *catlist, maxCat;
     int catlistCount, use_catlist;
-    double fontscale;
+    double fontsize;
 
 
     /* Initialize the GIS calls */
@@ -157,15 +158,14 @@
     opt_font->description = _("Font name");
     opt_font->guisection = _("Font settings");
 
-    /* HB: this option should become redundant as soon as the bug in trunk's D_text_size() is fixed. */
-    opt_fontscale = G_define_option();
-    opt_fontscale->key = "fontscale";
-    opt_fontscale->type = TYPE_DOUBLE;
-    opt_fontscale->required = NO;
-    opt_fontscale->answer = "5";
-    opt_fontscale->options = "0-100";
-    opt_fontscale->description = _("Font scaling factor for floating point legends");
-    opt_fontscale->guisection = _("Font settings");
+    opt_fontsize = G_define_option();
+    opt_fontsize->key = "fontsize";
+    opt_fontsize->type = TYPE_DOUBLE;
+    opt_fontsize->required = NO;
+    opt_fontsize->options = "1-360";
+    opt_fontsize->label = _("Font size");
+    opt_fontsize->description = _("Default: Auto-scaled");
+    opt_fontsize->guisection = _("Font settings");
 
     opt_path = G_define_standard_option(G_OPT_F_INPUT);
     opt_path->key = "path";
@@ -225,9 +225,10 @@
     do_smooth = smooth->answer;
     flip = flipit->answer;
 
-    /* Create the fontscale factor for floating point legends */
-    fontscale = atof(opt_fontscale->answer);
-    fontscale = 1.0 / (100.0/fontscale);
+    if (opt_fontsize->answer != NULL)
+	fontsize = atof(opt_fontsize->answer);
+    else
+	fontsize = 12; /* dummy placeholder, should never be called */
 
     color = D_parse_color(opt_color->answer, TRUE);
 
@@ -506,7 +507,7 @@
 		    y0 = ((b - t) - (dots_per_line * lines)) / 2;
 	}
 
-	/*      D_text_size((int)(dots_per_line*4/5), (int)(dots_per_line*4/5)) ;    redundant */
+	/*      D_text_size(dots_per_line*4/5., dots_per_line*4/5.);    redundant */
 	/* if(Rast_is_c_null_value(&min_ind) && Rast_is_c_null_value(&max_ind))
 	   {
 	   min_ind = 1;
@@ -581,7 +582,7 @@
 
     if (do_smooth) {
 	int wleg, lleg, dx, dy;
-	int txsiz;
+	double txsiz;
 	int ppl;
 	int tcell;
 	float ScaleFactor = 1.0;
@@ -682,19 +683,22 @@
 
 	    /* Draw text */
 	    if (!horiz)
-		txsiz = (int)((y1 - y0) * fontscale);
+		txsiz = (y1 - y0) / 20;
 	    else
-		txsiz = (int)((x1 - x0) * fontscale);
+		txsiz = (x1 - x0) / 20;
 
 	    /* scale text to fit in window if position not manually set */
 	    /* usually not needed, except when frame is really narrow   */
 	    if (opt_at->answer == NULL) {	/* ie default scaling */
 		ScaleFactor = ((r - x1) / ((MaxLabelLen + 1) * txsiz * 0.81));	/* ?? txsiz*.81=actual text width. */
 		if (ScaleFactor < 1.0) {
-		    txsiz = (int)(txsiz * ScaleFactor);
+		    txsiz = txsiz * ScaleFactor;
 		}
 	    }
 
+	    if (opt_fontsize->answer != NULL)
+		txsiz = fontsize;
+
 	    if (txsiz < 0)
 		txsiz = 0;	/* keep it sane */
 
@@ -759,7 +763,8 @@
     }
     else {			/* non FP, no smoothing */
 
-	int txsiz, true_l, true_r;
+	int true_l, true_r;
+	double txsiz;
 	float ScaleFactor = 1.0;
 
 	/* set legend box bounds */
@@ -780,13 +785,13 @@
 
 	/* adjust text size */
 	/*      txsiz = (int)((y1-y0)/(1.5*(lines+5))); */
-	txsiz = (int)((y1 - y0) / (2.0 * lines));
+	txsiz = (y1 - y0) / (2.0 * lines);
 
 	/* scale text to fit in window if position not manually set */
 	if (opt_at->answer == NULL) {	/* ie defualt scaling */
 	    ScaleFactor = ((true_r - true_l) / ((MaxLabelLen + 3) * txsiz * 0.81));	/* ?? txsiz*.81=actual text width. */
 	    if (ScaleFactor < 1.0) {
-		txsiz = (int)floor(txsiz * ScaleFactor);
+		txsiz = txsiz * ScaleFactor;
 		dots_per_line = (int)floor(dots_per_line * ScaleFactor);
 	    }
 	}
@@ -794,6 +799,9 @@
 	if (dots_per_line < txsiz)
 	    txsiz = dots_per_line;
 
+	if (opt_fontsize->answer != NULL)
+	    txsiz = fontsize;
+
 	D_text_size(txsiz, txsiz);
 
 
@@ -928,7 +936,7 @@
 
 	if (do_cats != cats_num) {
 	    cur_dot_row += dots_per_line;
-	    /*          sprintf(buff, "%d of %d categories\n", (j-1), cats_num) ;   */
+	    /* sprintf(buff, "%d of %d categories\n", (j-1), cats_num); */
 
 	    sprintf(buff, "%d of %d categories\n", k, cats_num);
 
@@ -936,7 +944,11 @@
 	    MaxLabelLen = strlen(buff) + 4;
 	    ScaleFactor = ((true_r - true_l) / (MaxLabelLen * txsiz * 0.81));	/* ?? txsiz*.81=actual text width. */
 	    if (ScaleFactor < 1.0) {
-		txsiz = (int)floor(txsiz * ScaleFactor);
+		txsiz = txsiz * ScaleFactor;
+
+		if (opt_fontsize->answer != NULL)
+		    txsiz = fontsize;
+
 		D_text_size(txsiz, txsiz);
 	    }
 	    D_use_color(white);



More information about the grass-commit mailing list