Man Linux: Main Page and Category List

NAME

       ppmshadow - add simulated shadows to a portable pixmap image

SYNOPSIS

       ppmshadow  [-b  blur_size]  [-k]  [-t]  [-x  xoffset] [-y yoffset] [-u]
       [pnmfile]

DESCRIPTION

       ppmshadow adds a simulated shadow to an image,  giving  the  appearance
       that  the contents of the image float above the page, casting a diffuse
       shadow on the background.  Shadows can either  be  black,  as  cast  by
       opaque objects, or translucent, where the shadow takes on the colour of
       the object which casts it.  You can specify the extent  of  the  shadow
       and its displacement from the image with command line options.

OPTIONS

       -b blur_size

              Sets  the  distance  of the light source from the image.  Larger
              values move the light source  closer,  casting  a  more  diffuse
              shadow,  while  smaller  settings  move  the light further away,
              yielding a sharper shadow.  blur_size defaults to 11 pixels.

       -k     Keep the intermediate temporary image  files.   When  debugging,
              these  intermediate files provide many clues as to the source of
              an error.  See FILES below for a list of the  contents  of  each
              file.

       -t     Consider the non-background material in the image translucent --
              it casts shadows of its own colour rather than a  black  shadow,
              which  is  default.   This often results in fuzzy, difficult-to-
              read images but in some circumstances may look better.

       -u     Print command syntax and a summary of options.

       -x xoffset
              Specifies the displacement of the light source to  the  left  of
              the  image.   Larger  settings of xoffset displace the shadow to
              the right, as would be cast by a light further to the left.   If
              not  specified,  the  horizontal  offset  is  half  of blur_size
              (above), to the left.

       -y yoffset
              Specifies the displacement of the light source above the top  of
              the  image.   Larger  settings  displace  the  shadow  downward,
              corresponding to moving the light further above the top  of  the
              image.  If you don’t specify -y, the vertical offset defaults to
              the same as the horizontal offset (above), upward.

FILES

       Input is an anymap named by the pnmfile command line argument;  if  you
       don’t specify pnmfile, the input is the Standard Input file.

       Output is a always a PPM file, written to Standard Output.

       pnmfile creates a number of temporary files as it executes.  It creates
       them in the /tmp directory, with names of the form:

       _PPMshadowpid-N.ppm

       where pid is the process number of the ppmshadow process  and  N  is  a
       number  identifying  the file as described below.  In normal operation,
       ppmshadow deletes temporary files as soon as it is done with  them  and
       leaves   no   debris  around  after  it  completes.   To  preserve  the
       intermediate files for debugging, use the -k command line option.

       N in the filename means:

       1      Positive binary mask

       2      Convolution kernel for blurring shadow

       3      Blurred shadow image

       4      Clipped shadow image, offset as requested

       5      Blank image with background of source image

       6      Offset shadow

       7      Inverse mask file

       8      Original image times inverse mask

       9      Generated shadow times positive mask

       10     Shadow times background colour

LIMITATIONS

       The source image must contain sufficient space  on  the  edges  in  the
       direction  in  which  the shadow is cast to contain the shadow -- if it
       doesn’t some of the internal steps may fail.  You  can  usually  expand
       the  border  of  a  too-tightly-cropped  image  with  pnmmargin  before
       processing it with ppmshadow.

       Black pixels and pixels with the same color  as  the  image  background
       don’t  cast  a  shadow.   If  this  causes unintentional "holes" in the
       shadow, fill the offending areas with a color which differs from  black
       or  the  background  by RGB values of 1, which will be imperceptible to
       the viewer.  Since the comparison is exact, the modified areas will now
       cast shadows.

       The  background  color  of  the source image (which is preserved in the
       output) is deemed to be the color of the pixel at the top left  of  the
       input  image.  If that pixel isn’t part of the background, simply add a
       one-pixel border at the top of the image, generate  the  shadow  image,
       then delete the border from it.

       If  something  goes  wrong  along  the way, the error messages from the
       various Netpbm programs  ppmshadow  calls  will,  in  general,  provide
       little  or  no  clue  as to where ppmshadow went astray.  In this case,
       Specify the -k option and  examine  the  intermediate  results  in  the
       temporary  files  (which  this  option causes to be preserved).  If you
       manually run the commands that ppmshadow runs on these files,  you  can
       figure  out  where  the problem is.  In problem cases where you want to
       manually tweak the image generation process along the way, you can keep
       the  intermediate  files  with the -k option, modify them appropriately
       with an image editor, then recombine them with the steps  used  by  the
       code  in  ppmshadow.   See  the  ppmshadow.doc  document for additional
       details and examples of the intermediate files.

       Shadows are by default black, as cast by opaque material in  the  image
       occluding  white  light.   Use  the  -t  option to simulate translucent
       material, where the shadow takes on the colour of the object that casts
       it.   If the contrast between the image and background is insufficient,
       the -t option may yield  unattractive  results  which  resemble  simple
       blurring of the original image.

       Because  Netpbm  used to have a maximum maxval of 255, which meant that
       the largest convolution kernel  pnmconvol  could  use  was  11  by  11,
       ppmshadow  includes  a horrid, CPU-time-burning kludge which, if a blur
       of greater than 11 is requested, performs an initial  convolution  with
       an  11×11 kernel, then calls pnmsmooth (which is actually a script that
       calls pnmconvol with a 3×3 kernel) as many times as the requested  blur
       exceeds  11.   It’s  ugly,  but  it  gets  the  job  done on those rare
       occasions where you need a blur greater than 11.

       If you wish to generate an image at high resolution, then scale  it  to
       publication  size  with  pnmscale in order to eliminate jagged edges by
       resampling, it’s best to generate  the  shadow  in  the  original  high
       resolution image, prior to scaling it down in size.  If you scale first
       and then add the shadow, you’ll get an unsightly jagged stripe  between
       the   edge  of  material  and  its  shadow,  due  to  resampled  pixels
       intermediate between the image and background obscuring the shadow.

EXIT STATUS

       ppmshadow returns status 0 if processing was completed without  errors,
       and  a  nonzero  Unix  error  code  if an error prevented generation of
       output.  Some  errors  may  result  in  the  script  aborting,  usually
       displaying  error  messages  from  various  Netpbm  components it uses,
       without returning a nonzero error code.  When this happens, the  output
       file  will be empty, so be sure to test this if you need to know if the
       program succeeded.

SEE ALSO

       pnm(5), pnmmargin(1), pnmconvol(1), pnmscale(1), pnmsmooth(1), ppm(5)

AUTHOR

       John Walker <http://www.fourmilab.ch> August 8, 1997

COPYRIGHT

       This software is in  the  public  domain.   Permission  to  use,  copy,
       modify,  and  distribute  this  software  and its documentation for any
       purpose and without fee is hereby granted, without  any  conditions  or
       restrictions.

                                 12 March 2000                    ppmshadow(1)