Merge pull request #17 from jangko/devel

update readme.md
This commit is contained in:
andri lim 2017-11-24 11:41:29 +07:00 committed by GitHub
commit 0117f1ea91
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

View File

@ -1,5 +1,6 @@
# nimPNG # nimPNG (PNG + APNG)
Portable Network Graphics Encoder and Decoder written in Nim store lossless image with good compression Portable Network Graphics Encoder and Decoder written in Nim store lossless image with good compression.
Since version 0.2.0 also support Animated PNG!
[![Build Status][badge-nimpng-travisci]][nimpng-travisci] [![Build Status][badge-nimpng-travisci]][nimpng-travisci]
@ -96,21 +97,32 @@ pixels are stored as raw bytes using Nim's string as container:
Since version 0.2.0, nimPNG provides support for [Animated PNG](https://wiki.mozilla.org/APNG_Specification). Since version 0.2.0, nimPNG provides support for [Animated PNG](https://wiki.mozilla.org/APNG_Specification).
Both decoder and encoder recognize/generate APNG chunks correctly: acTL, fcTL, fdAT.
Decoded frames is provided as is, the dimension and coordinate offset might be different with default frame.
No alpha blending or other blending method performed.
It is up to the application to do proper in-memory rendering before displaying the animation.
Don't ask how to do it, any decent graphics rendering library have their own set of API to do alpha blending and
offset rendering. In the future nimPNG might be shipped with simple frame rendering utility for common cases.
Right now nimPNG is just a PNG encoder/decoder.
### Decoding ### Decoding
```Nim ```Nim
#let png = loadPNG32("image.png")
# or
#let png = loadPNG("image.png", LCT_RGBA, 8) #let png = loadPNG("image.png", LCT_RGBA, 8)
# or # or
#let png = decodePNG32(raw_bytes) #let png = decodePNG32(raw_bytes)
``` ```
The usual loadPNG and decodePNG can decode both unanimated and animated PNG. The usual loadPNG and decodePNG can decode both unanimated and animated PNG.
png.width, png.height, png.data works as usual. If the decoded PNG is an APNG, png.data will contains default frame. `png.width`, `png.height`, `png.data` works as usual. If the decoded PNG is an APNG, `png.data` will contains default frame.
Animation frames can be accessible via png.frames. If it is not an APNG, png.frames will be nil. Animation frames can be accessible via `png.frames`. If it is not an APNG, `png.frames` will be nil.
### Encoding ### Encoding
Under construction
[nimpng-travisci]: https://travis-ci.org/jangko/nimPNG [nimpng-travisci]: https://travis-ci.org/jangko/nimPNG
[badge-nimpng-travisci]: https://travis-ci.org/jangko/nimPNG.svg?branch=master [badge-nimpng-travisci]: https://travis-ci.org/jangko/nimPNG.svg?branch=master