- All Implemented Interfaces:
- Serializable,- AbstractDocument.AttributeContext
public class StyleSheet extends StyleContext
toString method is required
 to return a string representation of CSS value.
 
 The primary entry point for HTML View implementations
 to get their attributes is the
 getViewAttributes
 method.  This should be implemented to establish the
 desired policy used to associate attributes with the view.
 Each HTMLEditorKit (i.e. and therefore each associated
 JEditorPane) can have its own StyleSheet, but by default one
 sheet will be shared by all of the HTMLEditorKit instances.
 HTMLDocument instance can also have a StyleSheet, which
 holds the document-specific CSS specifications.
 
In order for Views to store less state and therefore be more lightweight, the StyleSheet can act as a factory for painters that handle some of the rendering tasks. This allows implementations to determine what they want to cache and have the sharing potentially at the level that a selector is common to multiple views. Since the StyleSheet may be used by views over multiple documents and typically the HTML attributes don't effect the selector being used, the potential for sharing is significant.
The rules are stored as named styles, and other information is stored to translate the context of an element to a rule quickly. The following code fragment will display the named styles, and therefore the CSS rules contained.
  
   import java.util.*;
   import javax.swing.text.*;
   import javax.swing.text.html.*;
  
   public class ShowStyles {
  
       public static void main(String[] args) {
         HTMLEditorKit kit = new HTMLEditorKit();
         HTMLDocument doc = (HTMLDocument) kit.createDefaultDocument();
         StyleSheet styles = doc.getStyleSheet();
  
         Enumeration rules = styles.getStyleNames();
         while (rules.hasMoreElements()) {
             String name = (String) rules.nextElement();
             Style rule = styles.getStyle(name);
             System.out.println(rule.toString());
         }
         System.exit(0);
       }
   }
  
 
 The semantics for when a CSS style should overide visual attributes
 defined by an element are not well defined. For example, the html
 <body bgcolor=red> makes the body have a red
 background. But if the html file also contains the CSS rule
 body { background: blue } it becomes less clear as to
 what color the background of the body should be. The current
 implementation gives visual attributes defined in the element the
 highest precedence, that is they are always checked before any styles.
 Therefore, in the previous example the background would have a
 red color as the body element defines the background color to be red.
 
 As already mentioned this supports CSS. We don't support the full CSS
 spec. Refer to the javadoc of the CSS class to see what properties
 we support. The two major CSS parsing related
 concepts we do not currently
 support are pseudo selectors, such as A:link { color: red },
 and the important modifier.
