[GRASS5] [PATCH] ps.map - legend in columns
Morten Hulden
morten at untamo.net
Wed Mar 3 21:23:45 EST 2004
Markus, Glynn, Hamish ...
A small patch to ps.map that adds a 'cols' option to vlegend, so the
legend can be printed in columns. Not too sofisticated - the columns will
overwrite each other if the legend text is too long or there are too many
columns. But I needed this so I tought I might as well submit it.
The default is still 1 column.
It also fixes the missing 'width' option for vlegend.
rgds
Morten
%<--------------------------------------------------------------------------------------
diff -uw grass57_exp_2004_02_28/ps/ps.map/ps_vlegend.c grass57_my/ps/ps.map/ps_vlegend.c
--- grass57_exp_2004_02_28/ps/ps.map/ps_vlegend.c 2003-03-26 16:56:15.000000000 +0100
+++ grass57_my/ps/ps.map/ps_vlegend.c 2004-03-04 02:53:37.000000000 +0100
@@ -2,6 +2,7 @@
**
** Author: Paul W. Carlson April 1992
** Modified by: Radim Blazek Jan 2000 area, label added
+** Modified by: Morten Hulden Mar 2004, support for legend in columns added
*/
#include "vector.h"
@@ -10,8 +11,8 @@
int PS_vlegend (void)
{
- int i, j, k, l, lcount, nopos;
- double x, y, fontsize, dy, xo, yo, margin, width;
+ int h, i, j, k, l, lc, st, lcount, nopos;
+ double x, y, fontsize, dx, dy, xo, yo, xs, ys, margin, width;
int **vec, *nvec;
G_debug (2, "vect_legend(): count = %d", vector.count );
@@ -71,9 +72,22 @@
margin = 0.4 * fontsize;
if (x < PS.map_left + margin) x = PS.map_left + margin;
+ if (lcount < vector.cols) vector.cols = lcount;
+ dx = (PS.map_right - x) / vector.cols;
+ xs = x; /*save x and y*/
+ ys = y;
+ lc = (int) lcount/vector.cols; /* lines per column */
+
+ for ( h = 0; h < vector.cols; h++) {
+
+ y = ys;
+ if (h) x+=dx;
+ st = ((h+1)*lc < lcount) ? ((h+1)*lc) : lcount;
+
/* make PostScript array "a" of name-mapset strings */
fprintf(PS.fp, "/a [\n");
- for ( i = 0; i < lcount; i++ ) {
+
+ for ( i = h*lc; i < st; i++ ) {
G_debug (4, " row = %d", i );
if ( nvec[i] > 0 ) { /* used position */
j = vec[i][nvec[i]-1]; /* vector with label */
@@ -101,11 +115,11 @@
/* make white background for text */
fprintf(PS.fp, "1 1 1 C ");
fprintf(PS.fp, "%.1f %.1f w %.1f B fill \n",
- x - margin, y - lcount * dy - margin, y);
+ x - margin, y - lc * dy - margin, y);
}
/* make the legend */
- for ( j = 0; j < lcount; j++ ) { /* each row */
+ for ( j = h*lc; j < st; j++ ) { /*each row */
G_debug (4, " row = %d", j );
y -= dy; /* set position of next row */
for (k = 0; k < nvec[j]; k++) {
@@ -166,8 +180,12 @@
/* plot the text */
set_rgb_color(BLACK);
- fprintf(PS.fp, "a %d get %.1f %.1f MS\n", j, x + width, y);
+ fprintf(PS.fp, "a %d get %.1f %.1f MS\n", j - h*lc, x + width, y);
}
+ } /*h*/
+ x = xs;
+ y = ys - lc*dy;
+
fprintf(PS.fp, "[] 0 setdash\n");
if (PS.min_y > y) PS.min_y = y;
diff -uw grass57_exp_2004_02_28/ps/ps.map/r_vlegend.c grass57_my/ps/ps.map/r_vlegend.c
--- grass57_exp_2004_02_28/ps/ps.map/r_vlegend.c 2003-03-26 16:56:15.000000000 +0100
+++ grass57_my/ps/ps.map/r_vlegend.c 2004-03-03 20:43:22.000000000 +0100
@@ -16,6 +16,8 @@
"where x y",
"font fontname",
"fontsize fontsize",
+ "width width",
+ "cols cols",
""
};
@@ -24,12 +26,13 @@
{
char buf[1024];
char *key, *data;
- int fontsize;
+ int fontsize, cols;
double x, y, width;
fontsize = 0;
x = y = 0.0;
width = -1;
+ cols = 1;
while (input(2, buf, help))
{
if (!key_data(buf, &key, &data)) continue;
@@ -65,6 +68,13 @@
continue;
}
+ if (KEY("cols"))
+ {
+ cols = atoi (data);
+ if (cols < 1 || cols > 10) cols = 1;
+ continue;
+ }
+
error(key, data, "illegal vlegend sub-request");
}
vector.x = x;
@@ -74,5 +84,7 @@
if (width > 0) vector.width = width;
else vector.width = 3 * fontsize / 72.0;
+ vector.cols = cols;
+
return 0;
}
diff -uw grass57_exp_2004_02_28/ps/ps.map/vector.h grass57_my/ps/ps.map/vector.h
--- grass57_exp_2004_02_28/ps/ps.map/vector.h 2003-10-11 06:15:12.000000000 +0200
+++ grass57_my/ps/ps.map/vector.h 2004-03-04 02:34:20.000000000 +0100
@@ -1,5 +1,6 @@
/** Modified by: Janne Soimasuo August 1994 line_cat added **/
/** Modified by: Radim Blazek Jan 2000 acolor, label added **/
+/** Modified by: Morten Hulden Mar 2004 cols added to vector **/
#include "clr.h"
#define PI 3.14159265
/* #define MAXVECTORS 20 */
@@ -81,6 +82,7 @@
int fontsize; /* legend font size */
char *font; /* legend font */
double width; /* width of legend symbols */
+ int cols; /* number of colums */
LAYER *layer;
} ;
-------------- next part --------------
diff -uw grass57_exp_2004_02_28/ps/ps.map/ps_vlegend.c grass57_my/ps/ps.map/ps_vlegend.c
--- grass57_exp_2004_02_28/ps/ps.map/ps_vlegend.c 2003-03-26 16:56:15.000000000 +0100
+++ grass57_my/ps/ps.map/ps_vlegend.c 2004-03-04 02:53:37.000000000 +0100
@@ -2,6 +2,7 @@
**
** Author: Paul W. Carlson April 1992
** Modified by: Radim Blazek Jan 2000 area, label added
+** Modified by: Morten Hulden Mar 2004, support for legend in columns added
*/
#include "vector.h"
@@ -10,8 +11,8 @@
int PS_vlegend (void)
{
- int i, j, k, l, lcount, nopos;
- double x, y, fontsize, dy, xo, yo, margin, width;
+ int h, i, j, k, l, lc, st, lcount, nopos;
+ double x, y, fontsize, dx, dy, xo, yo, xs, ys, margin, width;
int **vec, *nvec;
G_debug (2, "vect_legend(): count = %d", vector.count );
@@ -71,9 +72,22 @@
margin = 0.4 * fontsize;
if (x < PS.map_left + margin) x = PS.map_left + margin;
+ if (lcount < vector.cols) vector.cols = lcount;
+ dx = (PS.map_right - x) / vector.cols;
+ xs = x; /*save x and y*/
+ ys = y;
+ lc = (int) lcount/vector.cols; /* lines per column */
+
+ for ( h = 0; h < vector.cols; h++) {
+
+ y = ys;
+ if (h) x+=dx;
+ st = ((h+1)*lc < lcount) ? ((h+1)*lc) : lcount;
+
/* make PostScript array "a" of name-mapset strings */
fprintf(PS.fp, "/a [\n");
- for ( i = 0; i < lcount; i++ ) {
+
+ for ( i = h*lc; i < st; i++ ) {
G_debug (4, " row = %d", i );
if ( nvec[i] > 0 ) { /* used position */
j = vec[i][nvec[i]-1]; /* vector with label */
@@ -101,11 +115,11 @@
/* make white background for text */
fprintf(PS.fp, "1 1 1 C ");
fprintf(PS.fp, "%.1f %.1f w %.1f B fill \n",
- x - margin, y - lcount * dy - margin, y);
+ x - margin, y - lc * dy - margin, y);
}
/* make the legend */
- for ( j = 0; j < lcount; j++ ) { /* each row */
+ for ( j = h*lc; j < st; j++ ) { /*each row */
G_debug (4, " row = %d", j );
y -= dy; /* set position of next row */
for (k = 0; k < nvec[j]; k++) {
@@ -166,8 +180,12 @@
/* plot the text */
set_rgb_color(BLACK);
- fprintf(PS.fp, "a %d get %.1f %.1f MS\n", j, x + width, y);
+ fprintf(PS.fp, "a %d get %.1f %.1f MS\n", j - h*lc, x + width, y);
}
+ } /*h*/
+ x = xs;
+ y = ys - lc*dy;
+
fprintf(PS.fp, "[] 0 setdash\n");
if (PS.min_y > y) PS.min_y = y;
diff -uw grass57_exp_2004_02_28/ps/ps.map/r_vlegend.c grass57_my/ps/ps.map/r_vlegend.c
--- grass57_exp_2004_02_28/ps/ps.map/r_vlegend.c 2003-03-26 16:56:15.000000000 +0100
+++ grass57_my/ps/ps.map/r_vlegend.c 2004-03-03 20:43:22.000000000 +0100
@@ -16,6 +16,8 @@
"where x y",
"font fontname",
"fontsize fontsize",
+ "width width",
+ "cols cols",
""
};
@@ -24,12 +26,13 @@
{
char buf[1024];
char *key, *data;
- int fontsize;
+ int fontsize, cols;
double x, y, width;
fontsize = 0;
x = y = 0.0;
width = -1;
+ cols = 1;
while (input(2, buf, help))
{
if (!key_data(buf, &key, &data)) continue;
@@ -65,6 +68,13 @@
continue;
}
+ if (KEY("cols"))
+ {
+ cols = atoi (data);
+ if (cols < 1 || cols > 10) cols = 1;
+ continue;
+ }
+
error(key, data, "illegal vlegend sub-request");
}
vector.x = x;
@@ -74,5 +84,7 @@
if (width > 0) vector.width = width;
else vector.width = 3 * fontsize / 72.0;
+ vector.cols = cols;
+
return 0;
}
diff -uw grass57_exp_2004_02_28/ps/ps.map/vector.h grass57_my/ps/ps.map/vector.h
--- grass57_exp_2004_02_28/ps/ps.map/vector.h 2003-10-11 06:15:12.000000000 +0200
+++ grass57_my/ps/ps.map/vector.h 2004-03-04 02:34:20.000000000 +0100
@@ -1,5 +1,6 @@
/** Modified by: Janne Soimasuo August 1994 line_cat added **/
/** Modified by: Radim Blazek Jan 2000 acolor, label added **/
+/** Modified by: Morten Hulden Mar 2004 cols added to vector **/
#include "clr.h"
#define PI 3.14159265
/* #define MAXVECTORS 20 */
@@ -81,6 +82,7 @@
int fontsize; /* legend font size */
char *font; /* legend font */
double width; /* width of legend symbols */
+ int cols; /* number of colums */
LAYER *layer;
} ;
More information about the grass-dev
mailing list