1

私は現在、学校のプロジェクトで opencv と c++ を使用しています。私の問題は、スケルトン画像の接合点を抽出する方法です。このコードを開発しようとしましたが、うまくいきませんでした。間違いも見つかりませんでした。前もって感謝します 。

int main( int argc, char** argv )
{
cv::Mat im = cv::imread("IMG.jpg",0);
if (im.empty())
    return -1;
cv::Mat img_rgb(im.size(), CV_8UC3);
cv::threshold(img_rgb, img_rgb, 155, 255, CV_THRESH_BINARY);
cv::cvtColor(im, img_rgb, CV_GRAY2RGB);

int s=0;

    for (int i = 1; i < img_rgb.rows-1; i++)
    {
    for (int j = 1; j < img_rgb.cols-1; j++)
    {

    if(255 == img_rgb.at<uchar>(i,j))
    {
        uchar p1 = img_rgb.at<uchar>(i, j);
        uchar p2 = img_rgb.at<uchar>(i-1, j);
        uchar p3 = img_rgb.at<uchar>(i-1, j+1);
        uchar p4 = img_rgb.at<uchar>(i, j+1);
        uchar p5 = img_rgb.at<uchar>(i+1, j+1);
        uchar p6 = img_rgb.at<uchar>(i+1, j);
        uchar p7 = img_rgb.at<uchar>(i+1, j-1);
        uchar p8 = img_rgb.at<uchar>(i, j-1);
        uchar p9 = img_rgb.at<uchar>(i-1, j-1);
       // s = abs(p9-p8)+abs(p8-p7)+abs(p7-p6)+abs(p6-p5)+abs(p5-p4)+abs(p4-p3)+abs(p3-p2)+abs(p2-p9);
        //    if (s == 1530)

                int same=(p9==p1);
                 same+=(p8==p1);
                same+=(p7==p1);
                 same+=(p6==p1);
                 same+=(p5==p1);
                 same+=(p4==p1);
                 same+=(p3==p1);
                 same+=(p2==p1);
              if (same==2)
              {


        //                   cout<<i<<" "<<j<<" " <<same<<endl;
    circle(img_rgb,Point(i,j),1,Scalar(0, 255, 0),1);
            }

    }
    }
}

cv::imshow("a",img_rgb);
cv::waitKey();

return 0 ;

}

4

1 に答える 1

2

その時点で空である img_rgb をしきい値処理しています。

また、なぜグレーからRGBに変換するのですか? (ところで、RGB 画像をループすると、mat.at<uchar>(y,x)間違っているはずですmat.at<Vec3b>(y,x))

私は言う、gray2rgb 変換をスキップし、代わりに読み込まれたグレースケール イメージのしきい値を設定します。

cv::Mat im = cv::imread("IMG.jpg",0);
if (im.empty())
    return -1;

cv::Mat thresh;
cv::threshold(im, thresh, 155, 255, CV_THRESH_BINARY);

次に、そのマットを使用してさらに処理します。

for (int i = 1; i < thresh.rows-1; i++)
{
    for (int j = 1; j < thresh.cols-1; j++)
    {
        uchar p1 = thresh.at<uchar>(i, j);
        if(255 == p1)
        {   
             uchar p2 = thresh.at<uchar>(i-1, j);
             uchar p3 = thresh.at<uchar>(i-1, j+1);

             // ...
于 2013-05-10T08:54:42.960 に答える