1 /********************************************** 2 * Copyright (C) 2010 Lukas Laag 3 * This file is part of lib-gwt-svg. 4 * 5 * libgwtsvg is free software: you can redistribute it and/or modify 6 * it under the terms of the GNU Lesser General Public License as published by 7 * the Free Software Foundation, either version 3 of the License, or 8 * (at your option) any later version. 9 * 10 * libgwtsvg is distributed in the hope that it will be useful, 11 * but WITHOUT ANY WARRANTY; without even the implied warranty of 12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 13 * GNU Lesser General Public License for more details. 14 * 15 * You should have received a copy of the GNU Lesser General Public License 16 * along with libgwtsvg. If not, see http://www.gnu.org/licenses/ 17 **********************************************/ 18 /* 19 * Copyright (c) 2004 World Wide Web Consortium, 20 * 21 * (Massachusetts Institute of Technology, European Research Consortium for 22 * Informatics and Mathematics, Keio University). All Rights Reserved. This 23 * work is distributed under the W3C(r) Software License [1] in the hope that 24 * it will be useful, but WITHOUT ANY WARRANTY; without even the implied 25 * warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. 26 * 27 * [1] http://www.w3.org/Consortium/Legal/2002/copyright-software-20021231 28 */ 29 30 package org.vectomatic.dom.svg.impl; 31 32 import org.vectomatic.dom.svg.OMSVGAnimatedString; 33 34 import com.google.gwt.core.client.JavaScriptException; 35 import com.google.gwt.dom.client.Element; 36 37 /** 38 * All of the SVG DOM interfaces that correspond directly to elements in the 39 * SVG language (such as the {@link org.vectomatic.dom.svg.impl.SVGPathElement} 40 * interface for the <a href='http://www.w3.org/TR/SVG11/paths.html#PathElement' 41 * title='path element specification'>path</a> element) derive from the {@link 42 * org.vectomatic.dom.svg.impl.SVGElement} interface. 43 */ 44 public class SVGElement extends Element { 45 protected SVGElement() { 46 } 47 48 // Implementation of the svg::SVGElement W3C IDL interface 49 /** 50 * Corresponds to attribute <code>xml:base</code> on the given element. 51 */ 52 public final native String getXmlbase() /*-{ 53 return this.xmlbase; 54 }-*/; 55 /** 56 * Corresponds to attribute <code>xml:base</code> on the given element. 57 * @throws DOMException(NO_MODIFICATION_ALLOWED_ERR) Raised on an attempt 58 * to change the value of a <a href="svgdom.html#ReadOnlyNodes">read only 59 * attribute</a>. 60 */ 61 public final native void setXmlbase(String value) throws JavaScriptException /*-{ 62 this.xmlbase = value; 63 }-*/; 64 /** 65 * The nearest ancestor <a href='http://www.w3.org/TR/SVG11/struct.html#SVGElement' 66 * title='svg element specification'>svg</a> element. Null if the given element 67 * is the outermost <a href='http://www.w3.org/TR/SVG11/struct.html#SVGElement' 68 * title='svg element specification'>svg</a> element. 69 */ 70 public final native SVGSVGElement getOwnerSVGElement() /*-{ 71 return this.ownerSVGElement; 72 }-*/; 73 /** 74 * The element which established the current viewport. Often, the nearest 75 * ancestor <a href='http://www.w3.org/TR/SVG11/struct.html#SVGElement' title='svg 76 * element specification'>svg</a> element. Null if the given element is the 77 * outermost <a href='http://www.w3.org/TR/SVG11/struct.html#SVGElement' title='svg 78 * element specification'>svg</a> element. 79 */ 80 public final native SVGElement getViewportElement() /*-{ 81 return this.viewportElement; 82 }-*/; 83 84 // Partial implementation of the svg::Stylable W3C IDL interface 85 // (the rest is inherited from Element) 86 public final native OMSVGAnimatedString getClassName_() /*-{ 87 return this.className; 88 }-*/; 89 90 public final native String getMarkup() /*-{ 91 return new XMLSerializer().serializeToString(this); 92 }-*/; 93 }