home *** CD-ROM | disk | FTP | other *** search
/ OS/2 Shareware BBS: 10 Tools / 10-Tools.zip / netpbma.zip / ppm / pgmtoppm.c < prev    next >
C/C++ Source or Header  |  1993-10-04  |  3KB  |  151 lines

  1. /* pgmtoppm.c - colorize a portable graymap into a portable pixmap
  2. **
  3. ** Copyright (C) 1991 by Jef Poskanzer.
  4. **
  5. ** Permission to use, copy, modify, and distribute this software and its
  6. ** documentation for any purpose and without fee is hereby granted, provided
  7. ** that the above copyright notice appear in all copies and that both that
  8. ** copyright notice and this permission notice appear in supporting
  9. ** documentation.  This software is provided "as is" without express or
  10. ** implied warranty.
  11. */
  12.  
  13. #include "ppm.h"
  14.  
  15. int
  16. main( argc, argv )
  17.     int argc;
  18.     char* argv[];
  19.     {
  20.     FILE* ifp;
  21.     gray* grayrow;
  22.     register gray* gP;
  23.     pixel p;
  24.     pixel* pixelrow;
  25.     register pixel* pP;
  26.     pixel** mappixels;
  27.     int argn, rows, cols, format, maprows, mapcols, mapmaxcolor, row;
  28.     register int col;
  29.     gray maxval;
  30.     pixval mapmaxval;
  31.     char* color0;
  32.     char* color1;
  33.     pixval red0, grn0, blu0, red1, grn1, blu1;
  34.     char* usage = "<colorspec> [pgmfile]\n                 <colorspec1>,<colorspec2> [pgmfile]\n                 -map mapfile [pgmfile]";
  35.  
  36.  
  37.     ppm_init( &argc, argv );
  38.  
  39.     argn = 1;
  40.     mappixels = (pixel**) 0;
  41.  
  42.     if ( argn < argc && argv[argn][0] == '-' && argv[argn][1] != '\0' )
  43.     {
  44.     if ( pm_keymatch( argv[argn], "-map", 2 ) )
  45.         {
  46.         ++argn;
  47.         if ( argn == argc )
  48.         pm_usage( usage );
  49.         ifp = pm_openr( argv[argn] );
  50.         mappixels = ppm_readppm( ifp, &mapcols, &maprows, &mapmaxval );
  51.         pm_close( ifp );
  52.         mapmaxcolor = maprows * mapcols - 1;
  53.         }
  54.     else
  55.         pm_usage( usage );
  56.     ++argn;
  57.     }
  58.  
  59.     if ( mappixels == (pixel**) 0 )
  60.     {
  61.     if ( argn == argc )
  62.         pm_usage( usage );
  63.     color0 = argv[argn];
  64.     ++argn;
  65.     }
  66.  
  67.     if ( argn != argc )
  68.     {
  69.     ifp = pm_openr( argv[argn] );
  70.     ++argn;
  71.     }
  72.     else
  73.     ifp = stdin;
  74.  
  75.     if ( argn != argc )
  76.     pm_usage( usage );
  77.  
  78.     pgm_readpgminit( ifp, &cols, &rows, &maxval, &format );
  79.     grayrow = pgm_allocrow( cols );
  80.     if ( mappixels == (pixel**) 0 )
  81.     ppm_writeppminit( stdout, cols, rows, (pixval) maxval, 0 );
  82.     else
  83.     ppm_writeppminit( stdout, cols, rows, mapmaxval, 0 );
  84.     pixelrow = ppm_allocrow( cols );
  85.  
  86.     if ( mappixels == (pixel**) 0 )
  87.     {
  88.     color1 = index( color0, '-' );
  89.     if ( color1 == 0 )
  90.         {
  91.         color1 = color0;
  92.         red0 = 0;
  93.         grn0 = 0;
  94.         blu0 = 0;
  95.         }
  96.     else
  97.         {
  98.         *color1 = '\0';
  99.         ++color1;
  100.         p = ppm_parsecolor( color0, (pixval) maxval );
  101.         red0 = PPM_GETR( p );
  102.         grn0 = PPM_GETG( p );
  103.         blu0 = PPM_GETB( p );
  104.         }
  105.     p = ppm_parsecolor( color1, (pixval) maxval );
  106.     red1 = PPM_GETR( p );
  107.     grn1 = PPM_GETG( p );
  108.     blu1 = PPM_GETB( p );
  109.     }
  110.  
  111.     for ( row = 0; row < rows; ++row )
  112.     {
  113.     pgm_readpgmrow( ifp, grayrow, cols, maxval, format );
  114.  
  115.     if ( mappixels == (pixel**) 0 )
  116.         {
  117.         for ( col = 0, gP = grayrow, pP = pixelrow;
  118.           col < cols;
  119.           ++col, ++gP, ++pP )
  120.         PPM_ASSIGN(
  121.             *pP,
  122.             ( red0 * ( maxval - *gP ) + red1 * *gP ) / maxval,
  123.             ( grn0 * ( maxval - *gP ) + grn1 * *gP ) / maxval,
  124.             ( blu0 * ( maxval - *gP ) + blu1 * *gP ) / maxval );
  125.  
  126.         }
  127.     else
  128.         {
  129.         register int c;
  130.  
  131.         for ( col = 0, gP = grayrow, pP = pixelrow;
  132.           col < cols;
  133.           ++col, ++gP, ++pP )
  134.         {
  135.         if ( maxval == mapmaxcolor )
  136.             c = *gP;
  137.         else
  138.             c = *gP * mapmaxcolor / maxval;
  139.         *pP = mappixels[c / mapcols][c % mapcols];
  140.         }
  141.         }
  142.  
  143.     ppm_writeppmrow( stdout, pixelrow, cols, (pixval) maxval, 0 );
  144.     }
  145.  
  146.     pm_close( ifp );
  147.     pm_close( stdout );
  148.  
  149.     exit( 0 );
  150.     }
  151.