- Implementation Note:
- This implementation is currently incomplete. It can be replaced with alternative implementations that are complete. Future versions of this class will provide better CSS support.
- 
Nested Class SummaryNested Classes Modifier and Type Class Description static classStyleSheet.BoxPainterClass to carry out some of the duties of CSS formatting.static classStyleSheet.ListPainterClass to carry out some of the duties of CSS list formatting.Nested classes/interfaces declared in class javax.swing.text.StyleContextStyleContext.NamedStyle, StyleContext.SmallAttributeSet
- 
Field Summary
- 
Constructor SummaryConstructors Constructor Description StyleSheet()Construct a StyleSheet
- 
Method SummaryModifier and Type Method Description AttributeSetaddAttribute(AttributeSet old, Object key, Object value)Adds an attribute to the given set, and returns the new representative set.AttributeSetaddAttributes(AttributeSet old, AttributeSet attr)Adds a set of attributes to the element.voidaddCSSAttribute(MutableAttributeSet attr, CSS.Attribute key, String value)Adds a CSS attribute to the given set.booleanaddCSSAttributeFromHTML(MutableAttributeSet attr, CSS.Attribute key, String value)Adds a CSS attribute to the given set.voidaddRule(String rule)Adds a set of rules to the sheet.voidaddStyleSheet(StyleSheet ss)Adds the rules from the StyleSheetssto those of the receiver.protected MutableAttributeSetcreateLargeAttributeSet(AttributeSet a)Creates a large set of attributes that should trade off space for time.protected StyleContext.SmallAttributeSetcreateSmallAttributeSet(AttributeSet a)Creates a compact set of attributes that might be shared.ColorgetBackground(AttributeSet a)Takes a set of attributes and turn it into a background color specification.URLgetBase()Returns the base.StyleSheet.BoxPaintergetBoxPainter(AttributeSet a)Fetches the box formatter to use for the given set of CSS attributes.AttributeSetgetDeclaration(String decl)Translates a CSS declaration to an AttributeSet that represents the CSS declaration.FontgetFont(AttributeSet a)Fetches the font to use for the given set of attributes.ColorgetForeground(AttributeSet a)Takes a set of attributes and turn it into a foreground color specification.static intgetIndexOfSize(float pt)Returns the index of HTML/CSS size model.StyleSheet.ListPaintergetListPainter(AttributeSet a)Fetches the list formatter to use for the given set of CSS attributes.floatgetPointSize(int index)Returns the point size, given a size index.floatgetPointSize(String size)Given a string such as "+2", "-2", or "2", returns a point size value.StylegetRule(String selector)Fetches the rule that best matches the selector given in string form.StylegetRule(HTML.Tag t, Element e)Fetches the style to use to render the given type of HTML tag.StyleSheet[]getStyleSheets()Returns an array of the linked StyleSheets.AttributeSetgetViewAttributes(View v)Fetches a set of attributes to use in the view for displaying.voidimportStyleSheet(URL url)Imports a style sheet fromurl.voidloadRules(Reader in, URL ref)Loads a set of rules that have been specified in terms of CSS1 grammar.AttributeSetremoveAttribute(AttributeSet old, Object key)Removes an attribute from the set.AttributeSetremoveAttributes(AttributeSet old, Enumeration<?> names)Removes a set of attributes for the element.AttributeSetremoveAttributes(AttributeSet old, AttributeSet attrs)Removes a set of attributes.voidremoveStyle(String nm)Removes a named style previously added to the document.voidremoveStyleSheet(StyleSheet ss)Removes the StyleSheetssfrom those of the receiver.voidsetBase(URL base)Sets the base.voidsetBaseFontSize(int sz)Sets the base font size, with valid values between 1 and 7.voidsetBaseFontSize(String size)Sets the base font size from the passed in String.ColorstringToColor(String string)Converts a color string such as "RED" or "#NNNNNN" to a Color.AttributeSettranslateHTMLToCSS(AttributeSet htmlAttrSet)Converts a set of HTML attributes to an equivalent set of CSS attributes.Methods declared in class javax.swing.text.StyleContextaddChangeListener, addStyle, getChangeListeners, getCompressionThreshold, getDefaultStyleContext, getEmptySet, getFont, getFontMetrics, getStaticAttribute, getStaticAttributeKey, getStyle, getStyleNames, readAttributes, readAttributeSet, reclaim, registerStaticAttributeKey, removeChangeListener, toString, writeAttributes, writeAttributeSet
- 
Constructor Details- 
StyleSheetpublic StyleSheet()Construct a StyleSheet
 
- 
- 
Method Details- 
getRuleFetches the style to use to render the given type of HTML tag. The element given is representing the tag and can be used to determine the nesting for situations where the attributes will differ if nesting inside of elements.- Parameters:
- t- the type to translate to visual attributes
- e- the element representing the tag; the element can be used to determine the nesting for situations where the attributes will differ if nested inside of other elements
- Returns:
- the set of CSS attributes to use to render the tag
 
- 
getRuleFetches the rule that best matches the selector given in string form. Whereselectoris a space separated String of the element names. For example,selectormight be 'html body tr td''The attributes of the returned Style will change as rules are added and removed. That is if you to ask for a rule with a selector "table p" and a new rule was added with a selector of "p" the returned Style would include the new attributes from the rule "p". - Parameters:
- selector- a space separated String of the element names.
- Returns:
- the rule that best matches the selector.
 
- 
addRuleAdds a set of rules to the sheet. The rules are expected to be in valid CSS format. Typically this would be called as a result of parsing a <style> tag.- Parameters:
- rule- a set of rules
 
- 
getDeclarationTranslates a CSS declaration to an AttributeSet that represents the CSS declaration. Typically this would be called as a result of encountering an HTML style attribute.- Parameters:
- decl- a CSS declaration
- Returns:
- a set of attributes that represents the CSS declaration.
 
