Skip to footer content
USING IRONPDF FOR JAVA

How to Preview PDF Files in Java

This article will demonstrate how to use IronPDF to preview PDF files within a Java application.

IronPDF

IronPDF is a high-performance Java library, offering fast and accurate operations, making it an excellent choice for PDF-related tasks such as reading PDF files, extracting text and images, merging, and splitting.

With the help of the IronPDF library, you can create PDFs from HTML, URLs, and strings with precise pixel-perfect rendering.

Prerequisites

To create a document viewer for PDF documents in Java, you need the following things set in place.

  1. JDK (Java Development Kit) and Swing UI framework installed.
  2. A Java IDE (Integrated Development Environment) such as Eclipse, NetBeans, or IntelliJ IDEA.
  3. IronPDF library for Java (You can download it from the IronPDF website and include it in your project).

Setting up

  1. Create a new Java project in your chosen IDE. I'm using IntelliJ IDEA and created the project using Maven.
  2. Add the IronPDF library to your project using Maven by adding the dependencies shown below in your project's pom.xml file:

    <!-- Add IronPDF dependency in your pom.xml -->
    <dependency>
        <groupId>com.ironsoftware</groupId>
        <artifactId>ironpdf</artifactId>
        <version>latest_version</version>
    </dependency>
    <!-- Add IronPDF dependency in your pom.xml -->
    <dependency>
        <groupId>com.ironsoftware</groupId>
        <artifactId>ironpdf</artifactId>
        <version>latest_version</version>
    </dependency>
    XML
  3. Add the necessary imports:

    import com.ironsoftware.ironpdf.PdfDocument;
    
    import javax.imageio.ImageIO;
    import javax.swing.*;
    import javax.swing.border.EmptyBorder;
    import java.awt.image.BufferedImage;
    import java.io.File;
    import java.io.IOException;
    import java.nio.file.Paths;
    import java.util.ArrayList;
    import java.util.List;
    import com.ironsoftware.ironpdf.PdfDocument;
    
    import javax.imageio.ImageIO;
    import javax.swing.*;
    import javax.swing.border.EmptyBorder;
    import java.awt.image.BufferedImage;
    import java.io.File;
    import java.io.IOException;
    import java.nio.file.Paths;
    import java.util.ArrayList;
    import java.util.List;
    JAVA

Loading the PDF File Format

To view PDF documents, the next step is to load the PDF file in this Java PDF viewer application by using the PdfDocument class.

public class PDFPreview extends JFrame {

    private List<String> imagePaths = new ArrayList<>();

    private List<String> ConvertToImages() throws IOException {
        // Load the PDF document from a file
        PdfDocument pdfDocument = PdfDocument.fromFile(Paths.get("example.pdf"));
        // Convert the PDF pages to a list of BufferedImages
        List<BufferedImage> extractedImages = pdfDocument.toBufferedImages();
        int i = 1;
        // Iterate over the extracted images and save each to an image file
        for (BufferedImage extractedImage : extractedImages) {
            String fileName = "assets/images/" + i + ".png";
            ImageIO.write(extractedImage, "PNG", new File(fileName));
            // Store the file paths in the image paths list
            imagePaths.add("assets/images/" + i + ".png");
            i++;
        }
        return imagePaths;
    }
}
public class PDFPreview extends JFrame {

    private List<String> imagePaths = new ArrayList<>();

    private List<String> ConvertToImages() throws IOException {
        // Load the PDF document from a file
        PdfDocument pdfDocument = PdfDocument.fromFile(Paths.get("example.pdf"));
        // Convert the PDF pages to a list of BufferedImages
        List<BufferedImage> extractedImages = pdfDocument.toBufferedImages();
        int i = 1;
        // Iterate over the extracted images and save each to an image file
        for (BufferedImage extractedImage : extractedImages) {
            String fileName = "assets/images/" + i + ".png";
            ImageIO.write(extractedImage, "PNG", new File(fileName));
            // Store the file paths in the image paths list
            imagePaths.add("assets/images/" + i + ".png");
            i++;
        }
        return imagePaths;
    }
}
JAVA

