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 package org.vectomatic.dom.svg.events; 30 31 import com.google.gwt.event.dom.client.DomEvent; 32 import com.google.gwt.event.dom.client.DomEvent.Type; 33 34 /** 35 * This event is raised at the active end of the element. 36 * Note that this event is not raised at the simple end of each repeat. 37 * This event may be raised both in the course of normal (i.e. scheduled 38 * or interactive) timeline play, as well as in the case that the element 39 * was ended with the endElement or endElementAt methods. 40 * Note that if an element is restarted while it is currently playing, 41 * the element will raise an end event and another begin event, as the 42 * element restarts. 43 */ 44 public class EndEvent extends TimeEvent<EndHandler> { 45 private static final Type<EndHandler> TYPE = new Type<EndHandler>( 46 "end", new EndEvent()); 47 /** 48 * Necessary hack. DomEvent.fireNativeEvent uses NativeEvent.getType 49 * to retrieve the type flyweight. However, for SMIL events, the 50 * event type name is not the same as the event attribute name 51 * (onend/endEvent vs onmousedown/mousedown for example !) 52 */ 53 private static final Type<EndHandler> TYPE_ = new Type<EndHandler>( 54 "endEvent", new EndEvent()); 55 56 /** 57 * Protected constructor, use 58 * {@link DomEvent#fireNativeEvent(com.google.gwt.dom.client.NativeEvent, com.google.gwt.event.shared.HasHandlers)} 59 * to fire mouse out events. 60 */ 61 protected EndEvent() { 62 } 63 64 /** 65 * @return the handler type 66 */ 67 public Type<EndHandler> getAssociatedType() { 68 return TYPE; 69 } 70 /** 71 * @return the handler type 72 */ 73 public static Type<EndHandler> getType() { 74 return TYPE; 75 } 76 77 @Override 78 protected void dispatch(EndHandler handler) { 79 handler.onEnd(this); 80 } 81 82 }