All Downloads are FREE. Search and download functionalities are using the official Maven repository.

erer.flying-saucer-examples.9.9.4.source-code.JPanelSizeToDocument Maven / Gradle / Ivy

There is a newer version: 9.11.2
Show newest version
/*
 * {{{ header & license
 * Copyright (c) 2008 Patrick Wright
 *
 * This program is free software; you can redistribute it and/or
 * modify it under the terms of the GNU Lesser General Public License
 * as published by the Free Software Foundation; either version 2.1
 * of the License, or (at your option) any later version.
 *
 * This program is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
 * GNU Lesser General Public License for more details.
 *
 * You should have received a copy of the GNU Lesser General Public License
 * along with this program; if not, write to the Free Software
 * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
 * }}}
 */


import org.xhtmlrenderer.event.DefaultDocumentListener;
import org.xhtmlrenderer.simple.XHTMLPanel;
import org.xhtmlrenderer.util.XRLog;

import javax.swing.*;
import java.awt.*;
import java.io.File;
import java.util.logging.Level;

/**
 * This example shows how to render a document as a Swing JPanel (XHTMLPanel, a subclass) and have the
 * render engine figure out the document size for you; the frame containing the panel is then sized to
 * the document size. To run this sample from the command line, make sure you have the Flying Saucer
 * JARs in the classpath; arguments to the program are a URL or file path, and optionally, a target width
 * for the document (width defaults to 800 otherwise):
 * java -jar core-renderer.jar JPanelSizeToDocument myHtml.html 1024
 *
 * @author Patrick Wright
 */
public class JPanelSizeToDocument {
    private String fileName;
    private int targetWidth = 800;

    public static void main(String[] args) {
        new JPanelSizeToDocument().run(args);
    }

    private void run(String[] args) {
        loadAndCheckArgs(args);
        SwingUtilities.invokeLater(() -> launchGUI());
    }

    private void launchGUI() {
        final JFrame frame = new JFrame();
        frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);

        // Create a JPanel subclass to render the page
        final XHTMLPanel panel = new XHTMLPanel();
        final Dimension orgSize = panel.getSize();

        // we'll add a listener to note the preferred size as calculated by the render engine
        panel.addDocumentListener(new DefaultDocumentListener() {
            public void documentLoaded() {
                frame.setTitle("Flying Saucer: " + panel.getDocumentTitle());

                final Dimension dim = panel.getPreferredSize();
                XRLog.general("Preferred size" + dim);
            }
        });

        frame.getContentPane().add(panel);

        // Set the XHTML document to render. We use the simplest form
        // of the API call, which uses a File reference. There
        // are a variety of overloads for setDocument().
        try {
            panel.setDocument(new File(fileName));
        } catch (Exception e) {
            XRLog.general(Level.WARNING, "Could not load XHTML document " + fileName, e);
            messageAndExit("Failed to load document");
        }

        // No-op as regards size, but has side effect of making the window and components "displayable". This is
        // necessary for the doDocumentLayout() below to work correctly. Alternately you could setVisible(true), but
        // then the document would be visible before the resize was completed.
        frame.pack();

        // Here we set an artificially large size for the document to let the render engine
        // figure out what the document needs based on content.
        //
        // Note that if the document itself has no fixed width, text will not automatically break and will
        // likely run out and extend the document width as far as necessary to accommodate the longest line of text
        // you could either set a max width in a document box, or you can set it here.
        //
        // The document height will be calculated automatically based on content. We use an artificially large size
        // here to not constrain the layout algorithm.
        panel.setSize(targetWidth, 10000);
        panel.doDocumentLayout(panel.getGraphics());
        panel.setSize(orgSize);
        frame.pack();
        frame.setVisible(true);
    }

    private void loadAndCheckArgs(String[] args) {
        if (args.length == 0) {
            messageAndExit("Enter a file or URI.");
        }
        String name = args[0];
        if (!new File(name).exists()) {
            messageAndExit("File " + name + " does not exist.");
        }
        this.fileName = name;

        if (args.length > 1) {
            String widthVal = args[1];
            try {
                targetWidth = Integer.parseInt(widthVal);
            } catch (NumberFormatException e) {
                messageAndExit("Target width " + widthVal + " is not an integer");
            }
        }
    }

    private void messageAndExit(String msg) {
        System.out.println(msg);
        System.exit(-1);
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy