org.w3c.css.properties.css2.CssBackgroundAttachmentCSS2 Maven / Gradle / Ivy
The newest version!
//
// $Id: CssBackgroundAttachmentCSS2.java,v 1.2 2010-01-05 19:49:50 ylafon Exp $
// 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.css2;
import org.w3c.css.parser.CssStyle;
import org.w3c.css.properties.css.CssBackgroundAttachment;
import org.w3c.css.properties.css.CssProperty;
import org.w3c.css.properties.css1.Css1Style;
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;
import java.util.HashMap;
/**
*
* 'background-attachment'
*
*
* Value: scroll | fixed
* Initial: scroll
* Applies to: all elements
* Inherited: no
* Percentage values: N/A
*
* If a background image is specified, the value of 'background-attachment'
* determines if it is fixed with regard to the canvas or if it scrolls along
* with the content.
*
* BODY {
* background: red url(pendant.gif);
* background-repeat: repeat-y;
* background-attachment: fixed;
* }
*
*
* @version $Revision: 1.2 $
*/
public class CssBackgroundAttachmentCSS2 extends CssBackgroundAttachment {
public static boolean checkMatchingIdent(CssIdent ident) {
return allowed_values.containsValue(ident);
}
private static HashMap allowed_values;
private static CssIdent scroll;
static {
allowed_values = new HashMap();
scroll = CssIdent.getIdent("scroll");
allowed_values.put("scroll", scroll);
allowed_values.put("fixed", CssIdent.getIdent("fixed"));
}
CssIdent value;
/**
* Create a new CssBackgroundAttachmentCSS2
*/
public CssBackgroundAttachmentCSS2() {
value = scroll;
}
/**
* Creates a new CssBackgroundAttachmentCSS2
*
* @param expression The expression for this property
* @throws InvalidParamException Values are incorrect
*/
public CssBackgroundAttachmentCSS2(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.getType() == CssTypes.CSS_IDENT) {
if (inherit.equals(val)) {
value = inherit;
expression.next();
return;
}
CssIdent new_val = allowed_values.get(val.toString());
if (new_val != null) {
value = new_val;
expression.next();
return;
}
}
throw new InvalidParamException("value", expression.getValue(),
getPropertyName(), ac);
}
public CssBackgroundAttachmentCSS2(ApplContext ac, CssExpression expression)
throws InvalidParamException {
this(ac, expression, false);
}
/**
* Returns the value of this property
*/
public Object get() {
return value;
}
/**
* Returns true if this property is "softly" inherited
* e.g. his value equals inherit
*/
public boolean isSoftlyInherited() {
return (inherit == value);
}
/**
* Returns a string representation of the object.
*/
public String toString() {
return value.toString();
}
/**
* Add this property to the CssStyle.
*
* @param style The CssStyle
*/
public void addToStyle(ApplContext ac, CssStyle style) {
CssBackgroundCSS2 cssBackground = ((Css1Style) style).cssBackgroundCSS2;
if (cssBackground.attachment != null)
style.addRedefinitionWarning(ac, this);
cssBackground.attachment = 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).getBackgroundAttachmentCSS2();
} else {
return ((Css1Style) style).cssBackgroundCSS2.attachment;
}
}
/**
* Compares two properties for equality.
*
* @param property The other property.
*/
public boolean equals(CssProperty property) {
return (property instanceof CssBackgroundAttachmentCSS2 &&
value == ((CssBackgroundAttachmentCSS2) property).value);
}
/**
* Is the value of this property is a default value.
* It is used by all macro for the function print
*/
public boolean isDefault() {
return (scroll == value);
}
}