Я получаю nullPointerError в CascadeClassifier в triDetect. Мне нужно написать код, чтобы найти количество кругов, треугольников, прямоугольников и линий. Пожалуйста, не жарите этот код, это ужасно, но мне действительно нужна помощь. Если у вас есть какие-либо предложения или помощь, пожалуйста, дайте любой совет, который вы можете. Мне нужно, чтобы это было сделано в ближайшие два дня (сегодня 15 июня 2019 года), поэтому, если прошло, вам не нужно тратить время на это. Пожалуйста, предложите любую помощь, чтобы сделать это лучше и решить мою проблему. Спасибо.
Я пытался изменить каскадный классификатор на другие вещи, но я считаю, что это лучший способ. Пожалуйста, помогите.
public class main extends JComponent implements MouseInputListener {
static int rects = 0;
static int triangles = 0;
static int circles = 0;
static int lines = 0;
public static void main(String[] args) throws AWTException, IOException {
System.loadLibrary( Core.NATIVE_LIBRARY_NAME );
Robot robot = new Robot();
Rectangle screenSize = new Rectangle(Toolkit.getDefaultToolkit().getScreenSize());
BufferedImage image = robot.createScreenCapture(screenSize);
JFrame window = new JFrame("Image Recognition");
main run = new main();
window.add(run, BorderLayout.CENTER);
window.pack();
window.setDefaultCloseOperation(WindowConstants.EXIT_ON_CLOSE);
window.setVisible(true);
window.setSize(300,500); //300,500
window.addMouseListener(run);
ImageIcon icon = new ImageIcon(image);
JLabel lbl=new JLabel();
lbl.setIcon(icon);
window.add(lbl);
window.repaint();
File outputFile = new File("image.jpg");
ImageIO.write(image, "jpg", outputFile);
File input = new File("C:\\Users\\ericl\\eclipse-workspace\\ImageRecognition\\image.jpg");
BufferedImage buffImage = ImageIO.read(input);
BufferedImage imageCopy =
new BufferedImage(buffImage.getWidth(), buffImage.getHeight(), BufferedImage.TYPE_3BYTE_BGR);
imageCopy.getGraphics().drawImage(buffImage, 0, 0, null);
byte[] data = ((DataBufferByte) imageCopy.getRaster().getDataBuffer()).getData();
Mat mat = new Mat(image.getHeight(),image.getWidth(), CvType.CV_8UC3);
mat.put(0, 0, data);
Imgcodecs.imwrite("C:\\Users\\ericl\\eclipse-workspace\\ImageRecognition\\input.jpg", mat);
new main().detectTris(mat);
window.repaint();
}
public void detectTris(Mat mat) {
System.out.println("\nRunning detection");
CascadeClassifier shapeDetector = new CascadeClassifier(getClass().getResource("C:\\Users\\ericl\\eclipse-workspace\\OpenCVImageRecognition\\shapes\\triEx.jpg").getPath());
MatOfRect triDetections = new MatOfRect();
shapeDetector.detectMultiScale(mat, triDetections);
System.out.println(String.format("Detected %s triangles", triDetections.toArray().length));
}
public void paint(Graphics g) {
String strRect = String.valueOf(rects);
String strTri = String.valueOf(triangles);
String strCirc = String.valueOf(circles);
String strLine = String.valueOf(lines);
g.setColor(Color.white);
g.fillRect(90,10,200,400);
g.setColor(Color.red);
g.setFont(new Font("Comic Sans", Font.PLAIN, 80));
g.drawString(strRect, 100, 100);
g.drawString(strTri, 100, 200);
g.drawString(strCirc, 100, 300);
g.drawString(strLine, 100, 400);
g.fillRect(200, 40, 60, 60);
int y[] = {200,150,200};
int x[] = {200,230,260};
g.fillPolygon(x,y, 3);
g.fillOval(200, 240, 55, 55);
g.fillRect(220, 340, 5, 60);
}
}
Ожидается, что выводом будет окно с количеством каждой фигуры из скриншота красным.