// 孤立輝点除去 // 周囲に輝点が無い場合,その輝点を消す static CvMat removeNoize(CvMat image) { // 1px大きい作業用画像 CvMat workImage = new CvMat( image.Rows+1, image.Cols+1, MatrixType.U8C1 ); image.CopyMakeBorder( workImage, new CvPoint(1, 1), BorderType.Constant ); // 走査 for ( int row = 0; row < image.Rows; row++ ) { for ( int col = 0; col < image.Cols; col++ ) { // 注目画素が暗点ならば何もしない if ( 0 == image.Get2D( row, col )) continue; // 範囲3x3の輝点が1ならば,中心画素を暗点にする CvRect rect = new CvRect( col, row, 3, 3 ); CvMat area; workImage.GetSubArr ( out area, rect ); int nonzero = area.CountNonZero(); if ( 1 == nonzero ) image.Set2D( row, col, 0 ); } } return image; }