Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/mqudsi/pngnq
https://github.com/mqudsi/pngnq
Last synced: 6 days ago
JSON representation
- Host: GitHub
- URL: https://github.com/mqudsi/pngnq
- Owner: mqudsi
- License: other
- Created: 2013-11-09T02:03:06.000Z (about 11 years ago)
- Default Branch: master
- Last Pushed: 2013-11-09T02:19:57.000Z (about 11 years ago)
- Last Synced: 2024-04-14T06:43:52.194Z (7 months ago)
- Language: C
- Size: 367 KB
- Stars: 0
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README
- Changelog: ChangeLog
- License: COPYING
Awesome Lists containing this project
README
PNGNQ - PNG NEUQUANT
VERSION 1.1USAGE:
pngnq [-vfhV][-s sample factor][-e extension][-d dir][-n colours][-Q f|n][input files]
options:
-v Verbose mode. Prints status messages.
-f Force ovewriting of files.
-s Sample factor. The neuquant algorithm samples pixels stepping by this value.
-n Number of colours the quantized image is to contain. Range: 2 to 256. Defaults to 256.
-e Specifies the new filename extension. Defaults to -nq8.png.
Will drop .png from original filenames.
-d Relocates the quantized files into this directory.
Otherwise output files stay in the same directory as the input files.
input files: The png files to be processed. Defaults to standard input if not specified.
-Q Dithering method: f = Floyd Steinberg, n = None (default)
-V Print version number and library versions.
-h Print this help.Quantizes a 32-bit RGBA PNG image to an 8 bit RGBA palette PNG
using the neuquant algorithm. The output file name is the input file name
extended with "-nq8.png" or a specified extension.NOTES:
Pngnq is a tool for quantizing PNG images in RGBA format.
Pngnq is an adaptation by Stuart Coyle of Greg Roelf's pnqquant program
using Anthony Dekker's neuquant algorithm.Pngnq exists because I needed a lot of png images in RGBA format
to be quantized. After some searching, the only tool I could find
that worked was pngquant. I tried pngquant but found that the median
cut algorithm that it uses, with or without dithering, gave inferior
looking results to the neuquant algorithm. You can see the difference
demonstrated on the neuquant web page:
http://members.ozemail.com.au/~dekker/NEUQUANT.HTML.The program was written to fulfill the specific needs of the small
project I was working on, and as such does not have all the
functionality one could want.I use Greg Roelf's png reading and writing code unchanged for the most part.
The pngnq source code includes neuquant32, which is an extension of Anthony Dekker's
neuquant, to make it handle 4 channels of pixel data.Major rewrite by Kornel Lesiński, adding double precision, dithering, better handling of alpha
transparency and more. Thanks!This program has been tested on:
Linux 32 and 64 bit
Mac OSX - intel processor.
OpenBSD 32 bit
Win32REQUIREMENTS:
Pngnq depends on the libpng and libz libraries.
You will need libpng >=1.2.8 installed.
If you have this then you will have libz.
On windows you will require the libpng13.dll
which can be downloaded from several sites.BUGS:
Some problems with greyscale alpha images at low bit depths.
TODO list:I want to change the error measure to use CIE u' v' color
space and see if results are visually better.Limited image input formats. I am not doing much checking on
the image pixel depth etc.Do a detailed comparison with other quantization algortithms.
- the pngcomp tool is in development to do this.Copyright (c) Stuart Coyle 2004-2009 [email protected]
See LICENCE for details of copyrights held on this program.