前提・実現したいこと
テンプレートマッチングでマッチングされた箇所だけをキー入力で切り取りを行い保存するプログラムを作成したいと思っています。補足情報が必要であれば追記しますのでコメントよろしくお願いします。
発生している問題・エラーメッセージ
テンプレートマッチングはできるのですが、切り取りができないです。 ソースコードの下部のelse if文内のdst = cv::Mat(src, Rect(850,450,125,55));のRectに何を入れたら良いのかわかりません。そもそも、Rectが間違っているのでしょうか?
該当のソースコード
C++
1#include<opencv2/opencv.hpp> 2#include <iostream> 3#include "opencv2/opencv.hpp" 4#include <opencv2/core/core.hpp> 5#include <opencv2/highgui/highgui.hpp> 6#pragma comment(lib, "opencv_world320d.lib") 7 8using namespace std; 9using namespace cv; 10 11int main() 12{ 13 VideoCapture cap(0); 14 if(!cap.isOpened()) 15 { 16 cout << "ERROR: cannot open cam device." << endl; 17 return -1; 18 } 19 20 Mat src; 21 //テンプレート画像とその名称 22 vector<Mat> img{ imread("/Users/i-am-kaito/Downloads/IMG_4483.png") 23 }; 24 vector<string> name{ "150" }; 25 26 while (1) { 27 cap >> src; if (src.empty()) break; 28 29 for (int num = 0; num < 1; num++){ 30 Mat mapCC; 31 //テンプレートマッチング 32 matchTemplate(src, img[num], mapCC, cv::TM_CCOEFF_NORMED);//ZNCC法 33 double maxCC; 34 Point maxLoc; 35 //相互相関係数の最大値探索 36 minMaxLoc(mapCC, NULL, &maxCC, NULL, &maxLoc); 37 38 if (maxCC > 0.4){ //類似度が0.4以上なら枠描写 39 rectangle(src, maxLoc, 40 maxLoc + Point(img[num].cols, img[num].rows), 0.4); 41 putText(src, name[num], maxLoc + Point(10, 30), 42 cv::FONT_HERSHEY_SIMPLEX, 1, 0, 2); 43 } 44 45 46 } 47 48 imshow("Temp", src); 49 50 const int key = cv::waitKey(1); 51 if(key == 'q') 52 { 53 break; 54 55 } 56 else if(key == 's') 57 { 58 Mat dst; 59 waitKey(1); 60 imwrite("/Users/i-am-kaito/Downloads/img.png", src); 61 62 src = imread("/Users/i-am-kaito/Downloads/img.png"); 63 dst = cv::Mat(src, Rect(850,450,125,55)); 64 65 imshow("kiri", dst); 66 imwrite("/Users/i-am-kaito/Downloads/img.png", dst); 67 68 waitKey(0); 69 70 71 } 72 } 73 74 return 0; 75} 76
補足情報(FW/ツールのバージョンなど)
開発環境
OS Mac OS
OpenCV 4.1
Xcode 11.3
回答1件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
2020/01/17 08:19
2020/01/22 09:02