This is a work in progress library to create, process, read and write different image formats with Zig programming language.
This project assume current Zig master (0.12.0-dev.799+d68f39b54 or higher) with stage2 self-hosted compiler.
How to add to your project:
- Clone this repository or add as a submodule
- Add to your
build.zig
exe.addAnonymousModule("zigimg", .{.source_file = .{ .path = "zigimg.zig" }});
- Example build.zig.zon file
.{
.name = "app",
.version = "0.0.0",
.dependencies = .{
.zigimg = .{
.url = "https://github.com/zigimg/zigimg/archive/$REPLACE_WITH_WANTED_COMMIT$.tar.gz",
},
},
}
- When it fails to build due to a mismatched hash, add the
hashline to the dependency
.zigimg = .{
.url = "https://github.com/zigimg/zigimg/archive/$REPLACE_WITH_WANTED_COMMIT$.tar.gz",
.hash = "$REPLACE_WITH_HASH_FROM_BUILD_ERROR$",
},
To run the test suite, checkout the test suite and run
- Checkout zigimg
- Go back one folder and checkout the test suite
- Run the tests with
zig build
zig build test
| Image Format | Read | Write |
|---|---|---|
| ANIM | ❌ | ❌ |
| BMP | ✔️ (Partial) | ✔️ (Partial) |
| GIF | ✔️ | ❌ |
| ICO | ❌ | ❌ |
| IILBM | ❌ | ❌ |
| JPEG | ❌ | ❌ |
| PAM | ✔️ | ✔️ |
| PBM | ✔️ | ✔️ |
| PCX | ✔️ | ✔️ |
| PGM | ✔️ (Partial) | ✔️ (Partial) |
| PNG | ✔️ | ✔️ (Partial) |
| PPM | ✔️ (Partial) | ✔️ (Partial) |
| QOI | ✔️ | ✔️ |
| TGA | ✔️ | ✔️ |
| TIFF | ❌ | ❌ |
| XBM | ❌ | ❌ |
| XPM | ❌ | ❌ |
- version 4 BMP
- version 5 BMP
- 24-bit RGB read & write
- 32-bit RGBA read & write
- Doesn't support any compression
- Support GIF87a and GIF89a
- Support animated GIF with Netscape application extension for looping information
- Supported interlaced
- Supports tiled and layered images used to achieve pseudo true color and more.
- The plain text extension is not supported
Currently, this only supports a subset of PAMs where:
- The tuple type is official (see
man 5 pam) or easily inferred (and by extension, depth is 4 or less) - All the images in a sequence have the same dimensions and maxval (it is technically possible to support animations with different maxvals and tuple types as each
AnimationFramehas its ownPixelStorage, however, this is likely not expected by users of the library) - Grayscale,
- Grayscale with alpha
- Rgb555
- Rgb24 and Rgba32
- Bgr24 and Bgra32
- Rgb48 and Rgba64
- Everything is supported
- Support monochrome, 4 color, 16 color and 256 color indexed images
- Support 24-bit RGB images
- Support 8-bit and 16-bit grayscale images
- 16-bit ascii grayscale loading not tested
- Support all pixel formats supported by PNG (grayscale, grayscale+alpha, indexed, truecolor, truecolor with alpha) in 8-bit or 16-bit.
- Support the mininal chunks in order to decode the image.
- Not all images in Png Test Suite is covered but should be good enough for now.
- Support 24-bit RGB (8-bit per channel)
- Missing 48-bit RGB (16-bit per channel)
- Imported from https://github.com/MasterQ32/zig-qoi with blessing of the author
- Supports uncompressed and compressed 8-bit grayscale, indexed with 16-bit and 24-bit colormap, truecolor with 16-bit(RGB555), 24-bit or 32-bit bit depth.
- Supports reading version 1 and version 2
- Supports writing version 2
