1
0
mirror of https://github.com/kettek/png-js synced 2025-10-23 17:58:45 -07:00
Mirror of kettek/png-js
Go to file
dependabot[bot] cd8a448e38
Bump minimist from 1.2.5 to 1.2.6
Bumps [minimist](https://github.com/substack/minimist) from 1.2.5 to 1.2.6.
- [Release notes](https://github.com/substack/minimist/releases)
- [Commits](https://github.com/substack/minimist/compare/1.2.5...1.2.6)

---
updated-dependencies:
- dependency-name: minimist
  dependency-type: indirect
...

Signed-off-by: dependabot[bot] <support@github.com>
2022-03-26 10:52:25 +00:00
dist Build for v1.0.0 2020-01-14 19:46:10 -08:00
src Allow extraction of pixel buffer via toPNGData() 2019-01-23 18:47:00 -08:00
LICENSE Update LICENSE 2019-01-23 18:35:30 -08:00
package-lock.json Bump minimist from 1.2.5 to 1.2.6 2022-03-26 10:52:25 +00:00
package.json Version bump 2020-05-12 21:26:45 -07:00
README.md Allow extraction of pixel buffer via toPNGData() 2019-01-23 18:47:00 -08:00
rollup.config.js Commit of png-js fork 2019-01-15 00:58:38 -08:00

png-js

This is a modified version of png.js that is intended to be used for palette swapping within the browser.

NOTE: Only supports indexed PNGs for obvious reasons. All others will cause IndexedPNG to throw during construction.

Usage

The following shows the process of loading a PNG file and rendering it to a canvas with its palette data reversed.

import { IndexedPNG }   from '@kettek/png-js/src'
import { readFile   }   from 'fs'

readFile("my_png.png", (err, data) => {
    if (err) throw err
    
    // Create an IndexedPNG object from our data.
    let png = new IndexedPNG(data)
    
    // Preemptively decode PNG data (optional).
    png.decode()
    
    // Convert our PNG data into an ImageData, usable by a Canvas. Passed options provide a reversed palette and a clipping.
    png.toImageData({
      palette: png.decodePalette().reverse(),
      clip: {
        x: 16,
        y: 16,
        w: 32,
        h: 32
      }
    })
    .then(imageData => {
      // This presumes at least one canvas element exists on the page.
      document.getElementsByTagName('canvas')[0]
      .getContext('2d')
      .putImageData(imageData, 0, 0)
    })
    .catch(err => {
        throw err
    })
})

Types

IndexedPNG

IndexedPNG(Buffer)
processes PNG data but does not decode it.
async decodePixels()
Decodes the PNG pixel data and returns it.
decodePalette()
Decodes the PNG palette and returns it as a Palette.
async decode()
Decodes the palette and the pixel data of the PNG data passed into the constructor. Calls decodePixels() and decodePalette().
ImageData async toImageData(ImageDataOptions)
Returns ImageData. Calls toPNGData(options).
PNGData async toPNGData(ImageDataOptions)
Returns PNGData. Calls decode() automatically if PNG has not been decoded.

ImageDataOptions

Object containing options to apply during toImageData().

Property Type Description
palette Palette Palette data to use for decoding.
clip Clip Clipping options to use for decoding.

Palette

A Buffer or Array containing the palette RGBA palette data.

let palette = [
    255, 0  ,  0  , 255, // Index 0
    0  , 255,  0  , 255, // Index 1
    0  , 0  ,  255, 255, // Index 2
    ...
]

Clip

Options to clip pixel data.

Property Type Defaults Description
x Number 0 Starting X coordinate.
y Number 0 Starting Y coordinate.
w Number width - x Width of clip.
h Number height - y Height of clip.
let clip = {
    x: 16,
    y: 16,
    w: 32,
    h: 32,
}

PNGData

Object containing the pixel data and row width.

Property Type
pixels Uint8ClampedArray
width Number