CvCapture 是視訊獲取結構 被用來作為視訊獲取函式的一個引數 比如 CvCapture* cap; IplImage* cvQueryFrame( cap ); 從攝像頭或者檔案中抓取並返回一幀

 
 

  1. #include "stdafx.h"  
  2. #include"highgui.h"  
  3.   
  4. int main(int argc,char* argv[])  
  5. {  
  6.  cvNamedWindow( "avi");  
  7.  CvCapture* capture = cvCreateFileCapture( "sample.avi");  
  8.  IplImage* frame;  
  9.       while(1)  
  10.            {  
  11.             frame = cvQueryFrame(capture);  
  12.             if(!frame) break ;  
  13.                                    
  14.             cvShowImage( "avi",frame);  
  15.             char c = cvWaitKey(33);  
  16.                                    
  17.             if(c == 27)  
  18.             break;  
  19.         }  
  20.             cvReleaseCapture(&capture);        
  21.             cvDestroyWindow( "avi");  
  22.             return 0;  
  23. }  

結構體 CvCapture

  

  CvCapture 是一個結構體,用來儲存影象捕獲所需要的資訊。 opencv提供兩種方式從外部捕獲影象:

一種是從攝像頭中,

一種是通過解碼視訊得到影象。

     兩種方式都必須從第一幀開始一幀一幀的按順序獲取,因此每獲取一幀後都要儲存相應的狀態和引數。

     比如從視訊檔案中獲取,需要儲存視訊檔案的檔名,相應的解碼器型別,下一次如果要

獲取將需要解碼哪一幀等。 這些資訊都儲存在CvCapture結構中,每獲取一幀後,這些資訊

都將被更新,獲取下一幀需要將新資訊傳給獲取的 api介面

cvCreateFileCapture(char*name)

通過輸入要讀取的avi檔案的路徑,然後,該函式返回一個指向 CvCapture結構體的指標。

cvQueryFrame(capture)

輸入一個CvCapture 型別的指標,該函式主要功能是將視訊檔案的下一幀載入到記憶體。與 cvLoadImage的不同之處是,該函式不重新分配記憶體空間。

C=cvWaitKey(33)

當前幀被顯示後,等待 33毫秒。如果使用者觸發了一個按鍵, c會被設定成這個按鍵的 ASCII碼,否則會被設定成 -1。

cvWaitKey(33) 在此處的另外一個作用是,控制幀率。

cvReleaseCapture(&capture)

釋放為 CvCapture結構體開闢的記憶體空間

關閉開啟的 AVI檔案相關的檔案控制代碼

讀取攝像頭

 

只需把 cvCreateFileCapture 改成cvCreateCameraCapture即可。

該函式的輸入引數是一個 ID號,只有存在多個攝像頭時才起作用。當 ID=-1時,表示

隨機選擇一個。 HighGUI做了很多工作,使得攝像機影象序列像一個視訊檔案一樣。

常見問題

cvCreateFileCapture返回空的問題

  • ( 1)視訊檔案路徑沒寫對
  • ( 2)沒有安裝解碼器
  • ( 3)如果使用的是 Opencv2.0或更高版本,那麼,能否正確載入 opencv_ffmpeg210.dll
  • ( 4)儘管是 AVI檔案,但也可能使用了某種 codec,例如 :MJPEG Decompressor。 需要把它轉換 OpenCV支援的 AVI檔案 . OpenCV支援的AVI。例如使用狸窩全能視訊轉換器,在《預置方案》處,選擇 AVI-Audio_Video Interleaved(*.avi)。或者使用格式工廠也可以。
  • ( 5)讀攝像頭資料,需要安裝與攝像頭相應的驅動程式。

————————————————————

cvQueryFrame

OpenCV中一個函式cvQueryFrame

從攝像頭或者檔案中抓取並返回一幀

IplImage* cvQueryFrame( CvCapture* capture );

capture

視訊獲取結構。

函式cvQueryFrame從攝像頭或者檔案中抓取一幀,然後解壓並返回這一幀。 這個函式僅僅是函式cvGrabFrame和 函式cvRetrieveFrame在一起呼叫的組合。 返回的影象不可以被使用者釋放或者修改。

cvQueryFrame的引數為CvCapture結構的指標。用來將下一幀視訊檔案載入記憶體,返回一個對應當前幀的指標。與cvLoadImage不同的是cvLoadIamge為影象分配記憶體空間,而cvQueryFrame使用已經在cvCapture結構中分配好的記憶體。這樣的話,就沒有必要通過cvReleaseImage()對這個返回的影象指標進行釋放,當CvCapture結構被釋放後,每一幀影象所對應的記憶體空間即會被釋放。

