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

org.netbeans.modules.javahelp.BrowserDisplayer Maven / Gradle / Ivy

There is a newer version: RELEASE240
Show newest version
/*
 * Licensed to the Apache Software Foundation (ASF) under one
 * or more contributor license agreements.  See the NOTICE file
 * distributed with this work for additional information
 * regarding copyright ownership.  The ASF licenses this file
 * to you under the Apache License, Version 2.0 (the
 * "License"); you may not use this file except in compliance
 * with the License.  You may obtain a copy of the License at
 *
 *   http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing,
 * software distributed under the License is distributed on an
 * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
 * KIND, either express or implied.  See the License for the
 * specific language governing permissions and limitations
 * under the License.
 */

package org.netbeans.modules.javahelp;

import com.sun.java.help.impl.ViewAwareComponent;
import java.awt.Color;
import java.awt.Cursor;
import java.awt.Font;
import java.awt.FontMetrics;
import java.awt.Insets;
import java.awt.datatransfer.Clipboard;
import java.awt.datatransfer.Transferable;
import java.awt.event.ActionListener;
import java.awt.event.ActionEvent;
import java.awt.event.MouseEvent;
import java.awt.event.MouseListener;
import javax.swing.JButton;
import javax.swing.UIManager;
import javax.swing.SwingConstants;
import javax.swing.border.EmptyBorder;
import javax.swing.text.html.HTMLDocument;
import javax.swing.text.html.StyleSheet;
import javax.swing.text.AttributeSet;
import javax.swing.text.StyleConstants;
import javax.swing.text.SimpleAttributeSet;
import javax.swing.text.View;
import java.net.MalformedURLException;
import java.net.URL;

import javax.swing.JPopupMenu;
import org.netbeans.modules.javahelp.CopyLinkLocationAction.LinkOwner;
import org.openide.awt.HtmlBrowser;
import org.openide.util.NbBundle;

