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

w3c.css.properties.css1.CssBackgroundImage Maven / Gradle / Ivy

There is a newer version: 1.0.8
Show newest version
//
// $Id$
// From Philippe Le Hegaret ([email protected])
//
// (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.properties.css.CssProperty;
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.CssTypes;
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$ */ public class CssBackgroundImage extends org.w3c.css.properties.css.CssBackgroundImage { CssValue url = null; protected static boolean checkMatchingIdent(CssIdent ident) { return none.equals(ident); } /** * Create a new CssBackgroundImage */ public CssBackgroundImage() { url = none; } /** * Creates a new CssBackgroundImage * * @param expression The expression for this property * @throws InvalidParamException Values are incorrect */ public CssBackgroundImage(ApplContext ac, CssExpression expression, boolean check) throws InvalidParamException { if (check && expression.getCount() > 1) { throw new InvalidParamException("unrecognize", ac); } setByUser(); CssValue val = expression.getValue(); switch (val.getType()) { case CssTypes.CSS_URL: url = val; break; case CssTypes.CSS_IDENT: if (none.equals(val)) { url = none; break; } default: throw new InvalidParamException("value", val, getPropertyName(), ac); } expression.next(); } public CssBackgroundImage(ApplContext ac, CssExpression expression) throws InvalidParamException { this(ac, expression, false); } /** * Returns a string representation of the object. */ public String toString() { return url.toString(); } /** * Add this property to the CssStyle. * * @param style The CssStyle */ public void addToStyle(ApplContext ac, CssStyle style) { org.w3c.css.properties.css.CssBackground cssBackground = ((Css1Style) style).cssBackground; 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).getBackgroundImage(); } else { return ((Css1Style) style).cssBackground.image; } } /** * Compares two properties for equality. * * @param property The other property. */ public boolean equals(CssProperty property) { return ((url == null && property == null) || (property instanceof CssBackgroundImage && url != null && url.equals(((CssBackgroundImage) property).url))); } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy