您好,登錄后才能下訂單哦!
本文為大家分享了使用opencv處理兩張圖片幀差的具體代碼,供大家參考,具體內容如下
這個程序是兩張圖片做幀差,用C++實現的,把不同的地方用框框起來,仔細讀一下程序,應該還是蠻簡單的哈哈,opencv處理圖片的基礎。
opencv配置不用我說了吧,源碼cmake編譯,然后導入vs即可。
#include <iostream> #include <opencv2/opencv.hpp> using namespace std; using namespace cv; int main() { Mat currentframe, previousframe; Mat img1, img2, img3; img1 = imread("D:/1129/20006/1123120.jpg"); img2 = imread("D:/1129/20006/1128120.jpg"); img3 = imread("D:/1129/20006/1128120.jpg"); cvtColor(img1, previousframe, CV_BGR2GRAY); cvtColor(img2, currentframe, CV_BGR2GRAY); //轉化為單通道灰度圖 absdiff(currentframe, previousframe, currentframe);//做差求絕對值 threshold(currentframe, currentframe, 130, 255.0, CV_THRESH_BINARY); dilate(currentframe, currentframe, Mat());//膨脹 erode(currentframe, currentframe, Mat());//腐蝕 imshow("moving area", currentframe); //顯示圖像 vector<vector<Point> > v; vector<Vec4i> hierarchy; Mat result; Rect rect; findContours(currentframe, v, hierarchy, RETR_EXTERNAL, CV_CHAIN_APPROX_NONE); for (int i = 0; i < hierarchy.size(); i++) { rect = boundingRect(v.at(i)); //rect.width *= 1.5; rect.height *= 1.5; // 畫最小的圓,貼著黑色 //drawContours(currentframe, v, i, Scalar(0, 0, 255), 1, 8, hierarchy); // 畫矩形包圍圓 rectangle(img3, rect, Scalar(0, 255, 0), 2); } imwrite("E:/res1.jpg", img3); imshow("moving area1", img3); //把當前幀保存作為下一次處理的前一幀 //cvtColor(tempframe, previousframe, CV_BGR2GRAY); waitKey(33); system("pause"); return 0; }
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持億速云。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。