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

org.xhtmlrenderer.simple.XHTMLPanel Maven / Gradle / Ivy

Go to download

An XML/XHTML CSS 2.1 Renderer library in pure Java for rendering to PDF, images, and Swing panels.

The newest version!
/*
 * {{{ header & license
 * Copyright (c) 2004, 2005 Joshua Marinacci
 *
 * 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.
 * }}}
 */
package org.xhtmlrenderer.simple;

import java.io.File;
import java.io.InputStream;
import java.net.URL;

import org.w3c.dom.Document;
import org.xhtmlrenderer.extend.UserAgentCallback;
import org.xhtmlrenderer.layout.SharedContext;
import org.xhtmlrenderer.render.RenderingContext;
import org.xhtmlrenderer.simple.extend.FormSubmissionListener;
import org.xhtmlrenderer.simple.extend.XhtmlNamespaceHandler;
import org.xhtmlrenderer.swing.BasicPanel;
import org.xhtmlrenderer.swing.CursorListener;
import org.xhtmlrenderer.swing.HoverListener;
import org.xhtmlrenderer.swing.LinkListener;
import org.xhtmlrenderer.util.Configuration;

/**
 * 

*

* XHTMLPanel is a simple Swing component that renders valid XHTML content in a * Java program. It is scrolling aware so you can safely drop it into a * {@link javax.swing.JScrollPane}. The most common usage is to stuff a {@link URL} * into it and then add it to your JFrame. Ex:

*
 * import org.xhtmlrenderer.simple.*;
 * .....
 * 

* public static void main(String[] args) { *

* // set up the xhtml panel XHTMLPanel xhtml = new XHTMLPanel(); * xhtml.setDocument(new URL("http://myserver.com/page.xhtml")); *

* JScrollPane scroll = new JScrollPane(xhtml); * JFrame frame = new JFrame("Demo"); * frame.getContentPane().add(scroll); * frame.pack(); * frame.setSize(500,600); * frame.show(); * } *

*

*

XHTMLPanel renders XHTML and XML which can be loaded as valid {@link Document} * instances. You should make sure the document you want to render is well-formed. For XHTML, * there is always a default stylesheet available, even if no CSS is attached to the * XHTML you are loading. For XML, there is no default stylesheet, so you should have * one attached to your XML before trying to render it using the xml-stylesheer processing * instruction. XHTMLPanel has methods to load * documents from a uri ({@link #setDocument(String uri)}), * from a Document instance ({@link #setDocument(Document)}) or from an InputStream * ({@link org.xhtmlrenderer.swing.BasicPanel#setDocument(java.io.InputStream,String)}).

*

*

*

* XHTMLPanel also lets you make simple changes with simple methods like * {@link #setFontScalingFactor(float)}. If you want to make other changes you will * need to get the rendering context ({@link #getSharedContext()}) and call methods on * that. Ex:

*

*

 * XHTMLPanel xhtml = new XHTMLPanel();
 * RenderingContext ctx = xhtml.getRenderingContext();
 * ctx.setLogging(true); // turn on logging
 * ctx.setValidating(true); // turn on doctype validation
 * ctx.addFont(fnt,"Arial"); // redefine a font
 * ctx.setDomImplementation("com.cooldom.DomImpl");
 * 
*

*

XHTMLPanel comes with a pre-installed MouseListener which handles :hover events used for rollovers * ( @see org.xhtmlrenderer.swing.HoverListener ). XHTMLPanel also comes with a pre-installed LinkListener * used to follow links. ( @see org.xhtmlrenderer.swing.LinkListener ) * If you want to disable these for some reason you can * get the list of mouse listeners and remove them all. *

* * @author Joshua Marinacci ([email protected]) * @see The Flying Saucer Home Page * @see RenderingContext */ public class XHTMLPanel extends BasicPanel { private static final long serialVersionUID = 1L; private float fontScalingFactor = 1.2F; private float minFontScale = 0.50F; private float maxFontScale = 3.0F; /** * Instantiates an XHTMLPanel with no {@link Document} loaded by default. */ public XHTMLPanel() { setupListeners(); } /** * Instantiates a panel with a custom {@link org.xhtmlrenderer.extend.UserAgentCallback} * implementation. * * @param uac The custom UserAgentCallback implementation. */ public XHTMLPanel(UserAgentCallback uac) { super(uac); setupListeners(); } private void setupListeners() { if (Configuration.isTrue("xr.use.listeners", true)) { addMouseTrackingListener(new HoverListener()); addMouseTrackingListener(new LinkListener()); addMouseTrackingListener(new CursorListener()); setFormSubmissionListener(new FormSubmissionListener() { public void submit(String query) { XHTMLPanel.this.setDocumentRelative(query); } }); } } private void resetListeners() { if (Configuration.isTrue("xr.use.listeners", true)) { resetMouseTracker(); } } /** * Lays out the current document again, and re-renders. */ public void relayout() { sharedContext.flushFonts(); super.relayout(); } /** * Loads and renders a Document given a uri. * The uri is resolved by the UserAgentCallback * * @param uri */ public void setDocument(String uri) { setDocument(loadDocument(uri), uri); } /** * Renders an XML Document instance. * Make sure that no relative resources are needed * * @param doc The document to render. */ public void setDocument(Document doc) { setDocument(doc, ""); } /** * Renders a Document using a URL as a base URL for relative * paths. * * @param doc The new document value * @param url The new document value */ public void setDocument(Document doc, String url) { resetListeners(); setDocument(doc, url, new XhtmlNamespaceHandler()); } /** * Renders a Document read from an InputStream using a URL * as a base URL for relative paths. * * @param stream The stream to read the Document from. * @param url The URL used to resolve relative path references. */ // TODO: should throw more specific exception (PWW 25/07/2006) public void setDocument(InputStream stream, String url) throws Exception { resetListeners(); setDocument(stream, url, new XhtmlNamespaceHandler()); } /** * Renders a Document read from an InputStream using a URL * as a base URL for relative paths. * * @param file The file to read the Document from. Relative paths * will be resolved based on the file's parent directory. */ // TODO: should throw more specific exception (PWW 25/07/2006) public void setDocument(File file) throws Exception { resetListeners(); File parent = file.getAbsoluteFile().getParentFile(); String parentURL = ( parent == null ? "" : parent.toURI().toURL().toExternalForm()); setDocument( loadDocument(file.toURI().toURL().toExternalForm()), parentURL ); } /** * Sets the {@link RenderingContext} attribute of the XHTMLPanel object. Generally * you should not use this unless you have a heavily customized context to * use. To modify just some rendering behavior, consider using * {@link #getSharedContext()} to retrieve the current context, and using * mutators to change its behavior. * * @param ctx A new RenderingContext to use for rendering. */ public void setSharedContext(SharedContext ctx) { super.setSharedContext(ctx); } /** * Sets the scaling factor used by {@link #incrementFontSize()} and * {@link #decrementFontSize()}--both scale the font up or down by this * scaling factor. The scaling roughly modifies the font size as a multiplier * or divisor. A scaling factor of 1.2 applied against a font size of 10pt * results in a scaled font of 12pt. The default scaling factor is * 1.2F. */ public void setFontScalingFactor(float scaling) { fontScalingFactor = scaling; } /** * Increments all rendered fonts on the current document by the current * scaling factor for the panel. Scaling applies culmulatively, which means that * multiple calls to this method scale fonts larger and larger by applying the * current scaling factor against itself. You can modify the scaling factor by * {@link #setFontScalingFactor(float)}, and reset to the document's specified * font size with {@link #resetFontSize()}. */ public void incrementFontSize() { scaleFont(fontScalingFactor); } /** * Resets all rendered fonts on the current document to the font size * specified in the document's styling instructions. */ public void resetFontSize() { SharedContext rc = getSharedContext(); rc.getTextRenderer().setFontScale(1.0F); setDocument(getDocument()); } /** * Decrements all rendered fonts on the current document by the current * scaling factor for the panel. Scaling applies culmulatively, which means that * multiple calls to this method scale fonts smaller and smaller by applying the * current scaling factor against itself. You can modify the scaling factor by * {@link #setFontScalingFactor(float)}, and reset to the document's specified * font size with {@link #resetFontSize()}. */ public void decrementFontSize() { scaleFont(1 / fontScalingFactor); } /** * Applies a change in scale for fonts using the rendering context's text * renderer. */ private void scaleFont(float scaleBy) { SharedContext rc = getSharedContext(); float fs = rc.getTextRenderer().getFontScale() * scaleBy; if (fs < minFontScale || fs > maxFontScale) return; rc.getTextRenderer().setFontScale(fs); setDocument(getDocument()); } /** * Returns the maximum font scaling that may be applied, e.g. 3 times assigned font size. */ public float getMaxFontScale() { return maxFontScale; } /** * Returns the minimum font scaling that may be applied, e.g. 0.5 times assigned font size. */ public float getMinFontScale() { return minFontScale; } /** * Sets the maximum font scaling that may be applied, e.g. 3 times assigned font size. Calling incrementFontSize() * after this scale has been reached doesn't have an effect. */ public void setMaxFontScale(float f) { maxFontScale = f; } /** * Sets the minimum font scaling that may be applied, e.g. 3 times assigned font size. Calling decrementFontSize() * after this scale has been reached doesn't have an effect. */ public void setMinFontScale(float f) { minFontScale = f; } } /* * $Id$ * * $Log$ * Revision 1.45 2009/02/15 17:17:24 pdoubleya * Support for callback on form submission using new FormSubmissionListener interface; patch from Christophe Marchand (thanks, Christophe!). * * Revision 1.44 2008/05/30 16:07:06 pdoubleya * Issue 228: when setting document from a file, use file.getAbsoluteFile().getParentFile() to find the parent, in case the file provided has no directory or path; otherwise, file.getParentFile() returns null, and we have no way of determining a base URI. Covers at least the (reproducible) part of the issue. * * Revision 1.43 2008/01/22 21:27:06 pdoubleya * Fix on resetting font scaling factor--was using old relayout/repaint approach, which isn't consistent--easier to use setDocument(), which in any case uses the DOM already in memory. * * Revision 1.42 2007/06/29 06:05:48 pdoubleya * As of R7, a change to layout (like changing font size) requires a call to setDocument(). * * Revision 1.41 2007/05/24 19:56:51 peterbrant * Add support for cursor property (predefined cursors only) * * Patch from Sean Bright * * Revision 1.40 2007/05/24 13:22:38 peterbrant * Optimize and clean up hover and link listeners * * Patch from Sean Bright * * Revision 1.39 2007/05/21 21:58:47 peterbrant * More cleanup (remove experimental threading code) * * Revision 1.38 2007/05/20 23:25:32 peterbrant * Various code cleanups (e.g. remove unused imports) * * Patch from Sean Bright * * Revision 1.37 2007/02/07 16:33:31 peterbrant * Initial commit of rewritten table support and associated refactorings * * Revision 1.36 2006/10/06 18:52:29 pdoubleya * Fixed NPE when calling setDocument(File) and file has no parent directory; issue #134. * * Revision 1.35 2006/07/26 18:11:21 pdoubleya * TODO * * Revision 1.34 2006/04/07 07:29:05 pdoubleya * JavaDoc * * Revision 1.33 2006/04/05 09:40:32 pdoubleya * Removed commented code. * * Revision 1.32 2006/04/05 09:36:59 pdoubleya * Added overloaded setDocument(File). * * Revision 1.31 2006/01/09 23:24:53 peterbrant * Provide config key to not use link and hover listeners (one of which currently leaks memory horribly) * * Revision 1.30 2005/12/14 22:08:02 peterbrant * Make relayout() work again * * Revision 1.29 2005/10/27 00:09:07 tobega * Sorted out Context into RenderingContext and LayoutContext * * Revision 1.28 2005/10/26 17:01:44 peterbrant * Allow the "use threads" config property to be set on individual instances of * XHTMLPanel. * * Revision 1.27 2005/10/22 23:00:29 peterbrant * Fix memory leak (all box trees ever built remained in memory) * * Revision 1.26 2005/09/28 20:13:25 joshy * re-enabled body height hack * Issue number: * Obtained from: * Submitted by: * Reviewed by: * * Revision 1.25 2005/07/07 22:13:51 tobega * cleanup * * Revision 1.24 2005/06/20 17:26:44 joshy * debugging for image issues * font scale stuff * * Issue number: * Obtained from: * Submitted by: * Reviewed by: * * Revision 1.23 2005/06/19 23:31:33 joshy * stop layout support * clear bug fixes * mouse busy cursor support * * Issue number: * Obtained from: * Submitted by: * Reviewed by: * * Revision 1.22 2005/06/16 13:11:36 pdoubleya * Added limits on font scaling. * * Revision 1.21 2005/06/16 12:59:24 pdoubleya * Cleaned up support for reloading documents. * * Revision 1.20 2005/06/16 11:29:12 pdoubleya * First cut support for reload page, flushes inline stylesheets. * * Revision 1.19 2005/06/16 07:24:52 tobega * Fixed background image bug. * Caching images in browser. * Enhanced LinkListener. * Some house-cleaning, playing with Idea's code inspection utility. * * Revision 1.18 2005/06/15 10:56:14 tobega * cleaned up a bit of URL mess, centralizing URI-resolution and loading to UserAgentCallback * * Revision 1.17 2005/06/09 22:34:56 joshy * This makes the hover listener be added to the xhtml panel by default. * Also improves the box searching code by testing if the parent of the deepest * box is hoverable in the case where the deepest box is not. * * * Issue number: * Obtained from: * Submitted by: * Reviewed by: * * Revision 1.16 2005/06/01 21:36:43 tobega * Got image scaling working, and did some refactoring along the way * * Revision 1.15 2005/03/22 13:55:29 pdoubleya * Fixed missing throws declarations. * * Revision 1.14 2005/03/22 12:28:14 pdoubleya * Updated JavaDocs. * * */




© 2015 - 2024 Weber Informatics LLC | Privacy Policy