ImageGear v26.5 - Updated
Developer Guide / File Formats and Compressions / File Formats / File Formats Reference / PNG
In This Topic
    PNG
    In This Topic
    Full Name PNG (Portable Network Graphics)
    Format ID ImGearFormats.PNG
    File Extension(s) *.png
    Data Type Raster Image
    Data Encoding Binary
    Multi-Page Support No
    Alpha Channel Support Supports single alpha channel for read/write.
    Metadata Update Support Page

    ImageGear Supported Versions

    • 10th draft (future drafts will be backward-compatible)
    • PNG v2

    ImageGear Supported Features

    • IGFilterFormatFlags.DETECTSUPPORT - autodetection
    • IGFilterFormatFlags.PAGEREADSUPPORT - single page file reading
    • IGFilterFormatFlags.PAGEINSERTSUPPORT - single-page file writing

    ImageGear Read Support

    • ImGearCompressions.DEFLATE:
      • Indexed RGB: 1, 2, 4, 8 bpp;
      • Grayscale: 1, 2, 4, 8, 16 bpp;
      • Grayscale + Alpha: 8, 16 bpp;
      • RGB: 24, 48 bpp;
      • RGB + Alpha: 32, 64 bpp

    ImageGear Write Support

    • ImGearCompressions.DEFLATE:
      • Indexed RGB: 4, 8 bpp;
      • Grayscale: 1, 4, 8, 16 bpp;
      • Grayscale + Alpha: 16, 32 bpp;
      • RGB: 24, 48 bpp;
      • RGB + Alpha: 32, 64 bpp

    ImageGear Filter Control Parameters

    ImageGear Filter Control Parameters

    Filter Control Parameter Type Default Value Available Values Description
    StripConfig int 0 (fixed count)

    0 (fixed count),

    1 (fixed buffer)

    Format of PNG strip, see ImGearPNGStrip constants.
    BufferSize int 0 Any int value Size of the buffer for strip if StripConfig is 1 ( fixed buffer).
    StripCount int 0 Any int value Number of lines in one strip if StripConfig is 0 ( fixed count).
    CompLevel int 6 (default compression) Any integer in range 0..9 Compression level. It must be between 0 (No compression) and 9 (max compression). Better compression takes more time for compression. See ImGearPNGCompLevel.
    KeepAlpha bool true true, false

    When loading: if this parameter is true, then alpha channel is loaded into Alpha DIB. Otherwise, the image is transformed into RGB, by compositing over the background supplied in the bKGD chunk, if it is present, or over the default background.

    When saving: if this parameter is true, and alpha DIB is present, it will be written to the file.

    Comments

    The PNG (pronounced "Ping") format was created out of reaction to Unisys's announcement that it would begin requiring royalty fees for use of its LZW compression scheme. This was the compression scheme for the widely-used GIF format (found in Web pages and online library images).

    Thomas Boutell and a host of other programmers began working to devise a new file format to eliminate the need for payment of royalty fees. The result was a file format that offers better compression than GIF, and adds features GIF doesn't offer, including truecolor, and full alpha channel and gamma correction.

    The basic organization of the PNG file format utilizes storage structures known as "chunks". A chunk is a block of data that contains its own header (identifying the chunk size and type). This makes it easy for a PNG viewer to identify chunks and to skip over the ones that are not necessary.

    The first entry in a PNG file is the "PNG signature" that identifies the format as PNG. The file then proceeds with a series of chunks.

    The IHDR Image Header, or IHDR Chunk, contains a number of fields including the height, width, depth, color type, and compression type of the image. The only valid compression value is 0, which indicates the PNG's custom compression scheme, a deflate/inflate compression with a 32k sliding window. This is a derivative of ZZ77, the precursor to LZW. ZZ77 is the compression scheme used by pkzip software.

    The "PLTE Palette Chunk" contains 1 to 256 palette entries. This is present if the type field of the header chunk is set to 3. The number of colors cannot exceed the range provided by the bit depth.

    The image data is stored in "IDAT Image Data Chunks". These are subdivided into chunks whose size is usually determined by the size of the encoder's buffer. The data may be stored in "interlaced order" allowing the image to be "faded in". The data may also be interlaced. Interlacing helps the appearance of an image as it displays while being decompressed, so that it "fades in". In a non-interlaced file, the presentation of the image data begins with row 1 and works downward to the last row of data. This method of display does not allow a quick preview of the whole image. When the data is interlaced, the lines are saved and displayed out of sequence. Every fourth row is displayed first and then filled in with every remaining fourth row, until all of the lines are displayed. This allows the eye to perceive the basic subject of the whole image before it is completely displayed.

    "Ancillary Chunks" are optional. They must appear before the first IDAT and after the PLTE. One chunk is the "bKGD chunk" that sets the default background color for the image. Two of the other ancillary chunks are the "hHist Chunk" or histogram chunk, and the "tEXt" chunk. The histogram chunk appears if there is a palette. It stores the frequency of each color of the palette as it occurs in the image data. If the application doesn't support all of the colors in the palette, the histogram can be used to choose a subset of colors. There may be any number of text chunks. They can vary in length from 0 to the maximum chunk size. They include the image author, copyright information, and any desired comments.

    Questions about PNG can be e-mailed to: png-info@uunet.uu.net

    References Used

    Murray, James D. "Graphic Image Format FAQ 3-4". James D. Murray, 1994-1996.

    PNG (Portable Network Graphics), tenth draft. Page 5, copyright Thomas Boutell, May 1995.

    Wegner, Tim. "Coding for PNG Graphics", "PC Techniques", Feb/Mar 1996, pp 32-38.