示例#1
0
        // 孤立輝点除去
        // 周囲に輝点が無い場合,その輝点を消す
        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;
        }