Annotation of researchv9/jerq/src/lib/j/circle.c, revision 1.1.1.1

1.1       root        1: #ifndef        MUX
                      2: #define        Jcursinhibit()  cursinhibit()
                      3: #define        Jcursallow()    cursallow()
                      4: #define        lrectf(l, r, f) rectf(l, r, f)
                      5: #define        lpoint(l, p, f) point(l, p, f)
                      6: #endif
                      7: 
                      8: #include <jerq.h>
                      9: #define        DB              ((Word *)0x700000)
                     10: #define        ONSCREEN(b)     (b->base>=DB && b->base<DB+XMAX/WORDSIZE*YMAX)
                     11: /*     Form a circle of radius r centered at x1,y1
                     12:  *     The boundary is a sequence of vertically, horizontally,
                     13:  *     or diagonally adjacent points that minimize 
                     14:  *     abs(x^2+y^2-r^2).
                     15:  *
                     16:  *     The circle is guaranteed to be symmetric about
                     17:  *     the horizontal, vertical, and diagonal axes
                     18:  */
                     19: circle(b,p,r,f)
                     20:        Bitmap *b;
                     21:        Point p;
                     22: {
                     23:        short inhibited;
                     24:        int x1=p.x;
                     25:        register y1=p.y;
                     26:        register eps = 0;       /* x^2 + y^2 - r^2 */
                     27:        register dxsq = 1;              /* (x+dx)^2-x^2*/
                     28:        register dysq = 1 - 2*r;
                     29:        register exy;
                     30:        int x0 = x1;
                     31:        register y0 = y1 - r;
                     32:        y1 += r;
                     33:        if (f == F_XOR) {       /* endpoints coincide */
                     34:                point(b,Pt(x0,y0),f);
                     35:                point(b,Pt(x0,y1),f);
                     36:                inhibited=0;
                     37:        }else if(ONSCREEN(b)){
                     38:                Jcursinhibit();
                     39:                inhibited=1;
                     40:        }
                     41:        while(y1 > y0) {
                     42:                lpoint(b,Pt(x0,y0),f);
                     43:                lpoint(b,Pt(x0,y1),f);
                     44:                lpoint(b,Pt(x1,y0),f);
                     45:                lpoint(b,Pt(x1,y1),f);
                     46:                exy = eps + dxsq + dysq;
                     47:                if(-exy <= eps+dxsq) {
                     48:                        y1--;
                     49:                        y0++;
                     50:                        eps += dysq;
                     51:                        dysq += 2;
                     52:                }
                     53:                if(exy <= -eps) {
                     54:                        x1++;
                     55:                        x0--;
                     56:                        eps += dxsq;
                     57:                        dxsq += 2;
                     58:                }
                     59:        }
                     60:        lpoint(b,Pt(x0,y0),f);
                     61:        lpoint(b,Pt(x1,y0),f);
                     62:        if(inhibited)
                     63:                Jcursallow();
                     64: }

unix.superglobalmegacorp.com

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