我正在从 ffmpeg 中提取运动矢量以用于计算机视觉项目。我一直在寻找一种简单的方法来以有意义的方式提取这些信息。
在阅读不同的帖子和其他网站时,我在 FFmpeg 的示例文件夹中发现了 extract_mvs.c。我注意到在这个文件生成的数据中(在编译之后)有一个我想修改的标志列,使它打印帧类型而不是 0x0s,如下所示。
我从代码的作者那里得到了修改标志的想法。
编译后的 extract_mvs.c 文件,返回如下信息:
framenum,source,blockw,blockh,srcx,srcy,dstx,dsty,flags
2,-1,16,16, 8, 8, 8, 8,0x0
2, 1,16,16, 8, 8, 8, 8,0x0
2, 1,16,16, 24, 8, 24, 8,0x0
2, 1,16,16, 40, 8, 40, 8,0x0
2, 1,16,16, 56, 8, 56, 8,0x0
2, 1,16,16, 72, 8, 72, 8,0x0
2, 1,16,16, 88, 8, 88, 8,0x0
...
297, 1,16,16, 248, 280, 248, 280,0x0
297, 1,16,16, 264, 280, 264, 280,0x0
297,-1,16,16, 278, 279, 280, 280,0x0
297, 1,16,16, 280, 280, 280, 280,0x0
297, 1,16,16, 296, 280, 296, 280,0x0
297, 1,16,16, 312, 280, 312, 280,0x0
297, 1,16,16, 328, 280, 328, 280,0x0
297, 1,16,16, 344, 280, 344, 280,0x0
理想情况下,我想要实现的是:
framenum,source,blockw,blockh,srcx,srcy,dstx,dsty,frametypes
2,-1,16,16, 8, 8, 8, 8,B
2, 1,16,16, 8, 8, 8, 8,B
2, 1,16,16, 24, 8, 24, 8,B
2, 1,16,16, 40, 8, 40, 8,B
2, 1,16,16, 56, 8, 56, 8,B
2, 1,16,16, 72, 8, 72, 8,B
2, 1,16,16, 88, 8, 88, 8,B
...
297, 1,16,16, 248, 280, 248, 280,P
297, 1,16,16, 264, 280, 264, 280,P
297,-1,16,16, 278, 279, 280, 280,P
297, 1,16,16, 280, 280, 280, 280,P
297, 1,16,16, 296, 280, 296, 280,P
297, 1,16,16, 312, 280, 312, 280,P
297, 1,16,16, 328, 280, 328, 280,P
297, 1,16,16, 344, 280, 344, 280,P
文件中需要修改的部分显示在这里,其中mv->flags需要替换为帧类型变量。我想用指针引用 AVFrame 结构并调用 pict-type。但不确定构建模块将如何。有什么帮助吗?