// // $Id: CssRenderIntent.java,v 1.2 2005/09/14 15:15:27 ylafon Exp $ // From Sijtsche de Jong (sy.de.jong@let.rug.nl) // // COPYRIGHT (c) 1995-2000 World Wide Web Consortium, (MIT, INRIA, Keio University) // Please first read the full copyright statement at // http://www.w3.org/Consortium/Legal/copyright-software-19980720 package org.w3c.css.properties.svg; import org.w3c.css.parser.CssStyle; import org.w3c.css.properties.css1.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.CssValue; /** *
* Value: auto || perceptual || relative-colorimetric ||
* saturation || absolute-colorimetric || inherit
* Initial:auto
* Applies to:all elements
* Inheritedyes
* Percentages:no
* Media:visual
*
* This property permits the specification of a color profile rendering intent other than the default.
* The behavior of values other than auto and inherent are defined by the International Color Consortium standard.
*/
public class CssRenderIntent extends CssProperty {
CssValue renderintent;
static CssIdent auto = new CssIdent("auto");
static CssIdent abscolorimetric = new CssIdent("absolute-colorimetric");
static CssIdent relcolorimetric = new CssIdent("relative-colorimetric");
static CssIdent saturation = new CssIdent("saturation");
static CssIdent perceptual = new CssIdent("perceptual");
/**
* Create a new CssRenderIntent
*/
public CssRenderIntent() {
renderintent = auto;
}
/**
* Create a new CssRenderIntent
*
*
*/
public CssRenderIntent(ApplContext ac, CssExpression expression,
boolean check) throws InvalidParamException {
setByUser();
CssValue val = expression.getValue();
if (val.equals(auto)) {
renderintent = auto;
expression.next();
}
else if (val.equals(perceptual)) {
renderintent = perceptual;
expression.next();
}
else if (val.equals(relcolorimetric)) {
renderintent = relcolorimetric;
expression.next();
}
else if (val.equals(saturation)) {
renderintent = saturation;
expression.next();
}
else if (val.equals(abscolorimetric)) {
renderintent = abscolorimetric;
expression.next();
}
else {
throw new InvalidParamException("value", val.toString(), getPropertyName(), ac);
}
}
public CssRenderIntent(ApplContext ac, CssExpression expression)
throws InvalidParamException {
this(ac, expression, false);
}
/**
* Add this property to the CssStyle.
*
* @param style The CssStyle
*/
public void addToStyle(ApplContext ac, CssStyle style) {
if (((SVGStyle) style).cssRenderIntent != null)
style.addRedefinitionWarning(ac, this);
((SVGStyle) style).cssRenderIntent = 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 ((SVGStyle) style).getRenderIntent();
} else {
return ((SVGStyle) style).cssRenderIntent;
}
}
/**
* Compares two properties for equality.
*
* @param value The other property.
*/
public boolean equals(CssProperty property) {
return (property instanceof CssRenderIntent &&
renderintent.equals( ((CssRenderIntent) property).renderintent));
}
/**
* Returns the name of this property
*/
public String getPropertyName() {
return "rendering-intent";
}
/**
* Returns the value of this property
*/
public Object get() {
return renderintent;
}
/**
* Returns true if this property is "softly" inherited
*/
public boolean isSoftlyInherited() {
return renderintent.equals(inherit);
}
/**
* Returns a string representation of the object
*/
public String toString() {
return renderintent.toString();
}
/**
* Is the value of this property a default value
* It is used by all macro for the function print
*/
public boolean isDefault() {
return renderintent == auto;
}
}