|
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 - downloadIndex: ┃ T d ┃
Length: 3956 (0xf74) Types: TextFile Names: »draw.c«
└─⟦a0efdde77⟧ Bits:30001252 EUUGD11 Tape, 1987 Spring Conference Helsinki └─ ⟦526ad3590⟧ »EUUGD11/gnu-31mar87/X.V10.R4.tar.Z« └─⟦2109abc41⟧ └─ ⟦this⟧ »./X.V10R4/libapollo/draw.c«
#ifndef lint static char *rcsid_draw_c = "$Header: draw.c,v 10.1 86/11/29 13:51:24 jg Rel $"; #endif lint /* Copyright 1986 by the University of Utah Permission to use, copy, modify, and distribute this software and its documentation for any purpose and without fee is hereby granted, provided that the above copyright notice appear in all copies and that both that copyright notice and this permission notice appear in supporting documentation, and that the name of the University of Utah not be used in advertising or publicity pertaining to distribution of the software without specific, written prior permission. The University of Utah makes no representations about the suitability of this software for any purpose. It is provided "as is" without express or implied warranty. */ /* draw.c Draw lines, curves, and polygons on the screen * * DrawCurve Draw a generalized line/polygon/combination * */ /* * ToDo: * Brush shapes * Patterned Curves * Curves */ #include "Xapollo.h" status_$t status; static Draw_Solid(srcpix, xbase, ybase, op, vertcount, verts, clipcount, clips, zmask) int srcpix; /* Pixel value to write */ int xbase, ybase; /* Origin of curve */ int op; /* Opcode */ int vertcount; /* Length of Vertex array */ Vertex *verts; /* Vertices */ int clipcount; /* Length of clip array */ CLIP *clips; /* clipping rectangles */ int zmask; { register Vertex *v = verts; char *kind; int i; int allmask = -1; gpr_$window_t cwindow; gpr_$set_draw_value((gpr_$pixel_value_t)srcpix, status); set_zmask( zmask ); set_op( op ); do { register int xp, yp; register Vertex *v = verts; register int vc = vertcount; GetNextClip(clips, cwindow); CheckCursor(cwindow.x_coord, cwindow.y_coord, cwindow.x_size, cwindow.y_size); gpr_$set_clip_window( cwindow, status); do { if (v->flags & VertexRelative) { xp += v->x; yp += v->y; } else { xp = v->x + xbase; yp = v->y + ybase; } /* XXX - ignore VertexCurved for now */ /* XXX - ignore VertexDrawLastPoint for now */ if (v->flags & VertexDontDraw) gpr_$move((short)xp, (short)yp, status); else gpr_$line((short)xp, (short)yp, status); v++; } while (--vc > 0); } while (--clipcount > 0); RestoreCursor(); } DrawCurve (verts, vertcount, xbase, ybase, srcpix, altpix, mode, bwidth, bheight, pat, patlen, patmul, clips, clipcount, func, zmask) Vertex *verts; int vertcount, xbase, ybase, srcpix, altpix, mode, bwidth, bheight; int pat, patlen, patmul, clipcount, zmask; register int func; CLIP *clips; { static gpr_$line_pattern_t pattern = {0, 0, 0, 0}; int op = func; pattern[0] = pat; /* must invert bits ? */ if (mode == DrawSolidLine) patlen = 0; gpr_$set_line_pattern((short)patmul, pattern, (short)patlen, status); if (bwidth == 1 && bheight == 1) switch (mode) { case DrawSolidLine: Draw_Solid(srcpix, xbase, ybase, op, vertcount, verts, clipcount, clips, zmask); break; case DrawDashedLine: Draw_Solid(srcpix, xbase, ybase, op, vertcount, verts, clipcount, clips, zmask); break; case DrawPatternedLine: Draw_Solid(srcpix, xbase, ybase, op, vertcount, verts, clipcount, clips, zmask); break; } else switch (mode) { /* XXX - ignores brush specification for now */ case DrawSolidLine: Draw_Solid(srcpix, xbase, ybase, op, vertcount, verts, clipcount, clips, zmask); break; case DrawDashedLine: Draw_Solid(srcpix, xbase, ybase, op, vertcount, verts, clipcount, clips, zmask); break; case DrawPatternedLine: Draw_Solid(srcpix, xbase, ybase, op, vertcount, verts, clipcount, clips, zmask); break; } }