画像のコーナーを見つけようとしていますが、輪郭は必要ありません。コーナーは4つしかありません。 4つのコーナーを使って視点を変更します。OpenCvを使用して画像のコーナーを見つける方法
私はOpencvを使用していますが、私はコーナーを見つけるためのステップと私が使用する機能を知る必要があります。
私のイメージはこのようになります(赤のポイントなしで、私は後にポイントをペイントします)
EDITED:(注:: - 私
推奨される手順の後、私は、コードをwrited純粋なOpenCvを使用せず、私はjavaCVを使用していますが、論理は同じです)。
// Load two images and allocate other structures (I´m using other image)
IplImage colored = cvLoadImage(
"res/scanteste.jpg",
CV_LOAD_IMAGE_UNCHANGED);
IplImage gray = cvCreateImage(cvGetSize(colored), IPL_DEPTH_8U, 1);
IplImage smooth = cvCreateImage(cvGetSize(colored), IPL_DEPTH_8U, 1);
//Step 1 - Convert from RGB to grayscale (cvCvtColor)
cvCvtColor(colored, gray, CV_RGB2GRAY);
//2 Smooth (cvSmooth)
cvSmooth(gray, smooth, CV_BLUR, 9, 9, 2, 2);
//3 - cvThreshold - What values?
cvThreshold(gray,gray, 155, 255, CV_THRESH_BINARY);
//5 - Find contours (cvFindContours)
int total = 0;
CvSeq contour2 = new CvSeq(null);
CvMemStorage storage2 = cvCreateMemStorage(0);
CvMemStorage storageHull = cvCreateMemStorage(0);
total = cvFindContours(gray, storage2, contour2, Loader.sizeof(CvContour.class), CV_RETR_CCOMP, CV_CHAIN_APPROX_NONE);
if(total > 1){
while (contour2 != null && !contour2.isNull()) {
if (contour2.elem_size() > 0) {
//6 - Approximate contours with linear features (cvApproxPoly)
CvSeq points = cvApproxPoly(contour2,Loader.sizeof(CvContour.class), storage2, CV_POLY_APPROX_DP,cvContourPerimeter(contour2)*0.005, 0);
cvDrawContours(gray, points,CvScalar.BLUE, CvScalar.BLUE, -1, 1, CV_AA);
}
contour2 = contour2.h_next();
}
}
//4 - Detect edges (cvCanny) -What values?
int N = 7;
int aperature_size = N;
double lowThresh = 20;
double highThresh = 40;
cvCanny(gray, gray, lowThresh*N*N, highThresh*N*N, aperature_size);
だから、私は、コーンズを見つけたいが、私はコーナーがcvCornerHarrisなどのように機能を使用する方法を知っているドント。
のこのセットに凸包を適用するポイント のリストを取得しますおおまかに言えば、水平方向と垂直方向に大きなばらつきのある領域があります。 OpenCVのコーナー機能の目標は、ビジュアルトラッキングに役立つ画像の特徴的な部分を見つけることです。これは必ずしもコーナーとして一般的に考えるものではありません。 –
正確なコードはhttp://stackoverflow.com/a/14368605/1832154です(画像サイズが小さいので、サイズ変更部分は除く)。http://i.imgur.com/hMdAlHX.png – mmgp