⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 basichtml.java

📁 Mobile 应用程序使用 Java Micro Edition (Java ME) 平台
💻 JAVA
📖 第 1 页 / 共 2 页
字号:
/* * @(#)BasicHTML.java	1.27 06/04/07 * * Copyright 2006 Sun Microsystems, Inc. All rights reserved. * SUN PROPRIETARY/CONFIDENTIAL. Use is subject to license terms. */package javax.swing.plaf.basic;import java.io.*;import java.awt.*;import java.net.URL;import javax.swing.*;import javax.swing.text.*;import javax.swing.text.html.*;import sun.swing.SwingUtilities2;/** * Support for providing html views for the swing components. * This translates a simple html string to a javax.swing.text.View * implementation that can render the html and provide the necessary * layout semantics. * * @author  Timothy Prinzing * @version 1.27 04/07/06 * @since 1.3 */public class BasicHTML {    /**     * Create an html renderer for the given component and     * string of html.     */    public static View createHTMLView(JComponent c, String html) {	BasicEditorKit kit = getFactory();	Document doc = kit.createDefaultDocument(c.getFont(),                                                 c.getForeground());	Object base = c.getClientProperty(documentBaseKey);	if (base instanceof URL) {	    ((HTMLDocument)doc).setBase((URL)base);	}	Reader r = new StringReader(html);	try {	    kit.read(r, doc, 0);	} catch (Throwable e) {	}	ViewFactory f = kit.getViewFactory();	View hview = f.create(doc.getDefaultRootElement());	View v = new Renderer(c, f, hview);	return v;    }    /**     * Returns the baseline for the html renderer.     *     * @param view the View to get the baseline for     * @param w the width to get the baseline for     * @param h the height to get the baseline for     * @throws IllegalArgumentException if width or height is &lt; 0     * @return baseline or a value &lt; 0 indicating there is no reasonable     *                  baseline     * @see java.awt.FontMetrics     * @see javax.swing.JComponent#getBaseline(int,int)     * @since 1.6     */    public static int getHTMLBaseline(View view, int w, int h) {        if (w < 0 || h < 0) {            throw new IllegalArgumentException(                    "Width and height must be >= 0");        }        if (view instanceof Renderer) {            return getBaseline(view.getView(0), w, h);        }        return -1;    }    /**     * Gets the baseline for the specified component.  This digs out     * the View client property, and if non-null the baseline is calculated     * from it.  Otherwise the baseline is the value <code>y + ascent</code>.     */    static int getBaseline(JComponent c, int y, int ascent,                                  int w, int h) {        View view = (View)c.getClientProperty(BasicHTML.propertyKey);        if (view != null) {            int baseline = getHTMLBaseline(view, w, h);            if (baseline < 0) {                return baseline;            }            return y + baseline;        }        return y + ascent;    }    /**     * Gets the baseline for the specified View.     */    static int getBaseline(View view, int w, int h) {        if (hasParagraph(view)) {            view.setSize(w, h);            return getBaseline(view, new Rectangle(0, 0, w, h));        }        return -1;    }    private static int getBaseline(View view, Shape bounds) {        if (view.getViewCount() == 0) {            return -1;        }        AttributeSet attributes = view.getElement().getAttributes();        Object name = null;        if (attributes != null) {            name = attributes.getAttribute(StyleConstants.NameAttribute);        }        int index = 0;        if (name == HTML.Tag.HTML && view.getViewCount() > 1) {            // For html on widgets the header is not visible, skip it.            index++;        }        bounds = view.getChildAllocation(index, bounds);        if (bounds == null) {            return -1;        }        View child = view.getView(index);        if (view instanceof javax.swing.text.ParagraphView) {            Rectangle rect;            if (bounds instanceof Rectangle) {                rect = (Rectangle)bounds;            }            else {                rect = bounds.getBounds();            }            return rect.y + (int)(rect.height *                                  child.getAlignment(View.Y_AXIS));        }        return getBaseline(child, bounds);    }    private static boolean hasParagraph(View view) {        if (view instanceof javax.swing.text.ParagraphView) {            return true;        }        if (view.getViewCount() == 0) {            return false;        }        AttributeSet attributes = view.getElement().getAttributes();        Object name = null;        if (attributes != null) {            name = attributes.getAttribute(StyleConstants.NameAttribute);        }        int index = 0;        if (name == HTML.Tag.HTML && view.getViewCount() > 1) {            // For html on widgets the header is not visible, skip it.            index = 1;        }        return hasParagraph(view.getView(index));    }    /**     * Check the given string to see if it should trigger the     * html rendering logic in a non-text component that supports      * html rendering.     */    public static boolean isHTMLString(String s) {	if (s != null) {	    if ((s.length() >= 6) && (s.charAt(0) == '<') && (s.charAt(5) == '>')) {		String tag = s.substring(1,5);		return tag.equalsIgnoreCase(propertyKey);	    }	}	return false;    }    /**     * Stash the HTML render for the given text into the client     * properties of the given JComponent. If the given text is      * <em>NOT HTML</em> the property will be cleared of any     * renderer.     * <p>     * This method is useful for ComponentUI implementations     * that are static (i.e. shared) and get their state     * entirely from the JComponent.     */    public static void updateRenderer(JComponent c, String text) {	View value = null;        View oldValue = (View)c.getClientProperty(BasicHTML.propertyKey);        Boolean htmlDisabled = (Boolean) c.getClientProperty(htmlDisable);	if (htmlDisabled != Boolean.TRUE && BasicHTML.isHTMLString(text)) {	    value = BasicHTML.createHTMLView(c, text);	}        if (value != oldValue && oldValue != null) {            for (int i = 0; i < oldValue.getViewCount(); i++) {                oldValue.getView(i).setParent(null);            }        }	c.putClientProperty(BasicHTML.propertyKey, value);    }    /**     * If this client property of a JComponent is set to Boolean.TRUE     * the component's 'text' property is never treated as HTML.     */    private static final String htmlDisable = "html.disable";    /**     * Key to use for the html renderer when stored as a      * client property of a JComponent.     */    public static final String propertyKey = "html";    /**     * Key stored as a client property to indicate the base that relative     * references are resolved against. For example, lets say you keep     * your images in the directory resources relative to the code path,     * you would use the following the set the base:     * <pre>     *   jComponent.putClientProperty(documentBaseKey,     *                                xxx.class.getResource("resources/"));     * </pre>     */    public static final String documentBaseKey = "html.base";    static BasicEditorKit getFactory() {	if (basicHTMLFactory == null) {            basicHTMLViewFactory = new BasicHTMLViewFactory();	    basicHTMLFactory = new BasicEditorKit();	}	return basicHTMLFactory;    }    /**     * The source of the html renderers     */    private static BasicEditorKit basicHTMLFactory;    /**     * Creates the Views that visually represent the model.     */    private static ViewFactory basicHTMLViewFactory;    /**     * Overrides to the default stylesheet.  Should consider     * just creating a completely fresh stylesheet.     */    private static final String styleChanges =     "p { margin-top: 0; margin-bottom: 0; margin-left: 0; margin-right: 0 }" +    "body { margin-top: 0; margin-bottom: 0; margin-left: 0; margin-right: 0 }";    /**     * The views produced for the ComponentUI implementations aren't     * going to be edited and don't need full html support.  This kit     * alters the HTMLEditorKit to try and trim things down a bit.       * It does the following:     * <ul>     * <li>It doesn't produce Views for things like comments,      * head, title, unknown tags, etc.       * <li>It installs a different set of css settings from the default     * provided by HTMLEditorKit.     * </ul>     */    static class BasicEditorKit extends HTMLEditorKit {	/** Shared base style for all documents created by us use. */	private static StyleSheet defaultStyles;	/**	 * Overriden to return our own slimmed down style sheet.	 */	public StyleSheet getStyleSheet() {	    if (defaultStyles == null) {		defaultStyles = new StyleSheet();		StringReader r = new StringReader(styleChanges);		try {		    defaultStyles.loadRules(r, null);		} catch (Throwable e) {		    // don't want to die in static initialization... 		    // just display things wrong.		}		r.close();		defaultStyles.addStyleSheet(super.getStyleSheet());	    }	    return defaultStyles;	}	/**	 * Sets the async policy to flush everything in one chunk, and	 * to not display unknown tags.	 */        public Document createDefaultDocument(Font defaultFont,                                              Color foreground) {	    StyleSheet styles = getStyleSheet();	    StyleSheet ss = new StyleSheet();	    ss.addStyleSheet(styles);	    BasicDocument doc = new BasicDocument(ss, defaultFont, foreground);	    doc.setAsynchronousLoadPriority(Integer.MAX_VALUE);	    doc.setPreservesUnknownTags(false);	    return doc;	}        /**         * Returns the ViewFactory that is used to make sure the Views don't         * load in the background.         */        public ViewFactory getViewFactory() {            return basicHTMLViewFactory;        }    }    /**     * BasicHTMLViewFactory extends HTMLFactory to force images to be loaded     * synchronously.     */    static class BasicHTMLViewFactory extends HTMLEditorKit.HTMLFactory {

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -