Low-level implementation of PNG file parser/reader/decoder using JavaScript on client size.
Why this when browsers support PNG already?
The browser will simply load and convert any PNG type into RGBA bitmaps. It may also apply ICC and gamma correction to the image resulting in different pixel values than in the original bitmap.
pngtoy is for special case scenarios where you need to work with the original bitmap as-is (ie. no gamma, no ICC, indexed, 16-bit etc.) and you need the original pixel values and format. This will also keep the bitmap values consistent across browsers as some browser support ICC, gamma, others doesn't.
pngtoy can also be used to analyse PNG files, extract special information such as header, chunks, texts and so forth, or to reduce file size, as a tool to attempt repairs to a file, add or remove chunks, and so forth.
pngtoy will allow you to work directly with, for example 16-bit greyscale bitmap buffers as well as other formats such as bit-planes (you can still convert the bitmap to RGBA bitmap or canvas).
pngtoy attempts to read all formats specified by the W3C standard (* not all are available in this alpha version).
pngtoy can also be used to clean up PNG files by stripping unnecessary chunks and rebuild a file you can save as new.
pngtoy let you just parse the chunks without decompressing and decoding any data.
(pngtoy can be used to repair and optimize PNG files.)
pngtoy do currently not encode PNG files, but works only with existing PNG files and content (chunks can be constructed manually and added - * build tools not available in alpha).
- Supports 8-bit, 16-bit, indexed, bit-planes, greyscale, rgb, rgba, transparency (and interlaced*).
- Strict parsing conforming to the standard (can be turned off for error correction purposes)
- CRC-checking for each chunk (can be turned off for error correction purposes)
- Using typed arrays for best performance
- Fast gzip implementation (pako)
- Non UI-blocking asynchronous block based decoding and format converting
- Access to chunks without the need to decompress or decode bitmaps
- Access to raw unfiltered buffer
- Get decoded (filtered) buffer
- Get converted buffer (8-bit RGBA)
- Apply gamma to converted bitmap (file, display and optional user gamma)
- Handles aspect ratio correctly (pHYs chunk) (can be disabled)
- Ability to reconstruct file based on chunks incl. stripping of unneeded chunks NOT IMPL.
- Supports compressed ancillary chunks and fields
- Supports extended chunks such as oFFs, sCAL, pCAL, sTER
- Uses promises (use Promise polyfill for IE)
- Support for Canvas64 (TBA) NOT IMPL.
- Can be used in attempt to rescue corrupted PNG files
Run the PNG test suit from the tests directory to see current status/rendering (must run from localhost in some browsers due to CORS restrictions).
pngtoy can be installed in various ways:
- Bower
bower install pngtoy
- Git using HTTPS:
git clone https://github.com/epistemex/pngtoy.git
- Git using SSH:
git clone git@github.com:epistemex/pngtoy.git
- Download zip archive and extract.
- pngtoy.min.js
Create a new and reusable instance of pngtoy parser:
var pngtoy = new PngToy([options]);
Invoke asynchronous fetching of file using a promise:
pngtoy.fetch("http://url.to/png.file").then( ... );
Now you can extract the information you like from the current PNG file:
// get and parse chunks
var chunks = pngtoy.getChunks(); // chunk list - does not decode any data
// parse individual chunks to object (all official chunks are supported)
var ihdr = pngtoy.get_IHDR(); // return object for parsed IHDR chunk
var raw = pngtoy.get_IDAT(); // get unfiltered but uncompressed bitmap data
var palette = pngtoy.get_PLTE(); // get parsed palette if exists, or null
var texts = pngtoy.get_zTXt(); // get array with parsed and uncompressed zTXt objects
var stereo = pngtoy.get_sTER(); // get stereo mode if stereo image
...
// decode
pngtoy.decode(options).then( ...) ; // get decoded bitmap in original depth and type
pngtoy.bitmapToCanvas(bmp, options).then(...) // convert to canvas and apply optional gamma
See also the PngImage
object.
NOTE: ALPHA version - API may change, see tests for current examples.
- Interlace (Adam7) mode does not currently work (do not use interlaced images)
- The pako inflate decompression code was written by Andrey Tupitsin (@anrd83) and Vitaly Puzrin (@puzrin)
- The Promise polyfill (optional) by @taylorhakes
Released under MIT license. You may use this class in both commercial and non-commercial projects provided that full header (minified and developer versions) is included.
© 2015 Epistmex