Path: blob/master/samples/java/tutorial_code/ShapeDescriptors/hull/HullDemo.java
16354 views
import java.awt.BorderLayout;1import java.awt.Container;2import java.awt.Image;3import java.util.ArrayList;4import java.util.List;5import java.util.Random;67import javax.swing.BoxLayout;8import javax.swing.ImageIcon;9import javax.swing.JFrame;10import javax.swing.JLabel;11import javax.swing.JPanel;12import javax.swing.JSlider;13import javax.swing.event.ChangeEvent;14import javax.swing.event.ChangeListener;1516import org.opencv.core.Core;17import org.opencv.core.CvType;18import org.opencv.core.Mat;19import org.opencv.core.MatOfInt;20import org.opencv.core.MatOfPoint;21import org.opencv.core.Point;22import org.opencv.core.Scalar;23import org.opencv.core.Size;24import org.opencv.highgui.HighGui;25import org.opencv.imgcodecs.Imgcodecs;26import org.opencv.imgproc.Imgproc;2728class Hull {29private Mat srcGray = new Mat();30private JFrame frame;31private JLabel imgSrcLabel;32private JLabel imgContoursLabel;33private static final int MAX_THRESHOLD = 255;34private int threshold = 100;35private Random rng = new Random(12345);3637public Hull(String[] args) {38/// Load source image39String filename = args.length > 0 ? args[0] : "../data/stuff.jpg";40Mat src = Imgcodecs.imread(filename);41if (src.empty()) {42System.err.println("Cannot read image: " + filename);43System.exit(0);44}4546/// Convert image to gray and blur it47Imgproc.cvtColor(src, srcGray, Imgproc.COLOR_BGR2GRAY);48Imgproc.blur(srcGray, srcGray, new Size(3, 3));4950// Create and set up the window.51frame = new JFrame("Convex Hull demo");52frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);53// Set up the content pane.54Image img = HighGui.toBufferedImage(src);55addComponentsToPane(frame.getContentPane(), img);56// Use the content pane's default BorderLayout. No need for57// setLayout(new BorderLayout());58// Display the window.59frame.pack();60frame.setVisible(true);61update();62}6364private void addComponentsToPane(Container pane, Image img) {65if (!(pane.getLayout() instanceof BorderLayout)) {66pane.add(new JLabel("Container doesn't use BorderLayout!"));67return;68}6970JPanel sliderPanel = new JPanel();71sliderPanel.setLayout(new BoxLayout(sliderPanel, BoxLayout.PAGE_AXIS));7273sliderPanel.add(new JLabel("Canny threshold: "));74JSlider slider = new JSlider(0, MAX_THRESHOLD, threshold);75slider.setMajorTickSpacing(20);76slider.setMinorTickSpacing(10);77slider.setPaintTicks(true);78slider.setPaintLabels(true);79slider.addChangeListener(new ChangeListener() {80@Override81public void stateChanged(ChangeEvent e) {82JSlider source = (JSlider) e.getSource();83threshold = source.getValue();84update();85}86});87sliderPanel.add(slider);88pane.add(sliderPanel, BorderLayout.PAGE_START);8990JPanel imgPanel = new JPanel();91imgSrcLabel = new JLabel(new ImageIcon(img));92imgPanel.add(imgSrcLabel);9394Mat blackImg = Mat.zeros(srcGray.size(), CvType.CV_8U);95imgContoursLabel = new JLabel(new ImageIcon(HighGui.toBufferedImage(blackImg)));96imgPanel.add(imgContoursLabel);9798pane.add(imgPanel, BorderLayout.CENTER);99}100101private void update() {102/// Detect edges using Canny103Mat cannyOutput = new Mat();104Imgproc.Canny(srcGray, cannyOutput, threshold, threshold * 2);105106/// Find contours107List<MatOfPoint> contours = new ArrayList<>();108Mat hierarchy = new Mat();109Imgproc.findContours(cannyOutput, contours, hierarchy, Imgproc.RETR_TREE, Imgproc.CHAIN_APPROX_SIMPLE);110111/// Find the convex hull object for each contour112List<MatOfPoint> hullList = new ArrayList<>();113for (MatOfPoint contour : contours) {114MatOfInt hull = new MatOfInt();115Imgproc.convexHull(contour, hull);116117Point[] contourArray = contour.toArray();118Point[] hullPoints = new Point[hull.rows()];119List<Integer> hullContourIdxList = hull.toList();120for (int i = 0; i < hullContourIdxList.size(); i++) {121hullPoints[i] = contourArray[hullContourIdxList.get(i)];122}123hullList.add(new MatOfPoint(hullPoints));124}125126/// Draw contours + hull results127Mat drawing = Mat.zeros(cannyOutput.size(), CvType.CV_8UC3);128for (int i = 0; i < contours.size(); i++) {129Scalar color = new Scalar(rng.nextInt(256), rng.nextInt(256), rng.nextInt(256));130Imgproc.drawContours(drawing, contours, i, color);131Imgproc.drawContours(drawing, hullList, i, color );132}133134imgContoursLabel.setIcon(new ImageIcon(HighGui.toBufferedImage(drawing)));135frame.repaint();136}137}138139public class HullDemo {140public static void main(String[] args) {141// Load the native OpenCV library142System.loadLibrary(Core.NATIVE_LIBRARY_NAME);143144// Schedule a job for the event dispatch thread:145// creating and showing this application's GUI.146javax.swing.SwingUtilities.invokeLater(new Runnable() {147@Override148public void run() {149new Hull(args);150}151});152}153}154155156