please help me understand why:) My program reach the "try" line, but seems to skip the "catch", Although its printing the stacktrace... I'm using JOptionPane in my catch, but also System.out.println() not working. Code:
import java.awt.AWTException;
import java.awt.Rectangle;
import java.awt.Robot;
import java.awt.Toolkit;
import java.awt.image.BufferedImage;
import java.io.File;
import java.io.IOException;
import java.text.SimpleDateFormat;
import java.util.Calendar;
import javax.imageio.ImageIO;
import javax.swing.JOptionPane;
public class main {
public static void main(String[] args) {
SimpleDateFormat dateFormat = new SimpleDateFormat("dd.MM.yyyy");
Calendar cal = Calendar.getInstance();
String fileName = dateFormat.format(cal.getTime());
Rectangle rectangle = new Rectangle(Toolkit.getDefaultToolkit().getScreenSize());
BufferedImage bufferedImage;
try {
bufferedImage = new Robot().createScreenCapture(rectangle);
try
{
ImageIO.write(bufferedImage, "jpg", new File("c:/temp/ScrenShots/"+fileName+".jpg"));
} catch (IOException e)
{
JOptionPane frame = null;
JOptionPane.showMessageDialog(frame,"Failed to take screen-shot", "ScreenShots", JOptionPane.ERROR_MESSAGE);
e.printStackTrace();
}
} catch (AWTException e) {
JOptionPane frame = null;
JOptionPane.showMessageDialog(frame,"AWT Error", "ScreenShots", JOptionPane.ERROR_MESSAGE);
e.printStackTrace();
}
}
}
Exception:
java.io.FileNotFoundException: c:\temp\ScrenShots\20.10.2014.jpg (The system cannot find the path specified)
at java.io.RandomAccessFile.open(Native Method)
at java.io.RandomAccessFile.<init>(Unknown Source)
at javax.imageio.stream.FileImageOutputStream.<init>(Unknown Source)
at com.sun.imageio.spi.FileImageOutputStreamSpi.createOutputStreamInstance(Unknown Source)
at javax.imageio.ImageIO.createImageOutputStream(Unknown Source)
at javax.imageio.ImageIO.write(Unknown Source)
at main.main(main.java:26)
Exception in thread "main" java.lang.NullPointerException
at javax.imageio.ImageIO.write(Unknown Source)
at main.main(main.java:26)
There is an NullPointerException
internally just before the FileNotFoundException
From your log.
Exception in thread "main" java.lang.NullPointerException //*
at javax.imageio.ImageIO.write(Unknown Source)
at main.main(main.java:26)
You can make sure it from following. This code here only for point out the issue. catching NullPointerException
is a bad practice in coding.
try {
// current code
} catch (IOException e) {
// current code
}catch (NullPointerException e){
JOptionPane frame = null;
JOptionPane.showMessageDialog(frame, "NPE", "npe", JOptionPane.ERROR_MESSAGE);
}