1

部屋のイメージがあります。画像のエッジを検出したい-つまり、天井の周りに線を引いたり、窓の周りに言ったりします。これはどれほど難しい問題ですか - これを行うライブラリはありますか?

これは iOS アプリ用ですが、私の質問はプラットフォーム/言語に依存しません。

4

1 に答える 1

2

これは、 edge.cppと呼ばれる openCV ソース コード の例です。

#include "opencv2/imgproc/imgproc.hpp"
#include "opencv2/highgui/highgui.hpp"

#include <stdio.h>

using namespace cv;
using namespace std;

int edgeThresh = 1;
Mat image, gray, edge, cedge;

// define a trackbar callback
static void onTrackbar(int, void*)
{
 blur(gray, edge, Size(3,3));

// Run the edge detector on grayscale
Canny(edge, edge, edgeThresh, edgeThresh*3, 3);
cedge = Scalar::all(0);

image.copyTo(cedge, edge);
imshow("Edge map", cedge);
}

static void help()
{
printf("\nThis sample demonstrates Canny edge detection\n"
       "Call:\n"
       "    /.edge [image_name -- Default is fruits.jpg]\n\n"); 
}

const char* keys =
{
"{@image |fruits.jpg|input image name}"
};

int main( int argc, const char** argv )
{
help();

CommandLineParser parser(argc, argv, keys);
string filename = parser.get<string>(1);

image = imread(filename, 1);
if(image.empty())
{
    printf("Cannot read image file: %s\n", filename.c_str());
    help();
    return -1;
}
cedge.create(image.size(), image.type());
cvtColor(image, gray, CV_BGR2GRAY);

// Create a window
namedWindow("Edge map", 1);

// create a toolbar
createTrackbar("Canny threshold", "Edge map", &edgeThresh, 100, onTrackbar);

// Show the image
onTrackbar(0, 0);

// Wait for a key stroke; the same function arranges events processing
waitKey(0);

return 0;
}

openCV ビルドとは別にビルドする場合は、このスクリプトを使用できます (c サンプル ディレクトリの下にあるバージョンが提供されています - 追加のライブラリをコンパイルするように変更しました)。

#!/bin/sh

if [ $# -gt 0 ] ; then
base=`basename $1 .c`
echo "compiling $base"
gcc -ggdb `pkg-config opencv --cflags --libs` $base.c -o $base 
else
for i in *.c; do
    echo "compiling $i"
    gcc -ggdb `pkg-config --cflags opencv` -o `basename $i .c` $i `pkg-config --libs    opencv`;
done
for i in *.cpp; do
    echo "compiling $i"
    g++ -ggdb `pkg-config --cflags opencv` -o `basename $i .cpp` $i `pkg-config -- libs opencv` -lpthread -D_REENTRANT;
done
fi
于 2012-12-01T15:29:01.327 に答える