![JAR search and dependency download from the Maven repository](/logo.png)
org.w3c.css.properties.css3.CssRenderIntent Maven / Gradle / Ivy
//
// $Id: CssRenderIntent.java,v 1.3 2010-01-05 13:49:54 ylafon Exp $
// From Sijtsche de Jong ([email protected])
//
// 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.css3;
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.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 if (val.equals(inherit)) {
renderintent = inherit;
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 (((Css3Style) style).cssRenderIntent != null)
style.addRedefinitionWarning(ac, this);
((Css3Style) 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 ((Css3Style) style).getRenderIntent();
} else {
return ((Css3Style) 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;
}
}