summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorKostya Shishkov <kostya.shishkov@gmail.com>2020-01-25 18:24:37 +0100
committerKostya Shishkov <kostya.shishkov@gmail.com>2020-01-25 18:24:37 +0100
commitab5baaf1d26574e979aa248dd31b1d912c01fe84 (patch)
tree011ce930daced34dcff72b173e5d0cbbe91a68bb
parentb8f7343a54df054ed8a0f1d81500af81a404ea3b (diff)
vp5: fix motion compensation part
-rw-r--r--nihav-duck/src/codecs/vp5.rs11
1 files changed, 8 insertions, 3 deletions
diff --git a/nihav-duck/src/codecs/vp5.rs b/nihav-duck/src/codecs/vp5.rs
index 0c901be..1cd6531 100644
--- a/nihav-duck/src/codecs/vp5.rs
+++ b/nihav-duck/src/codecs/vp5.rs
@@ -219,11 +219,16 @@ impl VP56Parser for VP5BR {
}
fn mc_block(&self, dst: &mut NASimpleVideoFrame<u8>, mc_buf: NAVideoBufferRef<u8>, src: NAVideoBufferRef<u8>, plane: usize, x: usize, y: usize, mv: MV, loop_str: i16) {
let (sx, sy, mx, my) = if (plane != 1) && (plane != 2) {
- (mv.x / 2, mv.y / 2, mv.x & 1, mv.y & 1)
+ (mv.x >> 1, mv.y >> 1, mv.x & 1, mv.y & 1)
} else {
- (mv.x / 4, mv.y / 4, (mv.x >> 1) & 1, (mv.y >> 1) & 1)
+ (mv.x >> 2, mv.y >> 2, (mv.x / 2) & 1, (mv.y / 2) & 1)
+ };
+ let mode1 = (mx as usize) + (my as usize) * 2;
+ let mode = if (mode1 == 3) && (mv.x ^ mv.y < 0) {
+ 4
+ } else {
+ mode1
};
- let mode = (mx as usize) + (my as usize) * 2;
vp_copy_block(dst, src, plane, x, y, sx, sy, 0, 1, loop_str,
mode, VP3_INTERP_FUNCS, mc_buf);
}