|
DataMuseum.dkPresents historical artifacts from the history of: DKUUG/EUUG Conference tapes |
This is an automatic "excavation" of a thematic subset of
See our Wiki for more about DKUUG/EUUG Conference tapes Excavated with: AutoArchaeologist - Free & Open Source Software. |
top - metrics - downloadIndex: T d
Length: 4443 (0x115b) Types: TextFile Names: »drawline.c«
└─⟦a05ed705a⟧ Bits:30007078 DKUUG GNU 2/12/89 └─⟦148e64aa4⟧ »./plot2ps.tar.Z« └─⟦ff7617d1d⟧ └─⟦this⟧ »drawline.c«
/* plot2ps, a utility for converting Unix plot files into postscript. Copyright (C) 1989 Free Software Foundation, Inc. Plot2ps is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY. No author or distributor accepts responsibility to anyone for the consequences of using it or for whether it serves any particular purpose or works at all, unless he says so in writing. Refer to the GNU General Public License for full details. Everyone is granted permission to copy, modify and redistribute plot2ps, but only under the conditions described in the GNU General Public License. A copy of this license is supposed to have been given to you along with plot2ps so you can know your rights and responsibilities. It should be in a file named COPYING. Among other things, the copyright notice and this notice must be preserved on all copies. */ /* This file is the draw_line routine, which is used by the other plot library routines. Coordinates are accumulated in the arrays line_x and line_y. The number of points accumulated is stored in PointsInLine. When draw_line is called it outputs any accumulated points. PointsInLine is set to one with the first point replaced by the last point of the previous line - so that the next line can be a continuation of the previous one. */ #include <math.h> #include <stdio.h> #ifdef sequent #include <strings.h> #else #include <string.h> #endif #include "plot3.h" extern int perror(); extern int exit(); extern int printf(); extern int fprintf(); #ifndef mips extern char *sprintf(); #endif extern int fputs(), fputc(); #ifndef hpux extern void *malloc(); extern void *realloc(); #endif \f /* plot (3) routines ___________________________________________ */ double x_input_min = 0.; /* minimum input x coordinate */ double y_input_min = 0.; /* minimum input y coordinate */ double x_output_min = 0.; /* minimum output x coordinate */ double y_output_min = 0.; /* minimum output y coordinate */ double x_output_max = 750.; /* maximum-minimum output x coordinate */ double y_output_max = 750.; /* maximum-minimum output y coordinate */ double scaleup = 10.; /* input to output scaleing for both x and y */ int last_x=0, last_y = 0; /* location of the last coordinates used */ /* the scaling and rotation part of a postscript transformation matrix */ double text_transformation_matrix[4] = { 1., 0., 0., 1. }; /* Note: define MAX_NO_OF_POINTS according to the number of points the postscript device can handle. Experimentation has shown 150 to be reasonable */ #define MAX_NO_OF_POINTS 150 int line_x[MAX_NO_OF_POINTS]; int line_y[MAX_NO_OF_POINTS]; /* We accumulate coordinates untill we either have enought points or the line is broken. The counter tells us whether we have accumulated points and how many */ int PointsInLine=0; /* this bit vector represents the line style (eg. dashed) for idraw. We intitialize it to all ones which represents a solid line. */ long line_type_bit_vector = 65535; /* this is a string that should conatain a postscript vector argument for the postscript setdash command. This is allocted in the open(3) function. */ char *line_type_setdash; /* the current length of the above buffer */ int line_type_setdash_length; /* one greater than the length in number of bits in the dash pattern. */ int line_type_setdash_bits=0; \f /* draw a line using all the accumulated points if there are any. */ int draw_line () { if (PointsInLine > 1 ) { int i; fputs ("Begin %I MLine\n", stdout); printf("%%I b %d\n", line_type_bit_vector); printf ("0 0 0 [ %s ] %d SetB\n", line_type_setdash, line_type_setdash_bits); printf ("%%I cfg plotFg\n%g %g %g SetCFg\n", fgcolor_red, fgcolor_green, fgcolor_blue); fputs ("%I cbg White\n1 1 1 SetCBg\n", stdout); if (fill_level == -1.) { printf ("%%I p\nnone SetP\n", fill_level); } else { printf ("%%I p\n%g SetP\n", fill_level); } printf ("%%I t\n[ %f 0 0 %f 0 0 ] concat\n", 1./scaleup, 1./scaleup); printf("%%I %d\n", PointsInLine); for (i=0; i<PointsInLine; i++) printf ("%d %d\n", line_x[i], line_y[i]); printf ("%d MLine\nEnd\n\n", PointsInLine); /* leave the last point as the first point of the next line */ line_x[0] = line_x [PointsInLine - 1]; line_y[0] = line_y [PointsInLine - 1]; PointsInLine = 1; } return 0; }