org.w3c.css.properties.css3.CssBaselineShift Maven / Gradle / Ivy
//
// $Id: CssBaselineShift.java,v 1.3 2010-01-05 13:49:49 ylafon Exp $
// From Sijtsche de Jong ([email protected])
//
// (c) COPYRIGHT 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.CssLength;
import org.w3c.css.values.CssPercentage;
import org.w3c.css.values.CssValue;
/**
*
* Value: baseline || sub || super || <percentage> || <length> || inherit
* Initial:baseline
* Applies to:inline-level elements
* Inherited:no
* Percentages:refers to the 'line-height' of the element
* Media::visual
*
* The 'baseline-shift' property allows repositioning of the dominant-baseline
* relative to the dominant-baseline. The shifted object might be a sub- or
* superscript. Within the shifted object, the whole baseline table is offset;
* not just a single baseline. For sub- and superscript, the amount of offset
* is determined from the nominal font of the parent.
*/
public class CssBaselineShift extends CssProperty {
CssValue baselineshift;
private static CssIdent baseline = new CssIdent("baseline");
private static CssIdent sub = new CssIdent("sub");
private static CssIdent sup = new CssIdent("super");
private static CssIdent initial = new CssIdent("initial");
/**
* Create a new CssBaselineShift
*/
public CssBaselineShift() {
baselineshift = baseline;
}
/**
* Create a new CssBaselineShift
*
* @param expression The expression for this property
* @exception InvalidParamException Incorrect value
*/
public CssBaselineShift(ApplContext ac, CssExpression expression,
boolean check) throws InvalidParamException {
setByUser();
CssValue val = expression.getValue();
if (val.equals(inherit)) {
baselineshift = inherit;
expression.next();
}
else if (val.equals(baseline)) {
baselineshift = baseline;
expression.next();
}
else if (val.equals(sub)) {
baselineshift = sub;
expression.next();
}
else if (val.equals(sup)) {
baselineshift = sup;
expression.next();
}
else if (val.equals(initial)) {
baselineshift = initial;
expression.next();
}
else if (val instanceof CssPercentage) {
baselineshift = val;
expression.next();
}
else if (val instanceof CssLength) {
baselineshift = val;
expression.next();
}
else {
throw new InvalidParamException("value", expression.getValue(),
getPropertyName(), ac);
}
}
public CssBaselineShift(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).cssBaselineShift != null)
style.addRedefinitionWarning(ac, this);
((Css3Style) style).cssBaselineShift = 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).getBaselineShift();
}
else {
return ((Css3Style) style).cssBaselineShift;
}
}
/**
* Compares two properties for equality.
*
* @param value The other property.
*/
public boolean equals(CssProperty property) {
return (property instanceof CssBaselineShift &&
baselineshift.equals(((CssBaselineShift) property).baselineshift));
}
/**
* Returns the name of this property
*/
public String getPropertyName() {
return "baseline-shift";
}
/**
* Returns the value of this property
*/
public Object get() {
return baselineshift;
}
/**
* Returns true if this property is "softly" inherited
*/
public boolean isSoftlyInherited() {
return baselineshift.equals(inherit);
}
/**
* Returns a string representation of the object
*/
public String toString() {
return baselineshift.toString();
}
/**
* Is the value of this property a default value
* It is used by alle macro for the function print
*/
public boolean isDefault() {
return baselineshift == baseline;
}
}