ffmpeg H264 avi文件获取帧时间戳? UINT64_C错误

时间:2012-07-29 14:10:59

标签: compiler-errors ffmpeg timestamp uint64

带有h264编解码器的

avi文件。我需要打开它并提取每个帧的时间戳。

我尝试在opencv中执行此操作,但它返回错误的结果。

我修改了fffmpeg / doc / examples文件夹中存在的示例filtering_video.c的代码,以获取时间戳。

我有以下代码,但编译它给了我一个关于UNIT64_C的奇怪结果。 在我周围搜索,我发现这是一个问题。

所以2个问题: 1.此代码是否能够返回并打印帧时间戳 2.任何解决UINT64_C问题的方法??

使用ubuntu 11.04和最新的ffmpeg。

代码

#include <unistd.h>

#include <libavcodec/avcodec.h>
#include <libavformat/avformat.h>

static AVFormatContext *fmt_ctx;
static AVCodecContext *dec_ctx;
static int video_stream_index = -1;

static int open_input_file(const char *filename)
{
int ret;
AVCodec *dec;

if ((ret = avformat_open_input(&fmt_ctx, filename, NULL, NULL)) < 0)
{
    printf("Cannot open input file\n");
    return ret;
}

if ((ret = avformat_find_stream_info(fmt_ctx, NULL)) < 0)
{
    printf("Cannot find stream information\n");
    return ret;
}

/* select the video stream */
ret = av_find_best_stream(fmt_ctx, AVMEDIA_TYPE_VIDEO, -1, -1, &dec, 0);
if (ret < 0)
{
    printf("Cannot find a video stream in the input file\n");
    return ret;
}
video_stream_index = ret;
dec_ctx = fmt_ctx->streams[video_stream_index]->codec;

/* init the video decoder */
if ((ret = avcodec_open2(dec_ctx, dec, NULL)) < 0)
{
    printf("Cannot open video decoder\n");
    return ret;
}

return 0;
}

int main(int argc, char **argv)
{
int ret;
AVPacket packet;
AVFrame frame;
int got_frame;

if (argc != 2)
{
    fprintf(stderr, "Usage: %s file\n", argv[0]);
    exit(1);
}

avcodec_register_all();
av_register_all();

if ((ret = open_input_file(argv[1])) < 0)
    goto end;

/* read all packets */
while (1)
{
    if ((ret = av_read_frame(fmt_ctx, &packet)) < 0)
        break;

    if (packet.stream_index == video_stream_index)
    {
        avcodec_get_frame_defaults(&frame);
        got_frame = 0;
        ret = avcodec_decode_video2(dec_ctx, &frame, &got_frame, &packet);
        if (ret < 0)
        {
           printf("Error decoding video\n");
            break;
        }

        if (got_frame)
        {
            frame.pts = av_frame_get_best_effort_timestamp(&frame);
            printf("frame timestamp %ld\n", frame.pts);
        }

    }
}
    av_free_packet(&packet);
end:
if (dec_ctx)
    avcodec_close(dec_ctx);
avformat_close_input(&fmt_ctx);

exit(0);
}

编译错误

/usr/local/include/libavutil/common.h||In function ‘int32_t    av_clipl_int32_c(int64_t)’:|
/usr/local/include/libavutil/common.h|173|error: ‘UINT64_C’ was not declared in this scope|

3 个答案:

答案 0 :(得分:2)

UINT64_C<stdint.h>中声明,因此请在任何其他标题之前包含该标题,并且不应该再抱怨它。

答案 1 :(得分:0)

UINT64_C的定义属于条件:

/* The ISO C99 standard specifies that in C++ implementations these
   should only be defined if explicitly requested.  */
#if !defined __cplusplus || defined __STDC_CONSTANT_MACROS

看起来如果你像我一样在C ++ 98中使用ffmpeg,你需要

#define __STDC_CONSTANT_MACROS

之前

#include <stdint.h>

答案 2 :(得分:0)

我发现stdint.h仅为C定义宏INT64_C,但不为C ++定义。 由于我不想用ffmpeg的标题过多麻烦,我把这个定义放在我的代码中,首先是来自ffmpeg的包含

#ifndef INT64_C
#define INT64_C(c) (c ## LL)
#define UINT64_C(c) (c ## ULL)
#endif