Add hg3 export support

This commit is contained in:
2025-06-29 16:48:38 +08:00
parent 0a6ac0afcb
commit 7d2522fdf7
13 changed files with 553 additions and 101 deletions

View File

@@ -85,3 +85,51 @@ impl<'a, T: Write> MsbBitWriter<'a, T> {
Ok(())
}
}
pub struct LsbBitStream<T: Read> {
pub m_input: T,
m_bits: u32,
pub m_cached_bits: u32,
}
impl<T: Read> LsbBitStream<T> {
pub fn new(input: T) -> Self {
LsbBitStream {
m_input: input,
m_bits: 0,
m_cached_bits: 0,
}
}
pub fn get_bits(&mut self, mut count: u32) -> Result<u32> {
if self.m_cached_bits >= count {
let mask = (1 << count) - 1;
let value = self.m_bits & mask;
self.m_bits >>= count;
self.m_cached_bits -= count;
Ok(value)
} else {
let mut value = self.m_bits & ((1 << self.m_cached_bits) - 1);
count -= self.m_cached_bits;
let mut shift = self.m_cached_bits;
self.m_cached_bits = 0;
while count >= 8 {
let b = self.m_input.read_u8()?;
value |= (b as u32) << shift;
shift += 8;
count -= 8;
}
if count > 0 {
let b = self.m_input.read_u8()?;
value |= ((b as u32) & ((1 << count) - 1)) << shift;
self.m_bits = b as u32 >> count;
self.m_cached_bits = 8 - count;
}
Ok(value)
}
}
pub fn get_next_bit(&mut self) -> Result<bool> {
Ok(self.get_bits(1)? == 1)
}
}

View File

@@ -160,3 +160,26 @@ pub fn decode_img(typ: ImageOutputType, filename: &str) -> Result<ImageData> {
}
}
}
pub fn flip_image(data: &mut ImageData) -> Result<()> {
if data.height <= 1 {
return Ok(());
}
let row_size = data.data.len() / data.height as usize;
if row_size == 0 {
return Ok(());
}
let mut i = 0;
let mut j = data.height as usize - 1;
while i < j {
let (top, bottom) = data.data.split_at_mut(j * row_size);
let top_row = &mut top[i * row_size..i * row_size + row_size];
let bottom_row = &mut bottom[0..row_size];
top_row.swap_with_slice(bottom_row);
i += 1;
j -= 1;
}
Ok(())
}