detect() org.opencv.features2d.Feature2D 메소드 (추상) 클래스는 주어진 이미지의 핵심 포인트를 감지합니다. 이 방법을 사용하려면 Mat 소스 이미지와 빈 MatOfKeyPoint 를 나타내는 개체 읽기 키 포인트를 유지하는 개체입니다.
drawMatches() org.opencv.features2d.Feature2D 메소드 클래스는 주어진 두 이미지의 키 포인트 사이에서 일치하는 부분을 찾아 그립니다. 이 메소드는 다음 매개변수를 받아들입니다 -
-
src1 − 매트의 개체 첫 번째 소스 이미지를 나타내는 클래스입니다.
-
핵심 포인트1 − MatOfKeyPoint의 개체 첫 번째 소스 이미지의 키 포인트를 나타내는 클래스입니다.
-
src2 − 두 번째 소스 이미지를 나타내는 Mat 클래스의 개체입니다.
-
핵심 포인트2 − MatOfKeyPoint의 개체 두 번째 소스 이미지의 키 포인트를 나타내는 클래스입니다.
-
1대2 일치 - 첫 번째 이미지에서 두 번째 이미지와 일치합니다. 즉, keypoints1[i]에는 keypoints2[matches[i]]에 해당 지점이 있습니다.
-
dst − 대상 이미지를 나타내는 Mat 클래스의 개체입니다.
따라서 두 이미지의 핵심 포인트를 일치시키려면 -
-
imread()를 사용하여 두 개의 소스 이미지를 읽습니다. 방법.
-
detect()를 사용하여 두 이미지의 요점을 가져옵니다. 방법.
-
drawMatches()를 사용하여 일치 항목을 찾고 그립니다. 방법.
예시
import org.opencv.core.Core; import org.opencv.core.Mat; import org.opencv.core.MatOfDMatch; import org.opencv.core.MatOfKeyPoint; import org.opencv.features2d.FastFeatureDetector; import org.opencv.features2d.Features2d; import org.opencv.highgui.HighGui; import org.opencv.imgcodecs.Imgcodecs; public class MatchingKeypoints { public static void main(String args[]) throws Exception { //Loading the OpenCV core library System.loadLibrary( Core.NATIVE_LIBRARY_NAME ); //Reading the source images String file1 ="D:\\Images\\feature1.jpg"; Mat src1 = Imgcodecs.imread(file1); String file2 ="D:\\Images\\feature2.jpg"; Mat src2 = Imgcodecs.imread(file2); //Creating an empty matrix to store the destination image Mat dst = new Mat(); FastFeatureDetector detector = FastFeatureDetector.create(); //Detecting the key points in both images MatOfKeyPoint keyPoints1 = new MatOfKeyPoint(); detector.detect(src1, keyPoints1); MatOfKeyPoint keyPoints2 = new MatOfKeyPoint(); detector.detect(src2, keyPoints2); MatOfDMatch matof1to2 = new MatOfDMatch(); Features2d.drawMatches(src1, keyPoints1, src2, keyPoints2, matof1to2, dst); HighGui.imshow("Feature Matching", dst); HighGui.waitKey(); } }
이미지 입력
이미지1 -
이미지2 -
출력