本文整理汇总了C#中CvMat.GetCols方法的典型用法代码示例。如果您正苦于以下问题:C# CvMat.GetCols方法的具体用法?C# CvMat.GetCols怎么用?C# CvMat.GetCols使用的例子?那么恭喜您, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类CvMat
的用法示例。
在下文中一共展示了CvMat.GetCols方法的2个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C#代码示例。
示例1: recognizeDigit
// 数字認識
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;
}
示例2: CharactersInfo
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;
}
}
}
}