Annotation of researchv10no/cmd/qsnap/Qsnap.c, revision 1.1

1.1     ! root        1: #include       <stdio.h>
        !             2: #include       <sys/types.h>
        !             3: #include       <sys/stat.h>
        !             4: #include       "defines.h"
        !             5: #include       "piclib.h"
        !             6: 
        !             7: #define XTIMES         Times
        !             8: #define YTIMES         Times
        !             9: #define Min(a,b)       ((a)>(b)?(b):(a))
        !            10: #define Max(a,b)       ((a)<(b)?(b):(a))
        !            11: 
        !            12: int Xmax, Ymax, Xmin, Ymin;
        !            13: int Dither=0, Times=3, Bright=0;
        !            14: int Film = 0;
        !            15: int Filter = GREEN;
        !            16: int Reso = 0;
        !            17: int redonly = 0;
        !            18: int settimes= 0;
        !            19: int setbright=0;
        !            20: int xoffset = 0;
        !            21: int yoffset = 0;
        !            22: 
        !            23: unsigned char nq[9];
        !            24: char *malloc();
        !            25: unsigned char *rgb;
        !            26: int lsize;
        !            27: int multiple=1;                /* number of exposures */
        !            28: int fad=1, dodub=0;
        !            29: 
        !            30: Usage(str)
        !            31:        char *str;
        !            32: {      fprintf(stderr, "qsnap: %s\n", str);
        !            33:        fprintf(stderr, "usage: qsnap -bdfmnrxFLRXY [N ...] file\n");
        !            34:        fprintf(stderr, "b  brightness  [0-8], defaults to 0 (2k) or 2 (4k)\n");
        !            35:        fprintf(stderr, "d  dither image +- N [2-255]\n");
        !            36:        fprintf(stderr, "f  filmtype [0-2], defaults to 0 (custom,lin,pola)\n");
        !            37:        fprintf(stderr, "m  enlargement [1-N], defaults to 3(2k) or 6(4k)\n");
        !            38:        fprintf(stderr, "n  TMAX-100 b&w corrected exposure\n");
        !            39:        fprintf(stderr, "r  expose red only (for multiple red overlays)\n");
        !            40:        fprintf(stderr, "x  N exposures (not with -L)\n");
        !            41:        fprintf(stderr, "F  bwfilter [0-3], defaults to 2 (n,r,g,b)\n");
        !            42:        fprintf(stderr, "L  raw file, no header, bw, line by line (no m,d,x)\n");
        !            43:        fprintf(stderr, "R  N set resolution to N [N=2 or N=4]\n");
        !            44:        fprintf(stderr, "X  add x-offset N (eg 480/m, for 35mm camera)\n");
        !            45:        fprintf(stderr, "Y  add y-offset N\n");
        !            46:        exit(1);
        !            47: }
        !            48: 
        !            49: main(argc, argv)
        !            50:        char **argv;
        !            51: {
        !            52:        int i=1, base=2;        /* base of option arguments */
        !            53:        int linebyline = 0;
        !            54:        char c;
        !            55: 
        !            56:        if (argc > 1 && argv[1][0] == '-')
        !            57:        {       base++;
        !            58:                while ((c = argv[1][i++]) != '\0')
        !            59:                        switch (c) {
        !            60:        /* TMAX-100 */  case 'n': dodub = 1; break;
        !            61:        /* N exps */    case 'x': if (argc >= base)
        !            62:                                  {     sscanf(argv[base-1], "%d", &multiple);
        !            63:                                        base++;
        !            64:                                        fad = 0;
        !            65:                                        break;
        !            66:                                  } else
        !            67:                                        Usage("missing argument for `a' flag");
        !            68:        /* bright   */  case 'b': if (argc >= base)
        !            69:                                  {     sscanf(argv[base-1], "%d", &Bright);
        !            70:                                        base++;
        !            71:                                        Bright = Bright%9;
        !            72:                                        setbright = 1;
        !            73:                                        break;
        !            74:                                  } else
        !            75:                                        Usage("missing argument for `b' flag");
        !            76:        /* dither   */  case 'd': if (argc >= base)
        !            77:                                  {     sscanf(argv[base-1], "%d", &Dither);
        !            78:                                        base++;
        !            79:                                        if (Dither < 0) Dither = -Dither;
        !            80:                                        break;
        !            81:                                  } else
        !            82:                                        Usage("missing argument for `d' flag");
        !            83: 
        !            84:        /* filmtype */  case 'f': if (argc >= base)
        !            85:                                  {     sscanf(argv[base-1], "%d", &Film);
        !            86:                                        Film = Film%8;
        !            87:                                        base++;
        !            88:                                        if (Film == 6)
        !            89:                                                Usage("unknown film type");
        !            90:                                        break;
        !            91:                                  } else
        !            92:                                        Usage("missing argument for `f' flag");
        !            93:        /* multiply */  case 'm': if (argc >= base)
        !            94:                                  {     sscanf(argv[base-1], "%d", &Times);
        !            95:                                        base++;
        !            96:                                        settimes = 1;
        !            97:                                        break;
        !            98:                                  } else
        !            99:                                        Usage("missing argument for `m' flag");
        !           100:        /* filter */    case 'F': if (argc >= base)
        !           101:                                  {     sscanf(argv[base-1], "%d", &Filter);
        !           102:                                        Filter = Filter%4;
        !           103:                                        base++;
        !           104:                                        break;
        !           105:                                  } else
        !           106:                                        Usage("missing argument for `F' flag");
        !           107:                        case 'L': if (argc >= base)
        !           108:                                  {     sscanf(argv[base-1], "%d", &lsize);
        !           109:                                        linebyline = 1;
        !           110:                                        base++;
        !           111:                                        break;
        !           112:                                  } else
        !           113:                                        Usage("missing argument for `L' flag");
        !           114:                        case 'R': if (argc >= base)
        !           115:                                  {     sscanf(argv[base-1], "%d", &Reso);
        !           116:                                        base++;
        !           117:                                        break;
        !           118:                                  } else
        !           119:                                        Usage("missing argument for `R' flag");
        !           120:                        case 'X': if (argc >= base)
        !           121:                                  {     sscanf(argv[base-1], "%d", &xoffset);
        !           122:                                        base++;
        !           123:                                        break;
        !           124:                                  } else
        !           125:                                        Usage("missing argument for `X' flag");
        !           126:                        case 'Y': if (argc >= base)
        !           127:                                  {     sscanf(argv[base-1], "%d", &yoffset);
        !           128:                                        base++;
        !           129:                                        break;
        !           130:                                  } else
        !           131:                                        Usage("missing argument for `Y' flag");
        !           132:                        case 'r': redonly = 1; break;
        !           133:                        default : Usage("unknown option");
        !           134:                        }
        !           135:        }
        !           136:        if (dodub == 1 && (setbright || Film))
        !           137:        {       fprintf(stderr, "warning: -b and -f flags have ");
        !           138:                fprintf(stderr, "no effect when combined with -n\n");
        !           139:        }
        !           140:        if (base != argc) Usage("bad arglist");
        !           141: 
        !           142:        qreset();
        !           143:        getbright(nq);
        !           144:        if (Reso == 2 || Reso == 4)
        !           145:                setreso(Reso);
        !           146:        qpause();
        !           147:        Reso = resolution();
        !           148:        Xmax = 1024*Reso;
        !           149:        Ymax =  768*Reso;
        !           150:        Xmin = -512*Reso;
        !           151:        Ymin =  384*Reso;
        !           152:        if (linebyline && lsize > Xmax)
        !           153:        {       fprintf(stderr, "image too wide: %d, max is %d\n", lsize, Xmax);
        !           154:                exit(1);
        !           155:        }
        !           156:        if (dodub && nq[2] != 81)
        !           157:        {       fprintf(stderr, "option -n requires that you first set\n");
        !           158:                fprintf(stderr, "\t$ qbright 36 58 81 103 126 148 171 193\n");
        !           159:                exit(1);
        !           160:        }
        !           161:        if (Reso == 4)
        !           162:        {       if (!settimes)  Times = 6;
        !           163:                if (!setbright) Bright = 2;
        !           164:        }
        !           165: 
        !           166:        qpause();
        !           167:        nocalibs();
        !           168:        handshake(1); fflush(stdout);
        !           169:        if (dodub)
        !           170:        {       qpause();
        !           171:                customluts(TMAX_100);
        !           172:                Bright = 2;
        !           173:        } else
        !           174:                filmtype(Film);
        !           175:        qpause();
        !           176:        advance(fad);
        !           177:        qpause();
        !           178:        if (fad==0)
        !           179:                shutter(1);
        !           180:        fflush(stdout);
        !           181: Again:
        !           182:        qpause();
        !           183:        brightness(Bright, Bright, Bright, Bright);
        !           184:        printf("brightness %d (%d)\n", Bright, nq[Bright]); fflush(stdout);
        !           185:        if (linebyline)
        !           186:                znap(argv[base-1]);
        !           187:        else
        !           188:                snap(argv[base-1]);
        !           189:        if (fad==0)
        !           190:                shutter(0);
        !           191:        exit(0);
        !           192: }
        !           193: 
        !           194: znap(name)
        !           195:        char *name;
        !           196: {
        !           197:        register i;
        !           198:        int fd, h, w;
        !           199:        unsigned char obuf[8192];
        !           200: 
        !           201:        w = lsize;
        !           202:        h = (lsize>683*Reso)?(683*Reso):lsize;
        !           203:        /* the maximum for 35mm; for 4x5 it is 768*Reso */
        !           204: 
        !           205:        if ((fd = open(name, 0)) < 0)
        !           206:        {       fprintf(stderr, "cannot open %s\n", name);
        !           207:                exit(1);
        !           208:        }
        !           209:        printf("file: %s\n", name);
        !           210:        window(Xmin+xoffset, Ymin-yoffset, w, h);
        !           211:        singlepass(Filter);
        !           212:        fflush(stdout);
        !           213:        for (i = 0; i < h; i++)
        !           214:        {       read(fd, obuf, w);
        !           215:                qwrite(obuf, w);
        !           216:        }
        !           217:        close(fd);
        !           218:        fprintf(stderr, "done\n");
        !           219: }
        !           220: 
        !           221: snap(name)
        !           222:        char *name;
        !           223: {
        !           224:        int fd, h, w;
        !           225:        struct pfile image;
        !           226: 
        !           227:        if((fd = openf(name, &image)) == -1 || !readf(fd, &image))
        !           228:        {       fprintf(stderr, "bad image %s\n", name);
        !           229:                exit(1);
        !           230:        }
        !           231:        w = image.r.corner.x - image.r.origin.x;
        !           232:        if (w*XTIMES > Xmax)
        !           233:        {       fprintf(stderr, "image too wide: %d, max %d\n", w*XTIMES, Xmax);
        !           234:                exit(1);
        !           235:        }
        !           236:        h = image.r.corner.y - image.r.origin.y;
        !           237:        h = Min(Ymax/YTIMES, h);
        !           238:        while (multiple-- > 0)
        !           239:        {       printf("file: %s\n", name);
        !           240:                window(Xmin+xoffset, Ymin-yoffset, w*XTIMES, h*YTIMES);
        !           241:                fflush(stdout);
        !           242:                if (image.nchan == 1)
        !           243:                {       singlepass(Filter);
        !           244:                        onechannel(image.pixred, h, w);
        !           245:                } else
        !           246:                {       threepass();
        !           247:                        fprintf(stderr, "red\n"); onechannel(image.pixred, h, w);
        !           248:                        if (redonly) goto done;
        !           249:                        fprintf(stderr, "grn\n"); onechannel(image.pixgrn, h, w);
        !           250:                        fprintf(stderr, "blu\n"); onechannel(image.pixblu, h, w);
        !           251:                }
        !           252:                sleep(10);
        !           253:                if (multiple > 0)
        !           254:                        printf("x pass %d\n", multiple);
        !           255:        }
        !           256:        close(fd);
        !           257: done:  fprintf(stderr, "done\n");
        !           258: }
        !           259: 
        !           260: onechannel(from, h, w)
        !           261:        unsigned char *from;
        !           262: {
        !           263:        fflush(stdout);
        !           264:        if (Dither)
        !           265:        {       prerand();
        !           266:                onedither(from, h, w);
        !           267:        } else
        !           268:                 straight(from, h, w);
        !           269: }
        !           270: 
        !           271: straight(from, h, w)
        !           272:        unsigned char *from;
        !           273: {
        !           274:        register i, j, k;
        !           275:        register unsigned char *p, *q;
        !           276:        unsigned char obuf[8192];
        !           277:        int chunk = w*XTIMES;
        !           278: 
        !           279:        for (i = 0, p = from; i < h; i++)
        !           280:        {       q = obuf;
        !           281:                for (j = 0; j < w; j++, p++)
        !           282:                for (k = 0; k < XTIMES; k++)
        !           283:                        *q++ = *p;
        !           284:                for (k = 0; k < YTIMES; k++)
        !           285:                {       qwrite(obuf, chunk);
        !           286:                        if (chunk > 2048) qwait(200);
        !           287:        }       }
        !           288: }
        !           289: 
        !           290: short Nrand[5000];
        !           291: 
        !           292: prerand()
        !           293: {      register int i, D1=Dither, D2=Dither/2;
        !           294: 
        !           295:        for (i = 0; i < 5000; i++)
        !           296:                Nrand[i] = (short) (nrand(D1) - D2);
        !           297: }
        !           298: 
        !           299: onedither(from, h, w)
        !           300:        unsigned char *from;
        !           301: {
        !           302:        register int c, m, kk=0;
        !           303:        register unsigned char *op, *q;
        !           304:        unsigned char *p, obuf[8192];
        !           305:        int i, j, k;
        !           306:        int chunk = w*XTIMES;
        !           307: 
        !           308:        for (i = 0, p = from; i < h; i++, p = op)
        !           309:        for (k = 0; k < YTIMES; k++)
        !           310:        {       q = obuf;
        !           311:                op = p;
        !           312:                j = w;
        !           313:                do{
        !           314:                        m = XTIMES;
        !           315:                        do{
        !           316:                                c = *op + Nrand[kk];
        !           317:                                if (++kk >= 5000) kk = 0;
        !           318:                                if(c<0)
        !           319:                                        c=0;
        !           320:                                if(c>255)
        !           321:                                        c=255;
        !           322:                                *q++ = c;
        !           323:                        }while(--m);
        !           324:                        op++;
        !           325:                }while(--j);
        !           326:                qwrite(obuf, chunk);
        !           327:        }
        !           328: }
        !           329: 
        !           330: qwait(n)
        !           331: {      int i;
        !           332:        for (i = 0; i < n; i++) ;
        !           333: }
        !           334: 
        !           335: dimension(fd)
        !           336: {      struct stat bam;
        !           337:        int N;
        !           338:        extern float fsqrt();
        !           339: 
        !           340:        if (fstat(fd, &bam)==0)
        !           341:        {       N = bam.st_size;
        !           342:                N = (int) fsqrt((double)N+1.0);
        !           343:                return N;
        !           344:        }
        !           345:        return 0;
        !           346: }

unix.superglobalmegacorp.com

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