X-Git-Url: https://git.nihav.org/?p=nihav.git;a=blobdiff_plain;f=nihav-commonfmt%2Fsrc%2Fcodecs%2Fzmbv.rs;h=471f47e6b9922834d6d85481a0a445d24a994515;hp=b01e37536f8eb0bd068c81c6fa386ccc91309d17;hb=78556b82a67ce2a7a846358fdad8f625ce38401a;hpb=19336bafcd1ff2601795d158d9124bf5756d3edc diff --git a/nihav-commonfmt/src/codecs/zmbv.rs b/nihav-commonfmt/src/codecs/zmbv.rs index b01e375..471f47e 100644 --- a/nihav-commonfmt/src/codecs/zmbv.rs +++ b/nihav-commonfmt/src/codecs/zmbv.rs @@ -104,15 +104,15 @@ fn decode_inter(frm: &mut [u8], prev: &[u8], dpal: bool, pal: &mut [u8; 768], pp } } else { let mut doff = off; - let mut soff = (off as isize) + xoff + yoff * (stride as isize); + let mut soff = xoff * (pparms.bpp as isize) + yoff * (stride as isize); for j in 0..cur_h { let cy = yoff + (j as isize); - if cy >= 0 && (cy as usize) + cur_h <= pparms.height { + if cy >= 0 && (cy as usize) < pparms.height { for i in 0..cur_w { let cx = xoff + (i as isize); - if cx >= 0 && (cx as usize) + cur_w <= pparms.width { + if cx >= 0 && (cx as usize) < pparms.width { for k in 0..pparms.bpp { - frm[doff + i * pparms.bpp + k] = prev[(soff + ((i * pparms.bpp + k) as isize) + ((j * stride) as isize)) as usize] + frm[doff + i * pparms.bpp + k] = prev[(soff + ((i * pparms.bpp + k) as isize)) as usize] } } else { for k in 0..pparms.bpp { @@ -320,6 +320,7 @@ mod test { use nihav_codec_support::test::dec_video::*; use crate::generic_register_all_decoders; use crate::generic_register_all_demuxers; + // samples are from https://samples.mplayerhq.hu/V-codecs/ZMBV/ #[test] fn test_zmbv_8() { let mut dmx_reg = RegisteredDemuxers::new(); @@ -327,7 +328,7 @@ mod test { let mut dec_reg = RegisteredDecoders::new(); generic_register_all_decoders(&mut dec_reg); test_decoding("avi", "zmbv", "assets/Misc/td3_000.avi", Some(10), - &dmx_reg, &dec_reg, ExpectedTestResult::MD5([0x90f431d3, 0x66336a2b, 0x113fd806, 0x8d53da95])); + &dmx_reg, &dec_reg, ExpectedTestResult::MD5([0x83c57ac3, 0xda325d18, 0x806bd3be, 0x4b108732])); } #[test] fn test_zmbv_15() {