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.OMSVGAnimatedBoolean; 33 import org.vectomatic.dom.svg.OMSVGAnimatedLength; 34 import org.vectomatic.dom.svg.OMSVGAnimatedString; 35 import org.vectomatic.dom.svg.OMSVGStringList; 36 37 /** 38 * The {@link org.vectomatic.dom.svg.impl.SVGCursorElement} interface corresponds 39 * to the <a href='http://www.w3.org/TR/SVG11/interact.html#CursorElement' 40 * title='cursor element specification'>cursor</a> element. 41 */ 42 public class SVGCursorElement extends SVGElement { 43 protected SVGCursorElement() { 44 } 45 46 // Implementation of the svg::SVGCursorElement W3C IDL interface 47 /** 48 * Corresponds to attribute {@link org.vectomatic.dom.svg.impl.SVGCursorElement#getX()} 49 * on the given <a href='http://www.w3.org/TR/SVG11/interact.html#CursorElement' 50 * title='cursor element specification'>cursor</a> element. 51 */ 52 public final native OMSVGAnimatedLength getX() /*-{ 53 return this.x; 54 }-*/; 55 /** 56 * Corresponds to attribute {@link org.vectomatic.dom.svg.impl.SVGCursorElement#getY()} 57 * on the given <a href='http://www.w3.org/TR/SVG11/interact.html#CursorElement' 58 * title='cursor element specification'>cursor</a> element. 59 */ 60 public final native OMSVGAnimatedLength getY() /*-{ 61 return this.y; 62 }-*/; 63 64 // Implementation of the svg::SVGExternalResourcesRequired W3C IDL interface 65 /** 66 * Corresponds to attribute {@link org.vectomatic.dom.svg.itf.ISVGExternalResourcesRequired#getExternalResourcesRequired()} 67 * on the given element. Note that the SVG DOM defines the attribute {@link 68 * org.vectomatic.dom.svg.itf.ISVGExternalResourcesRequired#getExternalResourcesRequired()} 69 * as being of type {@link org.vectomatic.dom.svg.OMSVGAnimatedBoolean}, whereas 70 * the SVG language definition says that {@link org.vectomatic.dom.svg.itf.ISVGExternalResourcesRequired#getExternalResourcesRequired()} 71 * is not animated. Because the SVG language definition states that {@link 72 * org.vectomatic.dom.svg.itf.ISVGExternalResourcesRequired#getExternalResourcesRequired()} 73 * cannot be animated, the {@link org.vectomatic.dom.svg.OMSVGAnimatedBoolean#getAnimVal()} 74 * will always be the same as the {@link org.vectomatic.dom.svg.OMSVGAnimatedBoolean#getBaseVal()}. 75 */ 76 public final native OMSVGAnimatedBoolean getExternalResourcesRequired() /*-{ 77 return this.externalResourcesRequired; 78 }-*/; 79 80 // Implementation of the svg::SVGTests W3C IDL interface 81 /** 82 * Corresponds to attribute {@link org.vectomatic.dom.svg.itf.ISVGTests#getRequiredFeatures()} 83 * on the given element. 84 */ 85 public final native OMSVGStringList getRequiredFeatures() /*-{ 86 return @org.vectomatic.dom.svg.OMNode::convertList(Lcom/google/gwt/core/client/JavaScriptObject;)(this.requiredFeatures); 87 }-*/; 88 /** 89 * Corresponds to attribute {@link org.vectomatic.dom.svg.itf.ISVGTests#getRequiredExtensions()} 90 * on the given element. 91 */ 92 public final native OMSVGStringList getRequiredExtensions() /*-{ 93 return @org.vectomatic.dom.svg.OMNode::convertList(Lcom/google/gwt/core/client/JavaScriptObject;)(this.requiredExtensions); 94 }-*/; 95 /** 96 * Corresponds to attribute {@link org.vectomatic.dom.svg.itf.ISVGTests#getSystemLanguage()} 97 * on the given element. 98 */ 99 public final native OMSVGStringList getSystemLanguage() /*-{ 100 return @org.vectomatic.dom.svg.OMNode::convertList(Lcom/google/gwt/core/client/JavaScriptObject;)(this.systemLanguage); 101 }-*/; 102 /** 103 * Returns true if the user agent supports the given extension, specified 104 * by a URI. 105 * @param extension The name of the extension, expressed as a URI. 106 * @return True or false, depending on whether the given extension is supported. 107 */ 108 public final native boolean hasExtension(String extension) /*-{ 109 return this.hasExtension(extension); 110 }-*/; 111 112 // Implementation of the svg::SVGURIReference W3C IDL interface 113 /** 114 * Corresponds to attribute <span class='attr-name'>'xlink:href'</span> on 115 * the given element. 116 */ 117 public final native OMSVGAnimatedString getHref() /*-{ 118 return this.href; 119 }-*/; 120 121 }