How to Preview PDF Files in Java, Figure 1: The output PDF file The output PDF file

Converted to Images:

How to Preview PDF Files in Java, Figure 2: Convert PDF file to images Convert PDF file to images

Creating PDF Viewer Window

Now, you can display the converted images in a preview window using Java Swing components.

public class PDFPreview extends JFrame {
    private JPanel imagePanel;
    private JScrollPane scrollPane;

    public PDFPreview() {
        try {
            // Convert the PDF to images and store the image paths
            imagePaths = this.ConvertToImages();
        } catch (Exception e) {
            e.printStackTrace();
        }

        // Create imagePanel
        imagePanel = new JPanel();
        imagePanel.setLayout(new BoxLayout(imagePanel, BoxLayout.Y_AXIS));

        // Add images to the panel
        for (String imagePath : imagePaths) {
            ImageIcon imageIcon = new ImageIcon(imagePath);
            JLabel imageLabel = new JLabel(imageIcon);
            imageLabel.setBorder(new EmptyBorder(10, 10, 10, 10));
            imagePanel.add(imageLabel);
        }

        // Create the scroll pane and add imagePanel to it
        scrollPane = new JScrollPane(imagePanel);
        scrollPane.setVerticalScrollBarPolicy(JScrollPane.VERTICAL_SCROLLBAR_ALWAYS);

        // Set up the frame
        getContentPane().add(scrollPane);
        setTitle("PDF Viewer");
        setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
        pack();
        setLocationRelativeTo(null);
        setVisible(true);
    }
}
public class PDFPreview extends JFrame {
    private JPanel imagePanel;
    private JScrollPane scrollPane;

    public PDFPreview() {
        try {
            // Convert the PDF to images and store the image paths
            imagePaths = this.ConvertToImages();
        } catch (Exception e) {
            e.printStackTrace();
        }

        // Create imagePanel
        imagePanel = new JPanel();
        imagePanel.setLayout(new BoxLayout(imagePanel, BoxLayout.Y_AXIS));

        // Add images to the panel
        for (String imagePath : imagePaths) {
            ImageIcon imageIcon = new ImageIcon(imagePath);
            JLabel imageLabel = new JLabel(imageIcon);
            imageLabel.setBorder(new EmptyBorder(10, 10, 10, 10));
            imagePanel.add(imageLabel);
        }

        // Create the scroll pane and add imagePanel to it
        scrollPane = new JScrollPane(imagePanel);
        scrollPane.setVerticalScrollBarPolicy(JScrollPane.VERTICAL_SCROLLBAR_ALWAYS);

        // Set up the frame
        getContentPane().add(scrollPane);
        setTitle("PDF Viewer");
        setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
        pack();
        setLocationRelativeTo(null);
        setVisible(true);
    }
}
JAVA

Invoke the Main class Constructor

Finally, place the following code in the main method in the PDFPreview class:

public static void main(String[] args) {
    // Run the PDF viewer in the Event Dispatch Thread
    SwingUtilities.invokeLater(
        PDFPreview::new
    );
}
public static void main(String[] args) {
    // Run the PDF viewer in the Event Dispatch Thread
    SwingUtilities.invokeLater(
        PDFPreview::new
    );
}
JAVA