- 
loadRulesLoads a set of rules that have been specified in terms of CSS1 grammar. If there are collisions with existing rules, the newly specified rule will win.- Parameters:
- in- the stream to read the CSS grammar from
- ref- the reference URL. This value represents the location of the stream and may be null. All relative URLs specified in the stream will be based upon this parameter.
- Throws:
- IOException- if I/O error occured.
 
- 
getViewAttributesFetches a set of attributes to use in the view for displaying. This is basically a set of attributes that can be used for View.getAttributes.- Parameters:
- v- a view
- Returns:
- the of attributes
 
- 
removeStyleRemoves a named style previously added to the document.- Overrides:
- removeStylein class- StyleContext
- Parameters:
- nm- the name of the style to remove
 
- 
addStyleSheetAdds the rules from the StyleSheetssto those of the receiver.ss'srules will override the rules of any previously added style sheets. An added StyleSheet will never override the rules of the receiving style sheet.- Parameters:
- ss- a StyleSheet
- Since:
- 1.3
 
- 
removeStyleSheetRemoves the StyleSheetssfrom those of the receiver.- Parameters:
- ss- a StyleSheet
- Since:
- 1.3
 
- 
getStyleSheetsReturns an array of the linked StyleSheets. Will return null if there are no linked StyleSheets.- Returns:
- an array of StyleSheets.
- Since:
- 1.3
 
- 
importStyleSheetImports a style sheet fromurl. The resulting rules are directly added to the receiver. If you do not want the rules to become part of the receiver, create a new StyleSheet and use addStyleSheet to link it in.- Parameters:
- url- an url
- Since:
- 1.3
 
- 
setBaseSets the base. All import statements that are relative, will be relative tobase.- Parameters:
- base- a base.
- Since:
- 1.3
 
- 
getBaseReturns the base.- Returns:
- the base.
- Since:
- 1.3
 
- 
addCSSAttributeAdds a CSS attribute to the given set.- Parameters:
- attr- a set of attributes
- key- a CSS property
- value- an HTML attribute value
- Since:
- 1.3
 
- 
addCSSAttributeFromHTMLAdds a CSS attribute to the given set.- Parameters:
- attr- a set of attributes
- key- a CSS property
- value- an HTML attribute value
- Returns:
- trueif an HTML attribute- valuecan be converted to a CSS attribute, false otherwise.
- Since:
- 1.3
 
- 
translateHTMLToCSSConverts a set of HTML attributes to an equivalent set of CSS attributes.- Parameters:
- htmlAttrSet- AttributeSet containing the HTML attributes.
- Returns:
- the set of CSS attributes.
 
- 
addAttributeAdds an attribute to the given set, and returns the new representative set. This is reimplemented to convert StyleConstant attributes to CSS prior to forwarding to the superclass behavior. The StyleConstants attribute has no corresponding CSS entry, the StyleConstants attribute is stored (but will likely be unused).- Specified by:
- addAttributein interface- AbstractDocument.AttributeContext
- Overrides:
- addAttributein class- StyleContext
- Parameters:
- old- the old attribute set
- key- the non-null attribute key
- value- the attribute value
- Returns:
- the updated attribute set
- See Also:
- MutableAttributeSet.addAttribute(java.lang.Object, java.lang.Object)
 
- 
addAttributesAdds a set of attributes to the element. If any of these attributes are StyleConstants attributes, they will be converted to CSS prior to forwarding to the superclass behavior.- Specified by:
- addAttributesin interface- AbstractDocument.AttributeContext
- Overrides:
- addAttributesin class- StyleContext
- Parameters:
- old- the old attribute set
- attr- the attributes to add
- Returns:
- the updated attribute set
- See Also:
- MutableAttributeSet.addAttribute(java.lang.Object, java.lang.Object)
 
- 
removeAttributeRemoves an attribute from the set. If the attribute is a StyleConstants attribute, the request will be converted to a CSS attribute prior to forwarding to the superclass behavior.- Specified by:
- removeAttributein interface- AbstractDocument.AttributeContext
- Overrides:
- removeAttributein class- StyleContext
- Parameters:
- old- the old set of attributes
- key- the non-null attribute name
- Returns:
- the updated attribute set
- See Also:
- MutableAttributeSet.removeAttribute(java.lang.Object)
 
- 
removeAttributesRemoves a set of attributes for the element. If any of the attributes is a StyleConstants attribute, the request will be converted to a CSS attribute prior to forwarding to the superclass behavior.- Specified by:
- removeAttributesin interface- AbstractDocument.AttributeContext
- Overrides:
- removeAttributesin class- StyleContext
- Parameters:
- old- the old attribute set
- names- the attribute names
- Returns:
- the updated attribute set
- See Also:
- MutableAttributeSet.removeAttributes(java.util.Enumeration<?>)
 
- 
removeAttributesRemoves a set of attributes. If any of the attributes is a StyleConstants attribute, the request will be converted to a CSS attribute prior to forwarding to the superclass behavior.- Specified by:
- removeAttributesin interface- AbstractDocument.AttributeContext
- Overrides:
- removeAttributesin class- StyleContext
- Parameters:
- old- the old attribute set
- attrs- the attributes
- Returns:
- the updated attribute set
- See Also:
- MutableAttributeSet.removeAttributes(java.util.Enumeration<?>)
 
- 
createSmallAttributeSetCreates a compact set of attributes that might be shared. This is a hook for subclasses that want to alter the behavior of SmallAttributeSet. This can be reimplemented to return an AttributeSet that provides some sort of attribute conversion.- Overrides:
- createSmallAttributeSetin class- StyleContext
- Parameters:
- a- The set of attributes to be represented in the the compact form.
- Returns:
- a compact set of attributes that might be shared
 
- 
createLargeAttributeSetCreates a large set of attributes that should trade off space for time. This set will not be shared. This is a hook for subclasses that want to alter the behavior of the larger attribute storage format (which is SimpleAttributeSet by default). This can be reimplemented to return a MutableAttributeSet that provides some sort of attribute conversion.- Overrides:
- createLargeAttributeSetin class- StyleContext
- Parameters:
- a- The set of attributes to be represented in the the larger form.
- Returns:
- a large set of attributes that should trade off space for time
 
- 
getFontFetches the font to use for the given set of attributes.- Overrides:
- getFontin class- StyleContext
- Parameters:
- a- the attribute set
- Returns:
- the font
 
- 
getForegroundTakes a set of attributes and turn it into a foreground color specification. This might be used to specify things like brighter, more hue, etc.- Overrides:
- getForegroundin class- StyleContext
- Parameters:
- a- the set of attributes
- Returns:
- the color
 
- 
getBackgroundTakes a set of attributes and turn it into a background color specification. This might be used to specify things like brighter, more hue, etc.- Overrides:
- getBackgroundin class- StyleContext
- Parameters:
- a- the set of attributes
- Returns:
- the color
 
- 
getBoxPainterFetches the box formatter to use for the given set of CSS attributes.- Parameters:
- a- a set of CSS attributes
- Returns:
- the box formatter.
 
- 
getListPainterFetches the list formatter to use for the given set of CSS attributes.- Parameters:
- a- a set of CSS attributes
- Returns:
- the list formatter.
 
- 
setBaseFontSizepublic void setBaseFontSize(int sz)Sets the base font size, with valid values between 1 and 7.- Parameters:
- sz- a font size.
 
- 
setBaseFontSizeSets the base font size from the passed in String. The string can either identify a specific font size, with legal values between 1 and 7, or identify a relative font size such as +1 or -2.- Parameters:
- size- a font size.
 
- 
getIndexOfSizepublic static int getIndexOfSize(float pt)Returns the index of HTML/CSS size model.- Parameters:
- pt- a size of point
- Returns:
- the index of HTML/CSS size model.
 
- 
getPointSizepublic float getPointSize(int index)Returns the point size, given a size index.- Parameters:
- index- a size index
- Returns:
- the point size value.
 
- 
getPointSizeGiven a string such as "+2", "-2", or "2", returns a point size value.- Parameters:
- size- a CSS string describing font size
- Returns:
- the point size value.
 
- 
stringToColorConverts a color string such as "RED" or "#NNNNNN" to a Color. Note: This will only convert the HTML3.2 color strings or a string of length 7; otherwise, it will return null.- Parameters:
- string- color string such as "RED" or "#NNNNNN"
- Returns:
- the color
 
 
-