C + OpenCV:带循环缓冲区的IplImage

时间:2012-03-16 06:40:28

标签: c opencv

我正在尝试使用OpenCV(使用C)实现循环缓冲区用作帧缓冲区。

我从这篇文章中无耻地窃取了循环缓冲区实现,以免重新发明轮子:

编辑:好的,所以我重新定义了一些东西。即我实现了自己的循环缓冲区。现在我收到了没有意义的错误。

这是我正在使用的循环缓冲区实现:

#define BUFFER_SIZE 100

typedef struct
{
    IplImage* queue[BUFFER_SIZE];
    IplImage *in;
    IplImage *out;
    int num_frames;
    int in_ctr;
    int out_ctr;
    int update_flag;
} frame_buffer;

这是get函数:

IplImage* buff_get()
{
    IplImage* nextfr;
    if(frbuff.num_frames == 0)
    {
        return NULL;
    }
    nextfr = frbuff.out++;
    if(++frbuff.out_ctr == BUFFER_SIZE)
    {
        frbuff.out = &frbuff.queue[0];
        frbuff.out_ctr = 0;
    }
    --frbuff.num_frames;
    return nextfr;
}

这是put函数:

int buff_put(IplImage* nextfr)
{
    if(++frbuff.num_frames > BUFFER_SIZE)
    {
       return 0;
    }
    frbuff.in++; 
    frbuff.in = nextfr;
    if(++frbuff.in_ctr == BUFFER_SIZE)
    {
        frbuff.in = &frbuff.queue[0];
        frbuff.in_ctr = 0;
    }

    return 1;
}

一切似乎都没问题。框架出现在缓冲区上,我知道因为我可以打印出尺寸。但是当我试图显示缓冲区上的图像时,一切都变坏了。

如果我尝试这样做:

IplImage* curr_frame = cvCreateImage(cvSize(640,480),8,3);
cvNamedWindow("proc_window",CV_WINDOW_AUTOSIZE);
cvShowImage("proc_window",curr_frame);

while(1)
{     
   if(buff_size() > 0) 
   {    
        if(buff_flag_check()) curr_frame = buff_get();
        if(curr_frame != NULL)
        {
            cvShowImage("proc_window",curr_frame);
        }

}

我在调用cvShowImage()时收到以下错误:

OpenCV Error: Bad flag (parameter or structure field) (Unrecognized or unsupported array type) in cvGetMat, file /home/fagg/src/OpenCV-2.3.1/modules/core/src/array.cpp, line 2482
terminate called after throwing an instance of 'cv::Exception'
what():  /home/fagg/src/OpenCV-2.3.1/modules/core/src/array.cpp:2482: error: (-206)     Unrecognized or unsupported array type in function cvGetMat

我很困惑这里发生了什么。希望有一个比我更新眼的人可以看到发生了什么......

1 个答案:

答案 0 :(得分:0)

您提供的代码片段无法编译,因为cb_init()将指向circular_buffer的指针作为第一个参数。

如果你在cb_init()中遇到段错误,那是因为malloc()无法返回请求的大小,链接中的实现也不能处理错误。

void cb_init(circular_buffer *cb, size_t capacity, size_t sz)
{
    cb->buffer = malloc(capacity * sz);
    if(cb->buffer == NULL)
        // handle error
    cb->buffer_end = (char *)cb->buffer + capacity * sz;//segfault when using cb->buffer which is null in case of malloc() failure
    cb->capacity = capacity;
    cb->count = 0;
    cb->sz = sz;
    cb->head = cb->buffer;
    cb->tail = cb->buffer;
}