Blame editor/ppmflash.c

Packit 78deda
Packit 78deda
/*********************************************************************/
Packit 78deda
/* ppmflash -  brighten a picture up to total whiteout               */
Packit 78deda
/* Frank Neumann, August 1993                                        */
Packit 78deda
/* V1.4 16.11.1993                                                   */
Packit 78deda
/*                                                                   */
Packit 78deda
/* version history:                                                  */
Packit 78deda
/* V1.0 ~ 15.August 1993    first version                            */
Packit 78deda
/* V1.1 03.09.1993          uses ppm libs & header files             */
Packit 78deda
/* V1.2 03.09.1993          integer arithmetics instead of float     */
Packit 78deda
/*                          (gains about 50 % speed up)              */
Packit 78deda
/* V1.3 11.10.1993          reads only one line at a time - this     */
Packit 78deda
/*                          saves LOTS of memory on big picturs      */
Packit 78deda
/* V1.4 16.11.1993          Rewritten to be NetPBM.programming con-  */
Packit 78deda
/*                          forming                                  */
Packit 78deda
/*********************************************************************/
Packit 78deda
Packit 78deda
#include "ppm.h"
Packit 78deda
Packit 78deda
/* global variables */
Packit 78deda
#ifdef AMIGA
Packit 78deda
static char *version = "$VER: ppmflash 1.4 (16.11.93)";
Packit 78deda
#endif
Packit 78deda
Packit 78deda
/**************************/
Packit 78deda
/* start of main function */
Packit 78deda
/**************************/
Packit 78deda
int main(argc, argv)
Packit 78deda
    int argc;
Packit 78deda
    char *argv[];
Packit 78deda
{
Packit 78deda
    FILE* ifp;
Packit 78deda
    int argn, rows, cols, i, j, format;
Packit 78deda
    pixel *srcrow, *destrow;
Packit 78deda
    pixel *pP, *pP2;
Packit 78deda
    pixval maxval;
Packit 78deda
    double flashfactor;
Packit 78deda
    long longfactor;
Packit 78deda
    const char* const usage = "flashfactor [ppmfile]\n        flashfactor: 0.0 = original picture, 1.0 = total whiteout\n";
Packit 78deda
Packit 78deda
    /* parse in 'default' parameters */
Packit 78deda
    ppm_init( &argc, argv );
Packit 78deda
Packit 78deda
    argn = 1;
Packit 78deda
Packit 78deda
    /* parse in flash factor */
Packit 78deda
    if (argn == argc)
Packit 78deda
        pm_usage(usage);
Packit 78deda
    if (sscanf(argv[argn], "%lf", &flashfactor) != 1)
Packit 78deda
        pm_usage(usage);
Packit 78deda
    if (flashfactor < 0.0 || flashfactor > 1.0)
Packit 78deda
        pm_error("flash factor must be in the range from 0.0 to 1.0 ");
Packit 78deda
    ++argn;
Packit 78deda
Packit 78deda
    /* parse in filename (if present, stdin otherwise) */
Packit 78deda
    if (argn != argc)
Packit 78deda
    {
Packit 78deda
        ifp = pm_openr(argv[argn]);
Packit 78deda
        ++argn;
Packit 78deda
    }
Packit 78deda
    else
Packit 78deda
        ifp = stdin;
Packit 78deda
Packit 78deda
    if (argn != argc)
Packit 78deda
        pm_usage(usage);
Packit 78deda
Packit 78deda
    /* read first data from file */
Packit 78deda
    ppm_readppminit(ifp, &cols, &rows, &maxval, &format);
Packit 78deda
Packit 78deda
    /* no error checking required here, ppmlib does it all for us */
Packit 78deda
    srcrow = ppm_allocrow(cols);
Packit 78deda
Packit 78deda
    longfactor = (long)(flashfactor * 65536);
Packit 78deda
Packit 78deda
    /* allocate a row of pixel data for the new pixels */
Packit 78deda
    destrow = ppm_allocrow(cols);
Packit 78deda
Packit 78deda
    ppm_writeppminit(stdout, cols, rows, maxval, 0);
Packit 78deda
Packit 78deda
    /** now do the flashing **/
Packit 78deda
    /* the 'float' parameter for flashing is sort of faked - in fact, we */
Packit 78deda
    /* convert it to a range from 0 to 65536 for integer math. Shouldn't */
Packit 78deda
    /* be something you'll have to worry about, though. */
Packit 78deda
Packit 78deda
    for (i = 0; i < rows; i++) {
Packit 78deda
        ppm_readppmrow(ifp, srcrow, cols, maxval, format);
Packit 78deda
Packit 78deda
        pP = srcrow;
Packit 78deda
        pP2 = destrow;
Packit 78deda
Packit 78deda
        for (j = 0; j < cols; j++) {
Packit 78deda
            PPM_ASSIGN(*pP2, 
Packit 78deda
                       PPM_GETR(*pP) + 
Packit 78deda
                       (((maxval - PPM_GETR(*pP)) * longfactor) >> 16),
Packit 78deda
                       PPM_GETG(*pP) + 
Packit 78deda
                       (((maxval - PPM_GETG(*pP)) * longfactor) >> 16),
Packit 78deda
                       PPM_GETB(*pP) + 
Packit 78deda
                       (((maxval - PPM_GETB(*pP)) * longfactor) >> 16));
Packit 78deda
Packit 78deda
            pP++;
Packit 78deda
            pP2++;
Packit 78deda
        }
Packit 78deda
Packit 78deda
        /* write out one line of graphic data */
Packit 78deda
        ppm_writeppmrow(stdout, destrow, cols, maxval, 0);
Packit 78deda
    }
Packit 78deda
Packit 78deda
    pm_close(ifp);
Packit 78deda
    ppm_freerow(srcrow);
Packit 78deda
    ppm_freerow(destrow);
Packit 78deda
Packit 78deda
    exit(0);
Packit 78deda
}
Packit 78deda