作者LGham (老大叉)
看板C_and_CPP
標題[問題] 利用opencv對影片做背景相減
時間Sun Mar 19 12:55:10 2017
開發平台(Platform): (Ex: Win10, Linux, ...)
win7
編譯器(Ex: GCC, clang, VC++...)+目標環境(跟開發平台不同的話需列出)
c++/c
額外使用到的函數庫(Library Used): (Ex: OpenGL, ...)
opencv
問題(Question):
我在網路上有看到可以將圖片與圖片做相減
再利用二值化可以得到我想要的特徵物
我現在是把影片切成一個一個frame再下去做相減看看效果如何
請問該怎麼直接輸入影片直接做背景相減呢
小弟對影像處理只是剛入門 程度不佳 希望各位指點迷津
程式碼如下
http://tim12332013.blogspot.tw/2013/10/opencvcvabsdiffimg1img2img3.html
餵入的資料(Input):
圖片
預期的正確結果(Expected Output):
希望能直接對此程式碼輸入影片然後跑動
錯誤結果(Wrong Output):
程式碼(Code):(請善用置底文網頁, 記得排版)
#include "opencv2/highgui/highgui.hpp"
#include <iostream>
#include <opencv/cv.h>
#include <opencv/highgui.h>
void BW(IplImage* img, int RGB)//二值化
{
int Height = cvGetDimSize(img, 0);
int Width = cvGetDimSize(img, 1);
for (int y = 0; y < Height; y++)
for (int x = 0; x < Width; x++)
{
if (!(cvGet2D(img, y, x).val[2] < RGB
&& cvGet2D(img, y, x).val[1] < RGB
&& cvGet2D(img, y, x).val[0] < RGB))
cvSet2D(img, y, x, CV_RGB(255, 255, 255));
else
cvSet2D(img, y, x, CV_RGB(0, 0, 0));
}
}
int main(int argc, char *argv[])
{
cvNamedWindow( "Example", CV_WINDOW_AUTOSIZE );
CvCapture* capture = cvCreateFileCapture( argv[1] );
IplImage* frame;
while(1)
{
frame = cvQueryFrame( capture );
if( !frame ) break;
cvShowImage( "Example", frame );
char c = cvWaitKey(33);
if( c == 27 ) break;
}
cvReleaseCapture( &capture );
cvDestroyWindow( "Example" );
IplImage* img1, *img2, *img3;
img1 = cvLoadImage("E:/20170313/1.png", -1);
img2 = cvLoadImage("E:/20170313/24.png", -1);
if (!img1 || !img2)
{
printf("Could not load image file\n");
system("pause");
exit(0);
}
img3 = cvCreateImage(cvGetSize(img1), img1->depth, img1->nChannels);
cvSmooth(img1, img1, CV_GAUSSIAN, 3, 0, 0);
cvSmooth(img2, img2, CV_GAUSSIAN, 3, 0, 0);
cvAbsDiff(img1, img2, img3);
printf("goal",cvAbsDiff);
int Height = cvGetDimSize(img3, 0);
int Width = cvGetDimSize(img3, 1);
BW(img3, 50);
cvErode(img3, img3, 0, 1);
cvDilate(img3, img3, 0, 1);
cvSaveImage("E:/20170313/yes.png", img3);
cvNamedWindow("img1", CV_WINDOW_AUTOSIZE);
cvNamedWindow("img2", CV_WINDOW_AUTOSIZE);
cvNamedWindow("img3", CV_WINDOW_AUTOSIZE);
cvShowImage("img1", img1);
cvShowImage("img2", img2);
cvShowImage("img3", img3);
cvWaitKey(0);
cvReleaseImage(&img1);
cvReleaseImage(&img2);
cvReleaseImage(&img3);
return 0;
}
補充說明(Supplement):
我試著用CvCapture,cvQueryFrame並利用while迴圈不斷讀取frame
但是都讀不出影片,不知道我用的方法是不是可行的
--
※ 發信站: 批踢踢實業坊(ptt.cc), 來自: 140.116.40.159
※ 文章網址: https://www.ptt.cc/bbs/C_and_CPP/M.1489899313.A.1F1.html
噓 Sidney0503: 作業自己做 03/19 13:54
→ wtchen: 你拿別人的程式碼,沒有自己的心得,這樣算伸手文喔 03/19 17:24
→ wtchen: 給你兩小時補充,不然砍文 03/19 17:24
※ 編輯: LGham (218.164.42.120), 03/19/2017 19:45:32
噓 grayStone: docs.opencv.org 03/19 23:16
→ wtchen: 你好歹也附個自己的程式碼.... 03/19 23:47
※ 編輯: LGham (140.116.40.159), 03/20/2017 10:16:57
→ unosis: 好像來問opencv的99%都是.. 03/20 11:38
→ escrowdis: Google一下 滿山滿谷 03/22 09:11