#[repr(u8)]pub enum Dither {
Auto = 0,
None = 1,
Atkinson = 2,
FS = 3,
JaJuNi = 4,
Stucki = 5,
Burkes = 6,
ADither = 7,
XDither = 8,
}
alloc
and crate feature term
and (crate features io
or std
) and (crate features dep_hashbrown
or std
) and crate feature image
only.Expand description
Dithering methods of error diffusion.
Dithering helps improve image quality when reducing color depth, commonly used in Sixel, GIF, and other indexed-color formats.
Variants§
Auto = 0
Choose diffusion type automatically. (Default)
None = 1
No dithering is applied. Pixels are directly quantized without modification.
Atkinson = 2
Error diffusion dithering using Bill Atkinson’s method.
Produces a softer dithering effect with a limited error spread. Often used in early Macintosh graphics.
FS = 3
Floyd-Steinberg error diffusion dithering.
A widely used method that spreads error to neighboring pixels for smooth gradients. Produces good results with minimal artifacts.
JaJuNi = 4
Jarvis, Judice & Ninke (JaJuNi) error diffusion dithering.
Spreads quantization error further across neighboring pixels, resulting in smoother transitions but requiring more computation.
Stucki = 5
Stucki error diffusion dithering.
Similar to JaJuNi but slightly optimized for faster computation. Produces high-quality results with minimal artifacts.
Burkes = 6
Burkes error diffusion dithering.
A simplified version of Stucki with a smaller diffusion matrix, reducing computation while maintaining good quality.
ADither = 7
Positionally stable arithmetic dithering.
Applies a deterministic arithmetic transformation to each pixel, ensuring consistency without propagating errors.
XDither = 8
Positionally stable XOR-based dithering.
Uses bitwise XOR operations for structured noise generation, creating a high-frequency dithering pattern without error diffusion.
Implementations§
Source§impl Dither
impl Dither
Sourcepub fn apply_15bpp(
self,
pixels: &mut [u8],
x: i32,
y: i32,
width: i32,
height: i32,
)
pub fn apply_15bpp( self, pixels: &mut [u8], x: i32, y: i32, width: i32, height: i32, )
Applies dithering to a pixel array in 15-bit color mode (5-5-5 RGB).
This method modifies pixel values based on the selected dithering algorithm. It is designed for 15bpp color depth, commonly used in retro graphics and hardware-limited displays.
§Behavior
- Error diffusion dithering (e.g., Floyd-Steinberg, Atkinson) is only applied when there is enough space for propagation.
- Positionally stable dithering (e.g.,
ADither
,XDither
) is applied unconditionally per pixel. None
disables dithering, andAuto
currently behaves the same.
Trait Implementations§
Source§impl ConstDefault for Dither
impl ConstDefault for Dither
impl Copy for Dither
impl Eq for Dither
impl StructuralPartialEq for Dither
Auto Trait Implementations§
impl Freeze for Dither
impl RefUnwindSafe for Dither
impl Send for Dither
impl Sync for Dither
impl Unpin for Dither
impl UnwindSafe for Dither
Blanket Implementations§
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Source§impl<T> ByteSized for T
impl<T> ByteSized for T
Source§const BYTE_ALIGN: usize = _
const BYTE_ALIGN: usize = _
Source§fn byte_align(&self) -> usize
fn byte_align(&self) -> usize
Source§fn ptr_size_ratio(&self) -> [usize; 2]
fn ptr_size_ratio(&self) -> [usize; 2]
Source§impl<T, R> Chain<R> for Twhere
T: ?Sized,
impl<T, R> Chain<R> for Twhere
T: ?Sized,
Source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
§fn equivalent(&self, key: &K) -> bool
fn equivalent(&self, key: &K) -> bool
key
and return true
if they are equal.Source§impl<T> ExtAny for T
impl<T> ExtAny for T
Source§fn type_hash_with<H: Hasher>(&self, hasher: H) -> u64
fn type_hash_with<H: Hasher>(&self, hasher: H) -> u64
TypeId
of Self
using a custom hasher.Source§fn as_any_mut(&mut self) -> &mut dyn Anywhere
Self: Sized,
fn as_any_mut(&mut self) -> &mut dyn Anywhere
Self: Sized,
Source§impl<T> ExtMem for Twhere
T: ?Sized,
impl<T> ExtMem for Twhere
T: ?Sized,
Source§const NEEDS_DROP: bool = _
const NEEDS_DROP: bool = _
Source§fn mem_align_of<T>() -> usize
fn mem_align_of<T>() -> usize
Source§fn mem_align_of_val(&self) -> usize
fn mem_align_of_val(&self) -> usize
Source§fn mem_size_of<T>() -> usize
fn mem_size_of<T>() -> usize
Source§fn mem_size_of_val(&self) -> usize
fn mem_size_of_val(&self) -> usize
Source§fn mem_needs_drop(&self) -> bool
fn mem_needs_drop(&self) -> bool
true
if dropping values of this type matters. Read moreSource§fn mem_forget(self)where
Self: Sized,
fn mem_forget(self)where
Self: Sized,
self
without running its destructor. Read moreSource§fn mem_replace(&mut self, other: Self) -> Selfwhere
Self: Sized,
fn mem_replace(&mut self, other: Self) -> Selfwhere
Self: Sized,
Source§unsafe fn mem_zeroed<T>() -> T
unsafe fn mem_zeroed<T>() -> T
unsafe_layout
only.T
represented by the all-zero byte-pattern. Read moreSource§unsafe fn mem_transmute_copy<Src, Dst>(src: &Src) -> Dst
unsafe fn mem_transmute_copy<Src, Dst>(src: &Src) -> Dst
unsafe_layout
only.T
represented by the all-zero byte-pattern. Read moreSource§fn mem_as_bytes(&self) -> &[u8] ⓘ
fn mem_as_bytes(&self) -> &[u8] ⓘ
unsafe_slice
only.§impl<S> FromSample<S> for S
impl<S> FromSample<S> for S
fn from_sample_(s: S) -> S
Source§impl<T> Hook for T
impl<T> Hook for T
§impl<T> Instrument for T
impl<T> Instrument for T
§fn instrument(self, span: Span) -> Instrumented<Self> ⓘ
fn instrument(self, span: Span) -> Instrumented<Self> ⓘ
§fn in_current_span(self) -> Instrumented<Self> ⓘ
fn in_current_span(self) -> Instrumented<Self> ⓘ
Source§impl<T> IntoEither for T
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self> ⓘ
fn into_either(self, into_left: bool) -> Either<Self, Self> ⓘ
self
into a Left
variant of Either<Self, Self>
if into_left
is true
.
Converts self
into a Right
variant of Either<Self, Self>
otherwise. Read moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self> ⓘ
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self> ⓘ
self
into a Left
variant of Either<Self, Self>
if into_left(&self)
returns true
.
Converts self
into a Right
variant of Either<Self, Self>
otherwise. Read more