Annotation of 43BSD/usr.lib/libplot/dumb/subr.c, revision 1.1

1.1     ! root        1: /*
        !             2:  * Copyright (c) 1980 Regents of the University of California.
        !             3:  * All rights reserved.  The Berkeley software License Agreement
        !             4:  * specifies the terms and conditions for redistribution.
        !             5:  */
        !             6: 
        !             7: #ifndef lint
        !             8: static char sccsid[] = "@(#)subr.c     5.1 (Berkeley) 5/7/85";
        !             9: #endif not lint
        !            10: 
        !            11: #include "dumb.h"
        !            12: 
        !            13: /* Does not plot first point -- assumed that it is already plotted */
        !            14: dda_line(ch, x0, y0, x1, y1)
        !            15:        char ch;
        !            16:        int x0, y0;     /* already transformed to screen coords */
        !            17:        int x1, y1;     /* untransformed */
        !            18: {
        !            19:        int length, i;
        !            20:        double deltaX, deltaY;
        !            21:        double x, y;
        !            22:        double floor();
        !            23:        int abs();
        !            24: 
        !            25:        scale(x1, y1);
        !            26: 
        !            27:        length = abs(x1 - x0);
        !            28:        if (abs(y1 -y0) > length)
        !            29:                length = abs(y1 - y0);
        !            30: 
        !            31:        if (length == 0)
        !            32:                return;
        !            33: 
        !            34:        deltaX = (double) (x1 - x0)/(double) length;
        !            35:        deltaY = (double) (y1 - y0)/(double) length;
        !            36: 
        !            37:        x = (double) x0 + 0.5;
        !            38:        y = (double) y0 + 0.5;
        !            39: 
        !            40:        for (i=0; i < length; ++i) {
        !            41:                x += deltaX;
        !            42:                y += deltaY;
        !            43:                x0 = floor(x);
        !            44:                y0 = floor(y);
        !            45:                currentx = x0;
        !            46:                currenty = y0;
        !            47:                screenmat[currentx][currenty] = ch;
        !            48:        }
        !            49: }

unix.superglobalmegacorp.com

This archive runs on limited infrastructure. Preserving old code on modern bandwidth. Automated agents are requested to crawl responsibly.