Java OpenCV 라이브러리를 사용하여 이미지 윤곽을 그리는 방법은 무엇입니까?

WBOY
풀어 주다: 2023-09-04 14:33:01
앞으로
957명이 탐색했습니다.

윤곽선은 특정 모양의 경계를 따라 모든 점을 연결하는 선일 뿐입니다. 이를 사용하면 -

  • 물체의 모양을 찾을 수 있습니다.

  • 물체의 면적을 계산합니다.

  • 물체를 감지합니다.

  • 물체를 인식합니다.

findContours()메서드를 사용하여 이미지에서 다양한 모양과 개체의 윤곽선을 찾을 수 있습니다. 같은 방법으로 그릴 수 있습니다.

다음 매개변수를 허용하는drawContours()메소드를 사용하여 발견된 이미지 윤곽을 그릴 수 있습니다.

  • 결과 이미지를 저장할 빈 Mat 객체.

  • 발견된 윤곽선이 포함된 객체를 나열합니다.

  • 그릴 윤곽선을 지정하는 정수 값(-ve 값은 모든 윤곽선을 그리는 데 사용됩니다).

  • 윤곽선의 색상을 지정하는 스칼라 객체

  • 윤곽선의 두께를 지정하는 정수 값.

Example

import java.util.ArrayList; import java.util.List; import org.opencv.core.Core; import org.opencv.core.Mat; import org.opencv.core.MatOfPoint; import org.opencv.core.Point; import org.opencv.core.Scalar; import org.opencv.highgui.HighGui; import org.opencv.imgcodecs.Imgcodecs; import org.opencv.imgproc.Imgproc; public class DrawingContours { public static void main(String args[]) throws Exception { //Loading the OpenCV core library System.loadLibrary( Core.NATIVE_LIBRARY_NAME ); String file ="D:\Images\shapes.jpg"; Mat src = Imgcodecs.imread(file); //Converting the source image to binary Mat gray = new Mat(src.rows(), src.cols(), src.type()); Imgproc.cvtColor(src, gray, Imgproc.COLOR_BGR2GRAY); Mat binary = new Mat(src.rows(), src.cols(), src.type(), new Scalar(0)); Imgproc.threshold(gray, binary, 100, 255, Imgproc.THRESH_BINARY_INV); //Finding Contours List contours = new ArrayList<>(); Mat hierarchey = new Mat(); Imgproc.findContours(binary, contours, hierarchey, Imgproc.RETR_TREE, Imgproc.CHAIN_APPROX_SIMPLE); //Drawing the Contours Scalar color = new Scalar(0, 0, 255); Imgproc.drawContours(src, contours, -1, color, 2, Imgproc.LINE_8, hierarchey, 2, new Point() ) ; HighGui.imshow("Drawing Contours", src); HighGui.waitKey(); } }
로그인 후 복사

Input picture

如何使用Java OpenCV库绘制图像轮廓?

Output

실행하면 위 프로그램이 실행되면 다음과 같은 창이 생성됩니다 -

Java OpenCV 라이브러리를 사용하여 이미지 윤곽을 그리는 방법은 무엇입니까?

위 내용은 Java OpenCV 라이브러리를 사용하여 이미지 윤곽을 그리는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:tutorialspoint.com
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿
회사 소개 부인 성명 Sitemap
PHP 중국어 웹사이트:공공복지 온라인 PHP 교육,PHP 학습자의 빠른 성장을 도와주세요!