________________________________________________________________________________

opencv提取視訊每一幀

[cpp] view plaincopy

  1. // test3.cpp  
  2. //  
  3. // 該程式實現視訊和圖片的相互轉換.  
  4. // Image_to_video()函式將一組圖片合成AVI視訊檔案.  
  5. // Video_to_image()函式將AVI視訊檔案讀入,將每一幀儲存為jpg檔案.  
  6. //  
  7. ////////////////////////////////////////////////////////////////////////  
  8. #include <stdlib.h>  
  9. #include <stdio.h>  
  10. #include <math.h>  
  11. #include <cv.h>  
  12. #include <highgui.h>  
  13. #define NUM_FRAME 300 //只處理前300幀,根據視訊幀數可修改  
  14.   
  15. void Video_to_image(char* filename)  
  16. {  
  17. printf("------------- video to image ... ----------------n");  
  18. //初始化一個視訊檔案捕捉器  
  19. CvCapture* capture = cvCaptureFromAVI(filename);  
  20. //獲取視訊資訊  
  21. cvQueryFrame(capture);  
  22. int frameH    = (int) cvGetCaptureProperty(capture, CV_CAP_PROP_FRAME_HEIGHT);  
  23. int frameW    = (int) cvGetCaptureProperty(capture, CV_CAP_PROP_FRAME_WIDTH);  
  24. int fps       = (int) cvGetCaptureProperty(capture, CV_CAP_PROP_FPS);  
  25. int numFrames = (int) cvGetCaptureProperty(capture, CV_CAP_PROP_FRAME_COUNT);  
  26. printf("tvideo height : %dntvideo width : %dntfps : %dntframe numbers : %dn", frameH, frameW, fps, numFrames);  
  27. //定義和初始化變數  
  28. int i = 0;  
  29. IplImage* img = 0;  
  30. char image_name[13];  
  31.   
  32. cvNamedWindow( "mainWin", CV_WINDOW_AUTOSIZE );  
  33. //讀取和顯示  
  34. while(1)  
  35. {  
  36.     
  37.    img = cvQueryFrame(capture); //獲取一幀圖片  
  38.    cvShowImage( "mainWin", img ); //將其顯示  
  39.    char key = cvWaitKey(20);  
  40.     
  41.    sprintf(image_name, "%s%d%s", "image", ++i, ".jpg");//儲存的圖片名  
  42.     
  43.    cvSaveImage( image_name, img);   //儲存一幀圖片  
  44.   
  45.    if(i == NUM_FRAME) break;  
  46. }  
  47. cvReleaseCapture(&capture);  
  48. cvDestroyWindow("mainWin");  
  49. }  
  50.    
  51. void Image_to_video()  
  52. {  
  53. int i = 0;  
  54. IplImage* img = 0;  
  55. char image_name[13];  
  56. printf("------------- image to video ... ----------------n");  
  57. //初始化視訊編寫器,引數根據實際視訊檔案修改  
  58. CvVideoWriter *writer = 0;  
  59. int isColor = 1;  
  60. int fps     = 30; // or 25  
  61. int frameW = 400; // 744 for firewire cameras  
  62. int frameH = 240; // 480 for firewire cameras  
  63. writer=cvCreateVideoWriter("out.avi",CV_FOURCC('X','V','I','D'),fps,cvSize(frameW,frameH),isColor);  
  64. printf("tvideo height : %dntvideo width : %dntfps : %dn", frameH, frameW, fps);  
  65. //建立視窗  
  66. cvNamedWindow( "mainWin", CV_WINDOW_AUTOSIZE );  
  67. while(i<NUM_FRAME)  
  68. {  
  69.    sprintf(image_name, "%s%d%s", "image", ++i, ".jpg");  
  70.    img = cvLoadImage(image_name);  
  71.    if(!img)  
  72.    {  
  73.     printf("Could not load image file...n");  
  74.     exit(0);  
  75.    }  
  76.    cvShowImage("mainWin", img);  
  77.    char key = cvWaitKey(20);  
  78.    cvWriteFrame(writer, img);  
  79. }  
  80. cvReleaseVideoWriter(&writer);  
  81. cvDestroyWindow("mainWin");  
  82. }  
  83.   
  84. int main(int argc, char *argv[])  
  85. {  
  86. char filename[13] = "infile.avi";  
  87. Video_to_image(filename); //視訊轉圖片  
  88. Image_to_video();    //圖片轉視訊  
  89. return 0;  
  90. }  

轉:https://www.cnblogs.com/gune/articles/3374651.html