轉載於http://blog.csdn.net/kcust/article/details/13768199
從網路攝影機或者檔案中抓取並返回一幀
IplImage* frame = cvQueryFrame( CvCapture* capture );
抓取後,capture被指向下一幀,可用cvSetCaptureProperty調整capture到合適的幀。函數cvQueryFrame從網路攝影機或者檔案中抓取一幀,然後解壓並返回這一幀。這個函數僅僅是函數cvGrabFrame和函數cvRetrieveFrame在一起調用的組合。返回的映像不可以被使用者釋放或者修改。
注意: cvQueryFrame返回的指標總是指向同一塊記憶體(這個特點就是下面的問題所在。)。建議cvQueryFrame後拷貝一份。而且返回的幀需要FLIP後才符合OPENCV的座標系。
若傳回值為NULL,說明到了視頻的最後一幀。
以下代碼:
IplImage* frame0 = 0; IplImage* frame1 = 0; IplImage* frame2 = 0; frame0 = cvQueryFrame( capture ); cvSaveImage("frame0.jpg",frame0); for (i=0;i<10;i++) { frame2=cvQueryFrame(capture); } frame1=cvCloneImage(frame0); cvSaveImage("frame2.jpg",frame2); cvSaveImage("frame1.jpg",frame1);
兩段代碼顯示的結果不一樣,前一段代碼中,frame1與frame0不相同,卻與frame2相同,後一段代碼則可實現正常的複製功能,這是因為cvQueryFrame返回的記憶體地區是由由vQueryFrame管理的,每調用一次,指標所指地區就會更新。
個人理解:第一次調用cvQueryFrame時,frame0指標指向的是該函數返回的是第0幀映像,緊接著連續調用10次cvQueryFrame函數後。由於cvQueryFrame函數每次返回的都是同一塊記憶體地區,因此之前的指標frame0指向的映像地址被更新和frame1一樣的了,此時再調用cvCloneImage複製的就是指標frame1所指向的映像地址了。