黒と白の数を数えてどちらの方が多いかまではできたのですが一つ一つ白黒を出力していく方法がわかりません。
c++
1 2//略 3 4int main(int argc, const char * argv[]){ 5 //画像変数の宣言 6 cv::Mat src_img, gray_img, dst_img, bin_img, bin_img2, tmp_img; 7 //変数宣言 8 int ku, si; 9 10 std::vector<std::vector<cv::Point>> contours; 11 std::vector<std::vector<cv::Point>> contours2; 12 13 //1. 入力画像をカラーで入力 14 src_img = cv::imread(FILE_NAME, cv::IMREAD_COLOR); 15 if (src_img.empty()) {//入力失敗の場合 16 fprintf(stderr, "Cannot read image file: %s.\n", FILE_NAME); 17 return (-1); 18 } 19 dst_img = cv::Mat::zeros(src_img.size(), CV_8UC1); 20 21 //2. グレースケール画像 22 cv::cvtColor(src_img, gray_img, cv::COLOR_BGR2GRAY); 23 //3. 二値化 24 cv::threshold(gray_img, bin_img, TH, MAX_VAL, cv::THRESH_BINARY_INV); 25 cv::threshold(gray_img, bin_img2, TH2, MAX_VAL, cv::THRESH_BINARY); 26 27 //4. 膨張縮小処理 28 cv::dilate(bin_img, bin_img, cv::Mat(), cv::Point(-1,-1), COUNT); 29 cv::erode(bin_img, bin_img, cv::Mat(), cv::Point(-1,-1), COUNT*2); 30 cv::dilate(bin_img, bin_img, cv::Mat(), cv::Point(-1,-1), COUNT); 31 32 cv::dilate(bin_img2, bin_img2, cv::Mat(), cv::Point(-1,-1), COUNT); 33 cv::erode(bin_img2, bin_img2, cv::Mat(), cv::Point(-1,-1), COUNT*2); 34 cv::dilate(bin_img2, bin_img2, cv::Mat(), cv::Point(-1,-1), COUNT); 35 36 37 //5.黒のコマの数を検出 38 tmp_img = bin_img.clone(); 39 cv::findContours(tmp_img, contours, cv::RETR_EXTERNAL, cv::CHAIN_APPROX_NONE); 40 std::cout << "黒 = " << contours.size() << std::endl; 41 42 ku = contours.size(); 43 44 //6.白のコマの数を検出 45 tmp_img = bin_img2.clone(); 46 cv::findContours(tmp_img, contours, cv::RETR_EXTERNAL, cv::CHAIN_APPROX_NONE); 47 std::cout << "白 = " << contours.size() << std::endl; 48 49 si = contours.size(); 50 51 //7.どちらが勝ったかの測定 52 if(ku>si){ 53 std::cout << "黒の勝ち\n"; 54 }else if(si<ku){ 55 std::cout << "白の勝ち\n"; 56 }else{ 57 std::cout << "引き分け\n"; 58 } 59 60 return 0; 61}
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。