/**
 * This class is a lightweight component to be included in HTML content within
 * JHContentViewer. It invokes default IDE html browser to show external URL.
 * (Default browser should be external browser to show external URL properly.
 * Component is displayed as a mouse enabled Label. Only text is supported.
 * 

* To use this class within HTML content use the <object> tag. Below is an * example usage: *

 * <object CLASSID="java:org.netbeans.module.javahelp.BrowserDisplayer">
 * <param name="content" value="http://www.netbeans.org">
 * <param name="text" value="Click here">
 * <param name="textFontFamily" value="SansSerif">
 * <param name="textFontSize" value="x-large">
 * <param name="textFontWeight" value="plain">
 * <param name="textFontStyle" value="italic">
 * <param name="textColor" value="red">
 * </object>
 * 

* Valid parameters are: *

    *
  • content - a valid external url like http://java.sun.com * @see setContent *
  • text - the text of the activator * @see setText *
  • textFontFamily - the font family of the activator text * @see setTextFontFamily *
  • textFontSize - the size of the activator text font. Size is specified * in a css terminology. See the setTextFontSize for acceptable syntax. * @see setTextFontSize *
  • textFontWeight - the activator text font weight * @see setTextFontWeight *
  • textFontStyle - the activator text font style * @see setTextFontStyle *
  • textColor - the activator text color * @see setTextColor *
      * * @author Marek Slama */ public class BrowserDisplayer extends JButton implements ActionListener, ViewAwareComponent, LinkOwner { private View myView; private SimpleAttributeSet textAttribs; private HTMLDocument doc; private URL base; private final static Cursor handCursor = Cursor.getPredefinedCursor(Cursor.HAND_CURSOR); private Cursor origCursor; private JPopupMenu popupMenu; /** * Create a secondaryviewer. By default the viewer creates a button with * the text of ">" */ public BrowserDisplayer() { super(); setMargin(new Insets(0,0,0,0)); createLinkLabel(); addActionListener(this); origCursor = getCursor(); getAccessibleContext().setAccessibleDescription( NbBundle.getMessage(BrowserDisplayer.class,"ACSD_Label")); this.popupMenu = HyperlinkEventProcessor.getPopupMenu( new CopyLinkLocationAction(this)); addMouseListener(new MouseListener() { public void mouseClicked(MouseEvent e) { setToolTipText(null); if (Utils.isMouseRightClick(e)) { Utils.showPopupMenu(e, popupMenu, BrowserDisplayer.this); } } public void mouseEntered(MouseEvent e) { setCursor(handCursor); setToolTipText(getContent()); } public void mouseExited(MouseEvent e) { setCursor(origCursor); setToolTipText(null); } public void mousePressed(MouseEvent e) { } public void mouseReleased(MouseEvent e) { } }); } /** * Sets data optained from the View */ public void setViewData(View v) { myView = v; doc = (HTMLDocument) myView.getDocument(); base = doc.getBase(); // Set the current font information in the local text attributes Font font = getFont(); textAttribs = new SimpleAttributeSet(); textAttribs.removeAttribute(StyleConstants.FontSize); textAttribs.removeAttribute(StyleConstants.Bold); textAttribs.removeAttribute(StyleConstants.Italic); textAttribs.addAttribute(StyleConstants.FontFamily, font.getName()); textAttribs.addAttribute(StyleConstants.FontSize, new Integer(font.getSize())); textAttribs.addAttribute(StyleConstants.Bold, Boolean.valueOf(font.isBold())); textAttribs.addAttribute(StyleConstants.Italic, Boolean.valueOf(font.isItalic())); } /** * properties */ private String content = ""; /** * Set the content for the secondary viewer * @param content a valid URL */ public void setContent(String content) { this.content = content; } /** * Returns the content of the secondary viewer */ public String getContent() { return content; } /** * Creates a link label. A link label is a form of a JButton but without a * button like appearance. */ private void createLinkLabel() { setBorder(new EmptyBorder(1,1,1,1)); setBorderPainted(false); setFocusPainted(false); setAlignmentY(getPreferredAlignmentY()); setContentAreaFilled(false); setHorizontalAlignment(SwingConstants.LEFT); setBackground(UIManager.getColor("EditorPane.background")); if (textAttribs != null && textAttribs.isDefined(StyleConstants.Foreground)) { setForeground((Color)textAttribs.getAttribute(StyleConstants.Foreground)); } else { setForeground(Color.blue); } invalidate(); } /** * Determine the alignment offset so the text is aligned with other views * correctly. */ private float getPreferredAlignmentY() { // Fix for the Issue #68316 Font font = getFont(); FontMetrics fm = getToolkit().getFontMetrics(font); float h = fm.getHeight(); float d = fm.getDescent(); return (h - d) / h; // Original implementation below is commented out due to Issue #68316. // It tries also take into account a size of the icon, but according to javadoc // of the class "Only text is supported". // Original implementation is commented out below due to the bug #68316. // It tries also to take into account a size of the icon, but according to // javadoc of the class "Only text is supported". // // Icon icon = (Icon)getIcon(); // String text = getText(); // // Font font = getFont(); // FontMetrics fm = getToolkit().getFontMetrics(font); // // Rectangle iconR = new Rectangle(); // Rectangle textR = new Rectangle(); // Rectangle viewR = new Rectangle(Short.MAX_VALUE, Short.MAX_VALUE); // // SwingUtilities.layoutCompoundLabel( // this, fm, text, icon, // getVerticalAlignment(), getHorizontalAlignment(), // getVerticalTextPosition(), getHorizontalTextPosition(), // viewR, iconR, textR, // (text == null ? 0 : ((BasicButtonUI)ui).getDefaultTextIconGap(this)) // ); // // // The preferred size of the button is the size of // // the text and icon rectangles plus the buttons insets. // Rectangle r = iconR.union(textR); // // Insets insets = getInsets(); // r.height += insets.top + insets.bottom; // // // Ensure that the height of the button is odd, // // to allow for the focus line. // if(r.height % 2 == 0) { // r.height += 1; // } // // float offAmt = fm.getMaxAscent() + insets.top; // return offAmt/(float)r.height; } /** * Sets the text Font family for the activator text. * For JDK 1.1 this must a family name of Dialog, DialogInput, Monospaced, * Serif, SansSerif, or Symbol. */ public void setTextFontFamily(String family) { textAttribs.removeAttribute(StyleConstants.FontFamily); textAttribs.addAttribute(StyleConstants.FontFamily, family); setFont(getAttributeSetFont(textAttribs)); Font font = getFont(); } /** * Returns the text Font family name of the activator text */ public String getTextFontFamily() { return StyleConstants.getFontFamily(textAttribs); } /** * Sets the text size for the activator text. * The String size is a valid Cascading Style Sheet value for * text size. Acceptable values are as follows: *
        *
      • xx-small *
      • x-small *
      • small *
      • medium *
      • large *
      • x-large *
      • xx-large *
      • bigger - increase the current base font size by 1 *
      • smaller - decrease the current base font size by 1 *
      • xxpt - set the font size to a specific pt value of "xx" *
      • +x - increase the current base font size by a value of "x" *
      • -x - decrease the current base font size by a value of "x" *
      • x - set the font size to the point size associated with * the index "x" *
      */ public void setTextFontSize(String size) { int newsize; StyleSheet css = doc.getStyleSheet(); try { if (size.equals("xx-small")) { newsize = (int)css.getPointSize(0); } else if (size.equals("x-small")) { newsize = (int)css.getPointSize(1); } else if (size.equals("small")) { newsize = (int)css.getPointSize(2); } else if (size.equals("medium")) { newsize = (int)css.getPointSize(3); } else if (size.equals("large")) { newsize = (int)css.getPointSize(4); } else if (size.equals("x-large")) { newsize = (int)css.getPointSize(5); } else if (size.equals("xx-large")) { newsize = (int)css.getPointSize(6); } else if (size.equals("bigger")) { newsize = (int)css.getPointSize("+1"); } else if (size.equals("smaller")) { newsize = (int)css.getPointSize("-1"); } else if (size.endsWith("pt")) { String sz = size.substring(0, size.length() - 2); newsize = Integer.parseInt(sz); } else { newsize = (int) css.getPointSize(size); } } catch (NumberFormatException nfe) { return; } if (newsize == 0) { return; } textAttribs.removeAttribute(StyleConstants.FontSize); textAttribs.addAttribute(StyleConstants.FontSize, new Integer(newsize)); setFont(getAttributeSetFont(textAttribs)); Font font = getFont(); } /** * Returns the text Font family name of the activator text */ public String getTextFontSize() { return Integer.toString(StyleConstants.getFontSize(textAttribs)); } /** * Sets the text Font Weigth for the activator text. * Valid weights are *
        *
      • plain *
      • bold *
      */ public void setTextFontWeight(String weight) { boolean isBold=false; if ("bold".equals(weight)) { isBold = true; } else { isBold = false; } textAttribs.removeAttribute(StyleConstants.Bold); textAttribs.addAttribute(StyleConstants.Bold, Boolean.valueOf(isBold)); setFont(getAttributeSetFont(textAttribs)); Font font = getFont(); } /** * Returns the text Font weight of the activator text */ public String getTextFontWeight() { if (StyleConstants.isBold(textAttribs)) { return "bold"; } return "plain"; } /** * Sets the text Font Style for the activator text. * Valid font styles are *
        *
      • plain *
      • italic *
      */ public void setTextFontStyle(String style) { boolean isItalic=false; if ("italic".equals(style)) { isItalic = true; } else { isItalic = false; } textAttribs.removeAttribute(StyleConstants.Italic); textAttribs.addAttribute(StyleConstants.Italic, Boolean.valueOf(isItalic)); setFont(getAttributeSetFont(textAttribs)); Font font = getFont(); } /** * Returns the text Font style of the activator text */ public String getTextFontStyle() { if (StyleConstants.isItalic(textAttribs)) { return "italic"; } return "plain"; } /** * Sets the text Color for the activator text. * The following is a list of supported Color names *
        *
      • black *
      • blue *
      • cyan *
      • darkGray *
      • gray *
      • green *
      • lightGray *
      • magenta *
      • orange *
      • pink *
      • red *
      • white *
      • yellow *
      */ public void setTextColor(String name) { Color color=null; if ("black".equals(name)) { color = Color.black; } else if ("blue".equals(name)) { color = Color.blue; } else if ("cyan".equals(name)) { color = Color.cyan; } else if ("darkGray".equals(name)) { color = Color.darkGray; } else if ("gray".equals(name)) { color = Color.gray; } else if ("green".equals(name)) { color = Color.green; } else if ("lightGray".equals(name)) { color = Color.lightGray; } else if ("magenta".equals(name)) { color = Color.magenta; } else if ("orange".equals(name)) { color = Color.orange; } else if ("pink".equals(name)) { color = Color.pink; } else if ("red".equals(name)) { color = Color.red; } else if ("white".equals(name)) { color = Color.white; } else if ("yellow".equals(name)) { color = Color.yellow; } if (color == null) { return; } textAttribs.removeAttribute(StyleConstants.Foreground); textAttribs.addAttribute(StyleConstants.Foreground, color); setForeground(color); } /** * Returns the text Color of the activator text */ public String getTextColor() { Color color = getForeground(); return color.toString(); } /** * Gets the font from an attribute set. This is * implemented to try and fetch a cached font * for the given AttributeSet, and if that fails * the font features are resolved and the * font is fetched from the low-level font cache. * Font's are cached in the StyleSheet of a document * * @param attr the attribute set * @return the font */ private Font getAttributeSetFont(AttributeSet attr) { // PENDING(prinz) add cache behavior int style = Font.PLAIN; if (StyleConstants.isBold(attr)) { style |= Font.BOLD; } if (StyleConstants.isItalic(attr)) { style |= Font.ITALIC; } String family = StyleConstants.getFontFamily(attr); int size = StyleConstants.getFontSize(attr); /** * if either superscript or subscript is * is set, we need to reduce the font size * by 2. */ if (StyleConstants.isSuperscript(attr) || StyleConstants.isSubscript(attr)) { size -= 2; } // fonts are cached in the StyleSheet so use that return doc.getStyleSheet().getFont(family, style, size); } /** * Displays the viewer according to the viewerType */ public void actionPerformed(ActionEvent e) { URL link; try { link = new URL(content); } catch (MalformedURLException exc) { //XXX log something to ide.log?? return; } HtmlBrowser.URLDisplayer.getDefault().showURL(link); } public String getURLExternalForm() { return getContent(); } public Clipboard getClipboard() { return this.getToolkit().getSystemClipboard(); } public void lostOwnership(Clipboard clipboard, Transferable contents) { // do nothing } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy