mirror of
https://github.com/lifegpc/msg-tool.git
synced 2026-06-08 22:08:47 +08:00
Add hg3 export support
This commit is contained in:
@@ -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)
|
||||
}
|
||||
}
|
||||
|
||||
@@ -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(())
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user