理想情况下,解决方案是在python和跨平台上,但这可能不太可能,所以我需要的是它在linux中工作,如果需要,我可以使用c扩展来连接w / python。我看到ffmpeg有一个python绑定,我正在考虑使用它,但我无法弄清楚如何确定配置文件和级别,使用fmmpeg或其他任何东西,更不用说它是实用的。谷歌也没有太大帮助。
如果我需要手动确定配置文件和级别然后我可以做到这一点,我已经能够确定我要查找的功能,但是这会导致问题,可以ffmpeg然后确定视频是否是用该功能集编码?我想我想知道的是,是否可能无法在编码后完全确定级别和特定的配置文件?我认为你必须知道才能解码它,但也许不是;这可以解释为什么我找不到任何相关信息。我一直在玩弄这种情况一段时间,但最近我决定考虑一个我一直在考虑的项目,但这是阻碍我的一件大事。
答案 0 :(得分:2)
基本上,您需要在比特流中识别SPS(序列参数集)并解码其几个前导字节。
请参阅H.264 stream header并在那里链接。
答案 1 :(得分:2)
这是我写的一个小程序。它打印使用h264作为视频编解码器的MP4文件的配置文件和级别。 您可以使用以下命令行编译它:
gcc -std=c99 printProfileAndLevel.c -o printProfileAndLevel
这是C源:
#include <stdio.h>
#include <stdlib.h>
void printProfile(int profile_idc, int profile_iop, int level_idc) {
switch(profile_idc) {
case 0x42: printf("Baseline Profile"); break;
case 0x4D: printf("Main Profile"); break;
case 0x58: printf("Extended Profile"); break;
case 0x64: printf("High Profile"); break;
default: printf("Unknown profile (%x)", profile_idc);
}
switch(level_idc) {
case 0x15: printf(" @ Level 2.1\n"); break;
case 0x1F: printf(" @ Level 3.1\n"); break;
case 0x29: printf(" @ Level 4.1\n"); break;
case 0x33: printf(" @ Level 5.1\n"); break;
default: printf(" @ unknown level (%x)", level_idc);
}
}
int main(int argc, char* argv[])
{
if(argc < 2) {
printf("syntax: %s <files>\n", argv[0]);
exit(-1);
}
int buffsize = 1024;
char *buffer = malloc(buffsize + 1);
for(int nArg = 1; nArg < argc; nArg++) {
printf("File %s:\n", argv[nArg]);
FILE *file = fopen(argv[nArg], "r+");
if(file == NULL) {
printf("Cannot open input file %s\n", argv[nArg]);
continue;
}
int nRead = 0;
nRead = fread(buffer, 1, buffsize, file);
for(int i = 0; i < nRead - 7; i++) {
if(buffer[i] == 0x61 && buffer[i+1] == 0x76 && buffer[i+2] == 0x63 && buffer[i+3] == 0x43) {
printProfile(buffer[i+5], buffer[i+6], buffer[i+7]);
}
}
fclose(file);
}
free(buffer);
return 0;
}