// 数字認識 internal static int recognizeDigit(CvMat image) { int nonzero = 0; nonzero = image.GetCols( image.Cols-2, image.Cols ).CountNonZero(); if ( image.Rows * 2 == nonzero ) // 1 右端2列がすべて輝点 return 1; nonzero = image.GetRows( image.Rows-2, image.Rows ).CountNonZero(); if ( image.Cols * 2 == nonzero ) // 2 下端2行がすべて輝点 return 2; nonzero = image.GetRows ( 0, 2 ).CountNonZero(); if ( image.Cols * 2 - 2 < nonzero ) // 7 上端2行がすべて輝点.ただし1ピクセルまで欠けても良い return 7; nonzero = image.GetCols ( image.Cols-3, image.Cols-1 ).CountNonZero(); if ( image.Rows * 2 == nonzero ) // 4 右端の左2列がすべて輝点 return 4; CvRect rect = new CvRect( 0, 0, 1, image.Rows*2/3 ); CvMat subarr; nonzero = image.GetSubArr ( out subarr, rect ).CountNonZero(); if ( 0 == nonzero ) // 3 左端の上部3分の2がすべて暗点 return 3; rect = new CvRect ( 0, image.Rows/2, 3, 2 ); nonzero = image.GetSubArr ( out subarr, rect ).CountNonZero(); if ( 0 == nonzero ) // 5 左端の下半分開始すぐのwidth3 height2 がすべて暗点 return 5; rect = new CvRect ( image.Cols/2, image.Rows/2-1, 1, 3 ); nonzero = image.GetSubArr( out subarr, rect ).CountNonZero(); if ( 0 == nonzero ) // 0 中央列中央3ピクセルがすべて暗点 return 0; rect = new CvRect ( image.Cols-1, 0, 1, image.Rows*2/5 ); nonzero = image.GetSubArr( out subarr, rect ).CountNonZero(); if ( 0 == nonzero ) // 6 右端上部5分の2がすべて暗点 return 6; rect = new CvRect ( image.Cols-1, image.Rows-3, 1, 3 ); nonzero = image.GetSubArr( out subarr, rect ).CountNonZero(); if ( 0 == nonzero ) // 右端下部3ピクセルがすべて暗点 return 9; // 8 上記条件を満たさない return 8; }
public CharactersInfo(CvMat _image) { positions = new List<CvRect>(); // 画像コピー image = _image.Clone(); // 文字列認識 // 輝点列検索フラグ.falseなら暗点列を探す bool searchingBright = true; // 始点 int left = 0; // 終点 int right; for (int col = 0; col < image.Cols; col++) { // 列の輝点数 int nonzero = image.GetCol(col).CountNonZero(); // 探索モードによる分岐 if ( true == searchingBright) { // 輝点列探索中 if (0 < nonzero) { // 輝点が1個以上あったなら left = col; // フラグ切り替え searchingBright = false; } } else { // 暗点列探索中 if (0 == nonzero) { // 暗点列だったなら right = col; // LowestWidth を満足するか if (CharactersInfo.LowestWidth > right - left) { // 条件を満たさない場合は探索やり直し searchingBright = true; continue; } // 文字と認める CvMat character = image.GetCols( left, right ); // 上端輝点行を探す int top = 0; for (int row = 0; row < character.Rows; row++) { if (0 < character.GetRow(row).CountNonZero()) { // 輝点発見 top = row; break; } } // 下端輝点行を探す int bottom = character.Rows - 1; for (int row = bottom; row > top; row--) { if (0 < character.GetRow(row).CountNonZero()) { // 輝点発見 bottom = row + 1; break; } } // 文字領域確定 positions.Add(new CvRect(left, top, right - left, bottom - top)); // 探索フラグ切り替え searchingBright = true; } } } }