01: /*
02:
03: Licensed to the Apache Software Foundation (ASF) under one or more
04: contributor license agreements. See the NOTICE file distributed with
05: this work for additional information regarding copyright ownership.
06: The ASF licenses this file to You under the Apache License, Version 2.0
07: (the "License"); you may not use this file except in compliance with
08: the License. You may obtain a copy of the License at
09:
10: http://www.apache.org/licenses/LICENSE-2.0
11:
12: Unless required by applicable law or agreed to in writing, software
13: distributed under the License is distributed on an "AS IS" BASIS,
14: WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
15: See the License for the specific language governing permissions and
16: limitations under the License.
17:
18: */
19: package org.apache.batik.css.engine;
20:
21: import java.net.URL;
22:
23: import org.w3c.dom.Element;
24:
25: /**
26: * This interface must be implemented by the DOM elements which needs
27: * CSS support.
28: *
29: * @author <a href="mailto:stephane@hillion.org">Stephane Hillion</a>
30: * @version $Id: CSSStylableElement.java 475477 2006-11-15 22:44:28Z cam $
31: */
32: public interface CSSStylableElement extends Element {
33:
34: /**
35: * Returns the computed style of this element/pseudo-element.
36: */
37: StyleMap getComputedStyleMap(String pseudoElement);
38:
39: /**
40: * Sets the computed style of this element/pseudo-element.
41: */
42: void setComputedStyleMap(String pseudoElement, StyleMap sm);
43:
44: /**
45: * Returns the ID of this element.
46: */
47: String getXMLId();
48:
49: /**
50: * Returns the class of this element.
51: */
52: String getCSSClass();
53:
54: /**
55: * Returns the CSS base URL of this element.
56: */
57: URL getCSSBase();
58:
59: /**
60: * Tells whether this element is an instance of the given pseudo
61: * class.
62: */
63: boolean isPseudoInstanceOf(String pseudoClass);
64:
65: /**
66: * Returns the object that gives access to the underlying
67: * {@link StyleDeclaration} for the override style of this element.
68: */
69: StyleDeclarationProvider getOverrideStyleDeclarationProvider();
70: }
|