// // $Id: CssBackgroundImageCSS1.java,v 1.3 2005/09/14 15:14:31 ylafon Exp $ // From Philippe Le Hegaret (Philippe.Le_Hegaret@sophia.inria.fr) // // (c) COPYRIGHT MIT and INRIA, 1997. // Please first read the full copyright statement in file COPYRIGHT.html package org.w3c.css.properties.css1; import org.w3c.css.parser.CssStyle; import org.w3c.css.util.ApplContext; import org.w3c.css.util.InvalidParamException; import org.w3c.css.values.CssExpression; import org.w3c.css.values.CssIdent; import org.w3c.css.values.CssURL; import org.w3c.css.values.CssValue; /** *

*    'background-image' *

*

* Value: <url> | none
* Initial: none
* Applies to: all elements
* Inherited: no
* Percentage values: N/A
*

This property sets the background image of an element. When setting a * background image, one should also set a background color that will be used * when the image is unavailable. When the image is available, it is overlaid * on top of the background color. *

 *   BODY { background-image: url(marble.gif) }
 *   P { background-image: none }
 *   
* @version $Revision: 1.3 $ */ public class CssBackgroundImageCSS1 extends CssProperty { CssValue url; private static CssIdent none = new CssIdent("none"); /** * Create a new CssBackgroundImageCSS1 */ public CssBackgroundImageCSS1() { url = none; } /** * Creates a new CssBackgroundImageCSS1 * * @param expression The expression for this property * @exception InvalidParamException Values are incorrect */ public CssBackgroundImageCSS1(ApplContext ac, CssExpression expression, boolean check) throws InvalidParamException { if(check && expression.getCount() > 1) { throw new InvalidParamException("unrecognize", ac); } setByUser(); CssValue val = expression.getValue(); if (val instanceof CssURL) { url = val; expression.next(); } else if (val.equals(none)) { url = none; expression.next(); } else { throw new InvalidParamException("value", expression.getValue(), getPropertyName(), ac); } } public CssBackgroundImageCSS1(ApplContext ac, CssExpression expression) throws InvalidParamException { this(ac, expression, false); } /** * Returns the value of this property */ public Object get() { return url; } /** * Returns true if this property is "softly" inherited * e.g. his value equals inherit */ public boolean isSoftlyInherited() { if (url != null) { return url.equals(inherit); } return false; } /** * Returns a string representation of the object. */ public String toString() { if (url != null) { return url.toString(); } return ""; } /** * Returns the name of this property */ public String getPropertyName() { return "background-image"; } /** * Add this property to the CssStyle. * * @param style The CssStyle */ public void addToStyle(ApplContext ac, CssStyle style) { CssBackgroundCSS1 cssBackground = ((Css1Style) style).cssBackgroundCSS1; if (cssBackground.image != null) style.addRedefinitionWarning(ac, this); cssBackground.image = this; } /** * Get this property in the style. * * @param style The style where the property is * @param resolve if true, resolve the style to find this property */ public CssProperty getPropertyInStyle(CssStyle style, boolean resolve) { if (resolve) { return ((Css1Style) style).getBackgroundImageCSS1(); } else { return ((Css1Style) style).cssBackgroundCSS1.image; } } /** * Compares two properties for equality. * * @param value The other property. */ public boolean equals(CssProperty property) { return ((url == null && property == null) || (property instanceof CssBackgroundImageCSS1 && url != null && url.equals(((CssBackgroundImageCSS1) property).url))); } /** * Is the value of this property is a default value. * It is used by all macro for the function print */ public boolean isDefault() { return url == none; } }