decode-ico
Decode `.ico` icons
Last updated 7 years ago by linusu .
MIT · Repository · Bugs · Original npm · Tarball · package.json
$ npm install decode-ico 
SYNC missed versions from official npm registry.

Decode ICO

Decode .ico icons

Installation

npm install --save decode-ico

Usage

const decodeIco = require('decode-ico')
const fs = require('fs')

const source = fs.readFileSync('favicon.ico')
const images = decodeIco(source)

console.log(images[0])
//=> { width: 16, height: 16, type: 'bmp', data: Uint8Array(...), bpp: 32, hotspot: null }

console.log(images[1])
//=> { width: 32, height: 32, type: 'bmp', data: Uint8Array(...), bpp: 32, hotspot: null }

API

decodeIco(source: ArrayBuffer | Buffer) => Image[]

Decodes the .ico file in the given buffer, and returns an array of images.

Each image has the following properties:

  • width: Number - The width of the image, in pixels
  • height: Number - The height of the image, in pixels
  • type: String - The type of image, will be one of bmp or png
  • bpp: Number - The color depth of the image as the number of bits used per pixel
  • data: Uint8Array - The data of the image, format depends on type, see below
  • hotspot: null | Hotspot - If the image is a cursor (.cur), this is the hotspot

The format of the data parameter depends on the type of image. When the image is of type bmp, the data array will hold raw pixel data in the RGBA order, with integer values between 0 and 255 (included). When the type is png, the array will be png data.

The hotspot property will either be null, or an object with an x and y property.

💡 The png data can be written to a file with the .png extension directly, or be decoded by node-lodepng which will give you the same raw format as the bmp type.

Current Tags

  • 0.4.1                                ...           latest (2 years ago)

12 Versions

  • 0.4.1                                ...           2 years ago
  • 0.4.0                                ...           5 years ago
  • 0.3.1                                ...           6 years ago
  • 0.3.0                                ...           6 years ago
  • 0.2.1                                ...           7 years ago
  • 0.2.0                                ...           7 years ago
  • 0.1.6                                ...           7 years ago
  • 0.1.4                                ...           7 years ago
  • 0.1.3                                ...           7 years ago
  • 0.1.2                                ...           7 years ago
  • 0.1.1                                ...           7 years ago
  • 0.1.0                                ...           7 years ago
Maintainers (1)
Downloads
Total 1
Today 1
This Week 1
This Month 1
Last Day 0
Last Week 0
Last Month 0
Dependencies (0)
None
Dev Dependencies (4)
Dependents (1)

© 2010 - cnpmjs.org x YWFE | Home | YWFE