#bit-depth #image-processing #image #image-encoding #codec #color-space #byte

no-std zune-core

Core utilities for image processing in the zune family of crates

10 releases

0.5.0-rc0 Apr 7, 2024
0.4.12 Jan 15, 2024
0.4.11 Dec 2, 2023
0.4.1 Nov 17, 2023
0.2.1 Feb 25, 2023

#203 in Images

Download history 801/week @ 2023-12-23 1107/week @ 2023-12-30 1893/week @ 2024-01-06 1867/week @ 2024-01-13 1718/week @ 2024-01-20 1843/week @ 2024-01-27 2108/week @ 2024-02-03 3021/week @ 2024-02-10 4404/week @ 2024-02-17 5259/week @ 2024-02-24 5404/week @ 2024-03-02 16204/week @ 2024-03-09 50582/week @ 2024-03-16 68601/week @ 2024-03-23 73961/week @ 2024-03-30 46099/week @ 2024-04-06

242,715 downloads per month
Used in 67 crates (18 directly)

MIT OR Apache-2.0 OR Zlib

91KB
1.5K SLoC

Zune core

Core primitives necessary for image manipulations

This crate contains small set of primitives necessary for image manipulations which are shared among most zune- family of decoders and encoders.

Items present

Currently,it contains.

  • Colorspace definitions
  • Bit depth definitions.
  • Decoder and encoder options

lib.rs:

Core routines shared by all libraries

This crate provides a set of core routines shared by the decoders and encoders under zune umbrella

It currently contains

  • A bytestream reader and writer with endian aware reads and writes
  • Colorspace and bit depth information shared by images
  • Image decoder and encoder options
  • A simple enum type to hold image decoding results.

This library is #[no_std] with alloc feature needed for defining Vec which we need for storing decoded bytes.

Features

  • no_std: Enables #[no_std] compilation support.

  • serde: Enables serializing of some of the data structures present in the crate

Input/Output

zune-image supports many different input and output devices. For input readers we can read anything that implements BufRead + Seek and provide an optimized routine for handling in memory buffers by using ZCursor.

For output, we support anything that implements Write trait, this includes files, standard io streams network sockets, etc

In a no_std environment. We can write to in memory buffers &mut [u8] and &mut Vec<u8>

If you have an in memory buffer, use ZCursor, it's optimized for in memory buffers.

Dependencies

~200KB