Code Explanation

  1. PDFPreview extends JFrame, a top-level container for window creation.
  2. Instance variables declared: imagePanel, scrollPane, and imagePaths.
  3. ConvertToImages() takes in PDF file example.pdf, and converts it to a series of images. The PdfDocument loads the PDF file and converts each page to a BufferedImage, then saves each as a PNG in the assets/images/ directory and adds the paths to imagePaths.
  4. PDFPreview() initializes the application. It calls ConvertToImages() to populate imagePaths.
  5. imagePanel is initialized and sets its layout as a vertical box layout.
  6. It iterates over imagePaths and creates ImageIcon for each image, adds them to JLabel, and adds labels to imagePanel.
  7. The source code creates JScrollPane and sets imagePanel as its viewport.
  8. Next, the code adds scrollPane to the frame's content pane, sets frame's title, sets default close operation, packs components, centers frame on the screen, and makes it visible.
  9. main() is the entry point of the program. It invokes the PDFPreview constructor using SwingUtilities.invokeLater() to ensure the Swing components are created and modified on the Event Dispatch Thread, the dedicated thread for GUI operations.

Now, execute the program and the PDF document file viewer will be displayed with the loaded PDF document.

How to Preview PDF Files in Java, Figure 3: The output PDF file The output PDF file

Conclusion

This article demonstrated how to use IronPDF for Java-based applications to preview PDF files within a Java application, and how to access and display a PDF file.

With IronPDF, you can easily integrate PDF preview functionality into your Java application. For detailed guidance and examples on utilizing IronPDF for Java, you can refer to this example. For the Java PDF reader tutorial visit this article to read PDF files.

IronPDF is free for development purposes. To learn more about the licensing details, you can visit the provided licensing page. A free trial for commercial use is also available.

Frequently Asked Questions

What is this Java library used for PDF tasks?

IronPDF for Java is a high-performance Java library designed for fast and accurate operations related to PDF tasks, such as reading, extracting text and images, merging, and splitting PDF files.

What are the prerequisites for creating a PDF viewer in Java?

To create a PDF viewer using IronPDF in Java, you need to have JDK and the Swing UI framework installed, a Java IDE like Eclipse, NetBeans, or IntelliJ IDEA, and the IronPDF library for Java included in your project.

How can I add the PDF library to my Java project?

You can add IronPDF to your Java project by including it in your project's pom.xml file as a Maven dependency with the group ID 'com.ironsoftware' and the artifact ID 'ironpdf'.

How do I convert PDF pages to images?

You can convert PDF pages to images using IronPDF by loading the PDF document with the PdfDocument class and converting each page to a BufferedImage, then saving them as image files.

How can I display PDF pages as images in a Java application?

You can display PDF pages as images in a Java application by using Java Swing components to create a window with a JPanel and JScrollPane to hold and scroll through the images.

What is the purpose of the ConvertToImages method in the PDF viewer code?

The ConvertToImages method in the PDF viewer code loads a PDF document, converts its pages to images, saves them as PNG files, and stores the paths of these images for display.

What is the significance of using SwingUtilities.invokeLater in the main method?

Using SwingUtilities.invokeLater ensures that the Swing components are created and modified on the Event Dispatch Thread, which is the dedicated thread for GUI operations in Java.

Is this Java PDF library free to use for development?

Yes, IronPDF is free to use for development purposes. A free trial for commercial use is also available.

Where can I find more examples and tutorials on using this Java PDF library?

You can find more examples and tutorials on using IronPDF for Java on the IronPDF website, including guides on creating PDFs from HTML and reading PDF files.

Darrius Serrant
Full Stack Software Engineer (WebOps)

Darrius Serrant holds a Bachelor’s degree in Computer Science from the University of Miami and works as a Full Stack WebOps Marketing Engineer at Iron Software. Drawn to coding from a young age, he saw computing as both mysterious and accessible, making it the perfect medium for creativity and problem-solving.

At Iron Software, Darrius enjoys creating new things and simplifying complex concepts to make them more understandable. As one of our resident developers, he has also volunteered to teach students, sharing his expertise with the next generation.

For Darrius, his work is fulfilling because it is valued and has a real impact.

Install with Maven

Version: 2025.6.5

<dependency>
  <groupId>com.ironsoftware</groupId>
  <artifactId>ironpdf</artifactId>
  <version>2025.6.5</version>
</dependency>
Talk to an Expert Five Star Trust Score Rating

Ready to Get Started?